StandardPaths updates. Added a demo sample for StandardPaths. Made
the Python install prefix be the default install prefix for StandardPaths. git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@30597 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -47,10 +47,7 @@ import images
|
|||||||
_treeList = [
|
_treeList = [
|
||||||
# new stuff
|
# new stuff
|
||||||
('Recent Additions/Updates', [
|
('Recent Additions/Updates', [
|
||||||
'StockButtons',
|
'StandardPaths',
|
||||||
'Ticker',
|
|
||||||
'Choicebook',
|
|
||||||
'ListCtrl_edit',
|
|
||||||
]),
|
]),
|
||||||
|
|
||||||
# managed windows == things with a (optional) caption you can close
|
# managed windows == things with a (optional) caption you can close
|
||||||
@@ -228,6 +225,7 @@ _treeList = [
|
|||||||
'PrintFramework',
|
'PrintFramework',
|
||||||
'ShapedWindow',
|
'ShapedWindow',
|
||||||
'Sound',
|
'Sound',
|
||||||
|
'StandardPaths',
|
||||||
'Unicode',
|
'Unicode',
|
||||||
]),
|
]),
|
||||||
|
|
||||||
@@ -254,9 +252,10 @@ class MyLog(wx.PyLog):
|
|||||||
self.logTime = logTime
|
self.logTime = logTime
|
||||||
|
|
||||||
def DoLogString(self, message, timeStamp):
|
def DoLogString(self, message, timeStamp):
|
||||||
if self.logTime:
|
#print message, timeStamp
|
||||||
message = time.strftime("%X", time.localtime(timeStamp)) + \
|
#if self.logTime:
|
||||||
": " + message
|
# message = time.strftime("%X", time.localtime(timeStamp)) + \
|
||||||
|
# ": " + message
|
||||||
if self.tc:
|
if self.tc:
|
||||||
self.tc.AppendText(message + '\n')
|
self.tc.AppendText(message + '\n')
|
||||||
|
|
||||||
|
97
wxPython/demo/StandardPaths.py
Normal file
97
wxPython/demo/StandardPaths.py
Normal file
@@ -0,0 +1,97 @@
|
|||||||
|
|
||||||
|
import wx
|
||||||
|
|
||||||
|
#----------------------------------------------------------------------
|
||||||
|
|
||||||
|
class TestPanel(wx.Panel):
|
||||||
|
def __init__(self, parent, log):
|
||||||
|
self.log = log
|
||||||
|
wx.Panel.__init__(self, parent, -1)
|
||||||
|
|
||||||
|
sizer = wx.FlexGridSizer(0, 3, 5, 5)
|
||||||
|
box = wx.BoxSizer(wx.VERTICAL)
|
||||||
|
fs = self.GetFont().GetPointSize()
|
||||||
|
bf = wx.Font(fs+4, wx.SWISS, wx.NORMAL, wx.BOLD)
|
||||||
|
|
||||||
|
t = wx.StaticText(self, -1, "StandardPaths")
|
||||||
|
t.SetFont(bf)
|
||||||
|
box.Add(t, 0, wx.CENTER|wx.ALL, 5)
|
||||||
|
box.Add(wx.StaticLine(self, -1), 0, wx.EXPAND)
|
||||||
|
|
||||||
|
# get the global (singleton) instance of wx.StandardPaths
|
||||||
|
sp = wx.StandardPaths.Get()
|
||||||
|
|
||||||
|
# StandardPaths will use the value of wx.App().GetAppName()
|
||||||
|
# for some of the stnadard path components. Let's set it to
|
||||||
|
# something that makes that obvious for the demo. In your own
|
||||||
|
# apps you'll set it in to something more meaningfull for your
|
||||||
|
# app in your OnInit, (or just let it default.)
|
||||||
|
wx.GetApp().SetAppName("AppName")
|
||||||
|
|
||||||
|
self.help = {}
|
||||||
|
|
||||||
|
# Loop through all of the getters in wx.StandardPaths and make
|
||||||
|
# a set of items in the sizer for each.
|
||||||
|
for x in ['GetConfigDir',
|
||||||
|
'GetUserConfigDir',
|
||||||
|
'GetDataDir',
|
||||||
|
'GetLocalDataDir',
|
||||||
|
'GetUserDataDir',
|
||||||
|
'GetUserLocalDataDir',
|
||||||
|
'GetPluginsDir',
|
||||||
|
'GetInstallPrefix',
|
||||||
|
]:
|
||||||
|
func = getattr(sp, x)
|
||||||
|
sizer.Add(wx.StaticText(self, -1, x+'():'), 0,
|
||||||
|
wx.ALIGN_RIGHT|wx.ALIGN_CENTER_VERTICAL)
|
||||||
|
sizer.Add(wx.TextCtrl(self, -1, func(), size=(275,-1), style=wx.TE_READONLY))
|
||||||
|
|
||||||
|
btn = wx.Button(self, wx.ID_HELP)
|
||||||
|
sizer.Add(btn)
|
||||||
|
self.help[btn] = func.__doc__
|
||||||
|
|
||||||
|
self.Bind(wx.EVT_BUTTON, self.OnShowDoc, id=wx.ID_HELP)
|
||||||
|
|
||||||
|
box.Add(sizer, 0, wx.CENTER|wx.ALL, 25)
|
||||||
|
self.SetSizer(box)
|
||||||
|
|
||||||
|
|
||||||
|
def OnShowDoc(self, evt):
|
||||||
|
doc = self.help[evt.GetEventObject()]
|
||||||
|
|
||||||
|
# trim the whitespace from each line
|
||||||
|
lines = []
|
||||||
|
for line in doc.split('\n'):
|
||||||
|
lines.append(line.strip())
|
||||||
|
doc = '\n'.join(lines)
|
||||||
|
wx.TipWindow(self, doc, 500)
|
||||||
|
|
||||||
|
|
||||||
|
#----------------------------------------------------------------------
|
||||||
|
|
||||||
|
def runTest(frame, nb, log):
|
||||||
|
win = TestPanel(nb, log)
|
||||||
|
return win
|
||||||
|
|
||||||
|
#----------------------------------------------------------------------
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
overview = """<html><body>
|
||||||
|
<h2><center>StandardPaths</center></h2>
|
||||||
|
|
||||||
|
wxWidgets provides this class to simply determine where to locate
|
||||||
|
certain types of files in a platform specific manner. This includes
|
||||||
|
things like configuration files, general data files writeable by the
|
||||||
|
user, and application files that are shared by all user.
|
||||||
|
|
||||||
|
</body></html>
|
||||||
|
"""
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
import sys,os
|
||||||
|
import run
|
||||||
|
run.main(['', os.path.basename(sys.argv[0])] + sys.argv[1:])
|
||||||
|
|
@@ -1,5 +1,5 @@
|
|||||||
|
|
||||||
import wx # This module uses the new wx namespace
|
import wx
|
||||||
|
|
||||||
#----------------------------------------------------------------------
|
#----------------------------------------------------------------------
|
||||||
|
|
||||||
|
@@ -165,6 +165,9 @@ your Mac."""
|
|||||||
if redirect:
|
if redirect:
|
||||||
self.RedirectStdio(filename)
|
self.RedirectStdio(filename)
|
||||||
|
|
||||||
|
# Use Python's install prefix as the default
|
||||||
|
wx.StandardPaths.Get().SetInstallPrefix(_sys.prefix)
|
||||||
|
|
||||||
# This finishes the initialization of wxWindows and then calls
|
# This finishes the initialization of wxWindows and then calls
|
||||||
# the OnInit that should be present in the derived class
|
# the OnInit that should be present in the derived class
|
||||||
self._BootstrapApp()
|
self._BootstrapApp()
|
||||||
|
@@ -53,22 +53,29 @@ class doesn't help you to do it.", "");
|
|||||||
class wxStandardPaths
|
class wxStandardPaths
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
|
||||||
DocDeclStr(
|
DocStr(
|
||||||
static wxStandardPaths& , Get(),
|
Get,
|
||||||
"Return the global standard paths object", "");
|
"Return the global standard paths singleton", "");
|
||||||
|
%extend {
|
||||||
|
static wxStandardPaths* Get() {
|
||||||
|
return (wxStandardPaths*) &wxStandardPaths::Get();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
DocDeclStr(
|
DocDeclStr(
|
||||||
virtual wxString , GetConfigDir() const,
|
virtual wxString , GetConfigDir() const,
|
||||||
"Return the directory with system config files: /etc under Unix,
|
"Return the directory with system config files: /etc under Unix,
|
||||||
c:\Documents and Settings\All Users\Application Data under Windows,
|
'c:\\Documents and Settings\\All Users\\Application Data' under Windows,
|
||||||
/Library/Preferences for Mac", "");
|
/Library/Preferences for Mac", "");
|
||||||
|
|
||||||
|
|
||||||
DocDeclStr(
|
DocDeclStr(
|
||||||
virtual wxString , GetUserConfigDir() const,
|
virtual wxString , GetUserConfigDir() const,
|
||||||
"Return the directory for the user config files: $HOME under Unix,
|
"Return the directory for the user config files: $HOME under Unix,
|
||||||
c:\Documents and Settings\username under Windows,
|
'c:\\Documents and Settings\\username' under Windows, and
|
||||||
~/Library/Preferences under Mac
|
~/Library/Preferences under Mac
|
||||||
|
|
||||||
Only use this if you have a single file to put there, otherwise
|
Only use this if you have a single file to put there, otherwise
|
||||||
@@ -79,7 +86,7 @@ Only use this if you have a single file to put there, otherwise
|
|||||||
virtual wxString , GetDataDir() const,
|
virtual wxString , GetDataDir() const,
|
||||||
"Return the location of the application's global, (i.e. not
|
"Return the location of the application's global, (i.e. not
|
||||||
user-specific,) data files: prefix/share/appname under Unix,
|
user-specific,) data files: prefix/share/appname under Unix,
|
||||||
c:\Program Files\appname under Windows,
|
'c:\\Program Files\\appname' under Windows,
|
||||||
appname.app/Contents/SharedSupport app bundle directory under Mac.", "");
|
appname.app/Contents/SharedSupport app bundle directory under Mac.", "");
|
||||||
|
|
||||||
|
|
||||||
@@ -93,8 +100,8 @@ host-specific. Same as `GetDataDir` except under Unix where it is
|
|||||||
DocDeclStr(
|
DocDeclStr(
|
||||||
virtual wxString , GetUserDataDir() const,
|
virtual wxString , GetUserDataDir() const,
|
||||||
"Return the directory for the user-dependent application data files:
|
"Return the directory for the user-dependent application data files:
|
||||||
$HOME/.appname under Unix, c:\Documents and
|
$HOME/.appname under Unix, c:\\Documents and
|
||||||
Settings\username\Application Data\appname under Windows and
|
Settings\\username\\Application Data\\appname under Windows and
|
||||||
~/Library/Application Support/appname under Mac", "");
|
~/Library/Application Support/appname under Mac", "");
|
||||||
|
|
||||||
|
|
||||||
@@ -104,7 +111,7 @@ Settings\username\Application Data\appname under Windows and
|
|||||||
with the other machines
|
with the other machines
|
||||||
|
|
||||||
Same as `GetUserDataDir` for all platforms except Windows where it is
|
Same as `GetUserDataDir` for all platforms except Windows where it is
|
||||||
the 'Local Settings\Application Data\appname' directory.", "");
|
the 'Local Settings\\Application Data\\appname' directory.", "");
|
||||||
|
|
||||||
|
|
||||||
DocDeclStr(
|
DocDeclStr(
|
||||||
@@ -119,12 +126,14 @@ Contents/Plugins app bundle subdirectory under Mac", "");
|
|||||||
void , SetInstallPrefix(const wxString& prefix),
|
void , SetInstallPrefix(const wxString& prefix),
|
||||||
"Set the program installation directory which is /usr/local by default.
|
"Set the program installation directory which is /usr/local by default.
|
||||||
This value will be used by other methods such as `GetDataDir` and
|
This value will be used by other methods such as `GetDataDir` and
|
||||||
`GetPluginsDir` as the prefix for what they return. (Unix only.)", "");
|
`GetPluginsDir` as the prefix for what they return. (This function
|
||||||
|
only has meaning on Unix systems.)", "");
|
||||||
|
|
||||||
|
|
||||||
DocDeclStr(
|
DocDeclStr(
|
||||||
wxString , GetInstallPrefix() const,
|
wxString , GetInstallPrefix() const,
|
||||||
"Get the program installation prefix. (Unix only.)", "");
|
"Get the program installation prefix. The default is the prefix where
|
||||||
|
Python is installed. (This function only has meaning on Unix systems.)", "");
|
||||||
#else
|
#else
|
||||||
%extend {
|
%extend {
|
||||||
void SetInstallPrefix(const wxString& prefix) {}
|
void SetInstallPrefix(const wxString& prefix) {}
|
||||||
|
Reference in New Issue
Block a user