mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-01-12 15:36:17 +01:00
GOptionContext: add some notes about encodings
Add a note to the overview documentation for GOptionContext about why you need to be careful about argv encoding on UNIX and about why you should avoid argv entirely on Windows. Mention some possible alternative approaches, including a code example. https://bugzilla.gnome.org/show_bug.cgi?id=722025
This commit is contained in:
parent
e5f91951a1
commit
258ac3b253
@ -130,6 +130,57 @@
|
||||
*
|
||||
* }
|
||||
* </programlisting></informalexample>
|
||||
*
|
||||
* On UNIX systems, the argv that is passed to main() has no particular
|
||||
* encoding, even to the extent that different parts of it may have
|
||||
* different encodings. In general, normal arguments and flags will be
|
||||
* in the current locale and filenames should be considered to be opaque
|
||||
* byte strings. Proper use of %G_OPTION_ARG_FILENAME vs
|
||||
* %G_OPTION_ARG_STRING is therefore important.
|
||||
*
|
||||
* Note that on Windows, filenames do have an encoding, but using
|
||||
* #GOptionContext with the argv as passed to main() will result in a
|
||||
* program that can only accept commandline arguments with characters
|
||||
* from the system codepage. This can cause problems when attempting to
|
||||
* deal with filenames containing Unicode characters that fall outside
|
||||
* of the codepage.
|
||||
*
|
||||
* A solution to this is to use g_win32_get_command_line() and
|
||||
* g_option_context_parse_strv() which will properly handle full Unicode
|
||||
* filenames. If you are using #GApplication, this is done
|
||||
* automatically for you.
|
||||
*
|
||||
* The following example shows how you can use #GOptionContext directly
|
||||
* in order to correctly deal with Unicode filenames on Windows:
|
||||
*
|
||||
* |[
|
||||
* int
|
||||
* main (int argc, char **argv)
|
||||
* {
|
||||
* GError *error = NULL;
|
||||
* GOptionContext *context;
|
||||
* gchar **args;
|
||||
*
|
||||
* #ifdef G_OS_WIN32
|
||||
* args = g_win32_get_command_line ();
|
||||
* #else
|
||||
* args = g_strdupv (argv);
|
||||
* #endif
|
||||
*
|
||||
* /* ... setup context ... */
|
||||
*
|
||||
* if (!g_option_context_parse_strv (context, &args, &error))
|
||||
* {
|
||||
* /* ... error ... */
|
||||
* }
|
||||
*
|
||||
* /* ... */
|
||||
*
|
||||
* g_strfreev (args);
|
||||
*
|
||||
* /* ... */
|
||||
* }
|
||||
* ]|
|
||||
*/
|
||||
|
||||
#include "config.h"
|
||||
|
Loading…
Reference in New Issue
Block a user