]> git.saurik.com Git - wxWidgets.git/blame - include/wx/msw/stdpaths.h
fixes #13557
[wxWidgets.git] / include / wx / msw / stdpaths.h
CommitLineData
40e8ee37
VZ
1///////////////////////////////////////////////////////////////////////////////
2// Name: wx/msw/stdpaths.h
3// Purpose: wxStandardPaths for Win32
4// Author: Vadim Zeitlin
5// Modified by:
6// Created: 2004-10-19
7// RCS-ID: $Id$
8// Copyright: (c) 2004 Vadim Zeitlin <vadim@wxwindows.org>
9// Licence: wxWindows licence
10///////////////////////////////////////////////////////////////////////////////
11
12#ifndef _WX_MSW_STDPATHS_H_
13#define _WX_MSW_STDPATHS_H_
14
15// ----------------------------------------------------------------------------
16// wxStandardPaths
17// ----------------------------------------------------------------------------
18
19class WXDLLIMPEXP_BASE wxStandardPaths : public wxStandardPathsBase
20{
21public:
4cd15b49
VZ
22 // ctor calls IgnoreAppBuildSubDirs() and also sets up the object to use
23 // both vendor and application name by default
24 wxStandardPaths();
2b147f2e 25
40e8ee37 26 // implement base class pure virtuals
ac7ad70d 27 virtual wxString GetExecutablePath() const;
40e8ee37
VZ
28 virtual wxString GetConfigDir() const;
29 virtual wxString GetUserConfigDir() const;
30 virtual wxString GetDataDir() const;
31 virtual wxString GetUserDataDir() const;
32 virtual wxString GetUserLocalDataDir() const;
33 virtual wxString GetPluginsDir() const;
17af82fb 34 virtual wxString GetDocumentsDir() const;
40e8ee37 35
4cd15b49
VZ
36
37 // MSW-specific methods
38
39 // This class supposes that data, plugins &c files are located under the
40 // program directory which is the directory containing the application
41 // binary itself. But sometimes this binary may be in a subdirectory of the
42 // main program directory, e.g. this happens in at least the following
43 // common cases:
44 // 1. The program is in "bin" subdirectory of the installation directory.
45 // 2. The program is in "debug" subdirectory of the directory containing
46 // sources and data files during development
47 //
48 // By calling this function you instruct the class to remove the last
49 // component of the path if it matches its argument. Notice that it may be
50 // called more than once, e.g. you can call both IgnoreAppSubDir("bin") and
51 // IgnoreAppSubDir("debug") to take care of both production and development
52 // cases above but that each call will only remove the last path component.
53 // Finally note that the argument can contain wild cards so you can also
54 // call IgnoreAppSubDir("vc*msw*") to ignore all build directories at once
55 // when using wxWidgets-inspired output directories names.
56 void IgnoreAppSubDir(const wxString& subdirPattern);
57
58 // This function is used to ignore all common build directories and is
59 // called from the ctor -- use DontIgnoreAppSubDir() to undo this.
60 void IgnoreAppBuildSubDirs();
61
62 // Undo the effects of all preceding IgnoreAppSubDir() calls.
63 void DontIgnoreAppSubDir();
64
94aff795
VZ
65
66 // Returns the directory corresponding to the specified Windows shell CSIDL
67 static wxString MSWGetShellDir(int csidl);
68
40e8ee37 69protected:
40e8ee37
VZ
70 // get the path corresponding to the given standard CSIDL_XXX constant
71 static wxString DoGetDirectory(int csidl);
adaa49a8
VZ
72
73 // return the directory of the application itself
4cd15b49
VZ
74 wxString GetAppDir() const;
75
76 // directory returned by GetAppDir()
77 mutable wxString m_appDir;
40e8ee37
VZ
78};
79
80// ----------------------------------------------------------------------------
81// wxStandardPathsWin16: this class is for internal use only
82// ----------------------------------------------------------------------------
83
84// override config file locations to be compatible with the values used by
85// wxFileConfig (dating from Win16 days which explains the class name)
86class WXDLLIMPEXP_BASE wxStandardPathsWin16 : public wxStandardPaths
87{
88public:
89 virtual wxString GetConfigDir() const;
90 virtual wxString GetUserConfigDir() const;
91};
92
93#endif // _WX_MSW_STDPATHS_H_