Document and improve system options definition in the environment.

Document that system options can be defined in the environment.

Replace another character (dash) invalid in environment variable names but
present in some standard system option names with underscore.

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@64651 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Vadim Zeitlin 2010-06-20 17:43:15 +00:00
parent e95f081682
commit aa0af8ce54
2 changed files with 13 additions and 0 deletions

View File

@ -14,6 +14,18 @@
used to optimize behaviour that doesn't deserve a distinct API,
but is still important to be able to configure.
System options can be set by the program itself using SetOption() method
and they also can be set from the program environment by defining an
environment variable @c wx_option to set the given option for all wxWidgets
applications or @c wx_appname_option to set it just for the application
with the given name (as returned by wxApp::GetAppName()). Notice that any
characters not allowed in the environment variables names, such as periods
and dashes, should be replaced with underscores. E.g. to define a system
option "foo-bar" you need to define the environment variable "wx_foo_bar".
The program may use system options for its own needs but they are mostly
used to control the behaviour of wxWidgets library itself.
These options are currently recognised by wxWidgets:

View File

@ -83,6 +83,7 @@ wxString wxSystemOptions::GetOption(const wxString& name)
// and then for "wx_name" which can be set to change the option globally
wxString var(name);
var.Replace(wxT("."), wxT("_")); // '.'s not allowed in env var names
var.Replace(wxT("-"), wxT("_")); // and neither are '-'s
wxString appname;
if ( wxTheApp )