Compilation fixes
[wxWidgets.git] / wxPython / src / _stdpaths.i
CommitLineData
53112743
RD
1/////////////////////////////////////////////////////////////////////////////
2// Name: _stdpaths.i
3// Purpose: SWIG interface for wxStandardPaths
4//
5// Author: Robin Dunn
6//
7// Created: 10-Nov-2004
8// RCS-ID: $Id$
9// Copyright: (c) 2004 by Total Control Software
10// Licence: wxWindows license
11/////////////////////////////////////////////////////////////////////////////
12
13// Not a %module
14
15
16//---------------------------------------------------------------------------
17
18%{
19#include <wx/stdpaths.h>
20%}
21
22
23//---------------------------------------------------------------------------
24%newgroup
25
26DocStr(wxStandardPaths,
b8c4ab9c
RD
27"wx.StandardPaths returns standard locations in the file system and
28should be used by programs to find their data files in a portable way.
53112743
RD
29
30In the description of the methods below, the example return values are
31given for the Unix, Windows and Mac OS X systems, however please note
b8c4ab9c
RD
32that these are just examples and the actual values may differ. For
33example, under Windows the system administrator may change the
53112743
RD
34standard directories locations, i.e. the Windows directory may be
35named W:\Win2003 instead of the default C:\Windows.
36
37The strings appname and username should be replaced with the value
38returned by `wx.App.GetAppName` and the name of the currently logged
39in user, respectively. The string prefix is only used under Unix and
40is /usr/local by default but may be changed using `SetInstallPrefix`.
41
42The directories returned by the methods of this class may or may not
43exist. If they don't exist, it's up to the caller to create them,
b8c4ab9c 44wx.StandardPaths doesn't do it.
53112743
RD
45
46Finally note that these functions only work with standardly packaged
47applications. I.e. under Unix you should follow the standard
48installation conventions and under Mac you should create your
49application bundle according to the Apple guidelines. Again, this
50class doesn't help you to do it.", "");
51
52class wxStandardPaths
53{
54public:
b8c4ab9c
RD
55 // possible resources categorires
56 enum ResourceCat
57 {
58 // no special category
59 ResourceCat_None,
60
61 // message catalog resources
62 ResourceCat_Messages,
63
64 // end of enum marker
65 ResourceCat_Max
66 };
62038e59
RD
67
68 DocStr(
69 Get,
70 "Return the global standard paths singleton", "");
71 %extend {
72 static wxStandardPaths* Get() {
73 return (wxStandardPaths*) &wxStandardPaths::Get();
74 }
75 }
76
77
428947f3
RD
78 DocDeclStr(
79 virtual wxString , GetExecutablePath() const,
80 "Return the path (directory+filename) of the running executable or an
81empty string if it couldn't be determined. The path is returned as an
82absolute path whenever possible.", "");
83
53112743
RD
84
85 DocDeclStr(
86 virtual wxString , GetConfigDir() const,
87 "Return the directory with system config files: /etc under Unix,
62038e59 88'c:\\Documents and Settings\\All Users\\Application Data' under Windows,
53112743
RD
89/Library/Preferences for Mac", "");
90
91
92 DocDeclStr(
93 virtual wxString , GetUserConfigDir() const,
94 "Return the directory for the user config files: $HOME under Unix,
62038e59 95'c:\\Documents and Settings\\username' under Windows, and
53112743
RD
96~/Library/Preferences under Mac
97
98Only use this if you have a single file to put there, otherwise
99`GetUserDataDir` is more appropriate", "");
100
101
102 DocDeclStr(
103 virtual wxString , GetDataDir() const,
104 "Return the location of the application's global, (i.e. not
105user-specific,) data files: prefix/share/appname under Unix,
62038e59 106'c:\\Program Files\\appname' under Windows,
53112743
RD
107appname.app/Contents/SharedSupport app bundle directory under Mac.", "");
108
109
110 DocDeclStr(
111 virtual wxString , GetLocalDataDir() const,
112 "Return the location for application data files which are
113host-specific. Same as `GetDataDir` except under Unix where it is
114/etc/appname", "");
115
116
117 DocDeclStr(
118 virtual wxString , GetUserDataDir() const,
119 "Return the directory for the user-dependent application data files:
62038e59
RD
120$HOME/.appname under Unix, c:\\Documents and
121Settings\\username\\Application Data\\appname under Windows and
53112743
RD
122~/Library/Application Support/appname under Mac", "");
123
124
125 DocDeclStr(
126 virtual wxString , GetUserLocalDataDir() const,
127 "Return the directory for user data files which shouldn't be shared
128with the other machines
129
130Same as `GetUserDataDir` for all platforms except Windows where it is
62038e59 131the 'Local Settings\\Application Data\\appname' directory.", "");
53112743
RD
132
133
134 DocDeclStr(
135 virtual wxString , GetPluginsDir() const,
136 "Return the directory where the loadable modules (plugins) live:
137prefix/lib/appname under Unix, program directory under Windows and
138Contents/Plugins app bundle subdirectory under Mac", "");
139
bb6e96a9 140
b8c4ab9c
RD
141 // get resources directory: resources are auxiliary files used by the
142 // application and include things like image and sound files
143 //
144 // same as GetDataDir() for all platforms except Mac where it returns
145 // Contents/Resources subdirectory of the app bundle
146 DocDeclStr(
147 virtual wxString , GetResourcesDir() const,
148 "Get resources directory. Resources are auxiliary files used by the
149application and include things like image and sound files.
150
151Same as `GetDataDir` for all platforms except Mac where it returns
152Contents/Resources subdirectory of the app bundle.", "");
153
154
155 DocDeclStr(
156 virtual wxString ,
157 GetLocalizedResourcesDir(const wxString& lang,
158 ResourceCat category = ResourceCat_None) const,
159 "Get localized resources directory containing the resource files of the
160specified category for the given language.
161
162In general this is just GetResourcesDir()/lang under Windows and Unix
163and GetResourcesDir()/lang.lproj under Mac but is something quite
164different under Unix for the message catalog category (namely the
165standard prefix/share/locale/lang/LC_MESSAGES.)", "");
166
46992103
RD
167 DocDeclStr(
168 virtual wxString , GetDocumentsDir() const,
169 "Return the Documents directory for the current user.
170
171C:\Documents and Settings\username\Documents under Windows,
172$HOME under Unix and ~/Documents under Mac", "");
173
ae8635b6
RD
174 DocDeclStr(
175 virtual wxString , GetTempDir() const,
176 "Return the user's directory for temporary files.", "");
177
53112743 178
bb6e96a9
RD
179 DocStr(SetInstallPrefix,
180 "Set the program installation directory which is /usr/local by default.
53112743 181This value will be used by other methods such as `GetDataDir` and
62038e59
RD
182`GetPluginsDir` as the prefix for what they return. (This function
183only has meaning on Unix systems.)", "");
53112743 184
bb6e96a9
RD
185 DocStr(GetInstallPrefix,
186 "Get the program installation prefix. The default is the prefix where
62038e59 187Python is installed. (This function only has meaning on Unix systems.)", "");
bb6e96a9
RD
188
189#ifdef __WXGTK__
190 void SetInstallPrefix(const wxString& prefix);
191 wxString GetInstallPrefix() const;
53112743
RD
192#else
193 %extend {
194 void SetInstallPrefix(const wxString& prefix) {}
195 wxString GetInstallPrefix() { return wxEmptyString; }
196 }
197#endif
198};
199
200
201//---------------------------------------------------------------------------