1 /* 2 * This file is part of gtkD. 3 * 4 * gtkD is free software; you can redistribute it and/or modify 5 * it under the terms of the GNU Lesser General Public License 6 * as published by the Free Software Foundation; either version 3 7 * of the License, or (at your option) any later version, with 8 * some exceptions, please read the COPYING file. 9 * 10 * gtkD is distributed in the hope that it will be useful, 11 * but WITHOUT ANY WARRANTY; without even the implied warranty of 12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 13 * GNU Lesser General Public License for more details. 14 * 15 * You should have received a copy of the GNU Lesser General Public License 16 * along with gtkD; if not, write to the Free Software 17 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110, USA 18 */ 19 20 // generated automatically - do not change 21 // find conversion definition on APILookup.txt 22 // implement new conversion functionalities on the wrap.utils pakage 23 24 25 module glib.Util; 26 27 private import glib.Str; 28 private import glib.c.functions; 29 public import glib.c.types; 30 public import gtkc.glibtypes; 31 32 33 /** */ 34 public struct Util 35 { 36 /** 37 * Behaves exactly like g_build_filename(), but takes the path elements 38 * as a string array, instead of varargs. This function is mainly 39 * meant for language bindings. 40 * 41 * Params: 42 * args = strings containing the path elements. 43 * 44 * Return: a newly-allocated string that must be freed with g_free(). 45 * 46 * Since: 2.8 47 */ 48 public static string buildFilename(string[] firstElement ... ) 49 { 50 return Str.toString(g_build_filenamev(Str.toStringzArray(firstElement))); 51 } 52 53 /** 54 * Behaves exactly like g_build_path(), but takes the path elements 55 * as a string array, instead of varargs. This function is mainly 56 * meant for language bindings. 57 * 58 * Params: 59 * separator = a string used to separator the elements of the path. 60 * args = strings containing the path elements. 61 * 62 * Return: a newly-allocated string that must be freed with g_free(). 63 * 64 * Since: 2.8 65 */ 66 public static string buildPath(string separator, string[] firstElement ... ) 67 { 68 return Str.toString(g_build_pathv(Str.toStringz(separator), Str.toStringzArray(firstElement))); 69 } 70 71 /** 72 */ 73 74 /** 75 * Specifies a function to be called at normal program termination. 76 * 77 * Since GLib 2.8.2, on Windows g_atexit() actually is a preprocessor 78 * macro that maps to a call to the atexit() function in the C 79 * library. This means that in case the code that calls g_atexit(), 80 * i.e. atexit(), is in a DLL, the function will be called when the 81 * DLL is detached from the program. This typically makes more sense 82 * than that the function is called when the GLib DLL is detached, 83 * which happened earlier when g_atexit() was a function in the GLib 84 * DLL. 85 * 86 * The behaviour of atexit() in the context of dynamically loaded 87 * modules is not formally specified and varies wildly. 88 * 89 * On POSIX systems, calling g_atexit() (or atexit()) in a dynamically 90 * loaded module which is unloaded before the program terminates might 91 * well cause a crash at program exit. 92 * 93 * Some POSIX systems implement atexit() like Windows, and have each 94 * dynamically loaded module maintain an own atexit chain that is 95 * called when the module is unloaded. 96 * 97 * On other POSIX systems, before a dynamically loaded module is 98 * unloaded, the registered atexit functions (if any) residing in that 99 * module are called, regardless where the code that registered them 100 * resided. This is presumably the most robust approach. 101 * 102 * As can be seen from the above, for portability it's best to avoid 103 * calling g_atexit() (or atexit()) except in the main executable of a 104 * program. 105 * 106 * Deprecated: It is best to avoid g_atexit(). 107 * 108 * Params: 109 * func = the function to call on normal program termination. 110 */ 111 public static void atexit(GVoidFunc func) 112 { 113 g_atexit(func); 114 } 115 116 /** 117 * Gets the name of the file without any leading directory 118 * components. It returns a pointer into the given file name 119 * string. 120 * 121 * Deprecated: Use g_path_get_basename() instead, but notice 122 * that g_path_get_basename() allocates new memory for the 123 * returned string, unlike this function which returns a pointer 124 * into the argument. 125 * 126 * Params: 127 * fileName = the name of the file 128 * 129 * Returns: the name of the file without any leading 130 * directory components 131 */ 132 public static string basename(string fileName) 133 { 134 return Str.toString(g_basename(Str.toStringz(fileName))); 135 } 136 137 /** 138 * Find the position of the first bit set in @mask, searching 139 * from (but not including) @nth_bit upwards. Bits are numbered 140 * from 0 (least significant) to sizeof(#gulong) * 8 - 1 (31 or 63, 141 * usually). To start searching from the 0th bit, set @nth_bit to -1. 142 * 143 * Params: 144 * mask = a #gulong containing flags 145 * nthBit = the index of the bit to start the search from 146 * 147 * Returns: the index of the first bit set which is higher than @nth_bit, or -1 148 * if no higher bits are set 149 */ 150 public static int bitNthLsf(gulong mask, int nthBit) 151 { 152 return g_bit_nth_lsf(mask, nthBit); 153 } 154 155 /** 156 * Find the position of the first bit set in @mask, searching 157 * from (but not including) @nth_bit downwards. Bits are numbered 158 * from 0 (least significant) to sizeof(#gulong) * 8 - 1 (31 or 63, 159 * usually). To start searching from the last bit, set @nth_bit to 160 * -1 or GLIB_SIZEOF_LONG * 8. 161 * 162 * Params: 163 * mask = a #gulong containing flags 164 * nthBit = the index of the bit to start the search from 165 * 166 * Returns: the index of the first bit set which is lower than @nth_bit, or -1 167 * if no lower bits are set 168 */ 169 public static int bitNthMsf(gulong mask, int nthBit) 170 { 171 return g_bit_nth_msf(mask, nthBit); 172 } 173 174 /** 175 * Gets the number of bits used to hold @number, 176 * e.g. if @number is 4, 3 bits are needed. 177 * 178 * Params: 179 * number = a #guint 180 * 181 * Returns: the number of bits used to hold @number 182 */ 183 public static uint bitStorage(gulong number) 184 { 185 return g_bit_storage(number); 186 } 187 188 /** 189 * Returns the value of the environment variable @variable in the 190 * provided list @envp. 191 * 192 * Params: 193 * envp = an environment list (eg, as returned from g_get_environ()), or %NULL 194 * for an empty environment list 195 * variable = the environment variable to get 196 * 197 * Returns: the value of the environment variable, or %NULL if 198 * the environment variable is not set in @envp. The returned 199 * string is owned by @envp, and will be freed if @variable is 200 * set or unset again. 201 * 202 * Since: 2.32 203 */ 204 public static string environGetenv(string[] envp, string variable) 205 { 206 return Str.toString(g_environ_getenv(Str.toStringzArray(envp), Str.toStringz(variable))); 207 } 208 209 /** 210 * Sets the environment variable @variable in the provided list 211 * @envp to @value. 212 * 213 * Params: 214 * envp = an environment list that can be freed using g_strfreev() (e.g., as 215 * returned from g_get_environ()), or %NULL for an empty 216 * environment list 217 * variable = the environment variable to set, must not 218 * contain '=' 219 * value = the value for to set the variable to 220 * overwrite = whether to change the variable if it already exists 221 * 222 * Returns: the updated environment list. Free it using g_strfreev(). 223 * 224 * Since: 2.32 225 */ 226 public static string[] environSetenv(string[] envp, string variable, string value, bool overwrite) 227 { 228 auto retStr = g_environ_setenv(Str.toStringzArray(envp), Str.toStringz(variable), Str.toStringz(value), overwrite); 229 230 scope(exit) Str.freeStringArray(retStr); 231 return Str.toStringArray(retStr); 232 } 233 234 /** 235 * Removes the environment variable @variable from the provided 236 * environment @envp. 237 * 238 * Params: 239 * envp = an environment list that can be freed using g_strfreev() (e.g., as 240 * returned from g_get_environ()), or %NULL for an empty environment list 241 * variable = the environment variable to remove, must not 242 * contain '=' 243 * 244 * Returns: the updated environment list. Free it using g_strfreev(). 245 * 246 * Since: 2.32 247 */ 248 public static string[] environUnsetenv(string[] envp, string variable) 249 { 250 auto retStr = g_environ_unsetenv(Str.toStringzArray(envp), Str.toStringz(variable)); 251 252 scope(exit) Str.freeStringArray(retStr); 253 return Str.toStringArray(retStr); 254 } 255 256 /** 257 * Locates the first executable named @program in the user's path, in the 258 * same way that execvp() would locate it. Returns an allocated string 259 * with the absolute path name, or %NULL if the program is not found in 260 * the path. If @program is already an absolute path, returns a copy of 261 * @program if @program exists and is executable, and %NULL otherwise. 262 * 263 * On Windows, if @program does not have a file type suffix, tries 264 * with the suffixes .exe, .cmd, .bat and .com, and the suffixes in 265 * the `PATHEXT` environment variable. 266 * 267 * On Windows, it looks for the file in the same way as CreateProcess() 268 * would. This means first in the directory where the executing 269 * program was loaded from, then in the current directory, then in the 270 * Windows 32-bit system directory, then in the Windows directory, and 271 * finally in the directories in the `PATH` environment variable. If 272 * the program is found, the return value contains the full name 273 * including the type suffix. 274 * 275 * Params: 276 * program = a program name in the GLib file name encoding 277 * 278 * Returns: a newly-allocated string with the absolute path, 279 * or %NULL 280 */ 281 public static string findProgramInPath(string program) 282 { 283 auto retStr = g_find_program_in_path(Str.toStringz(program)); 284 285 scope(exit) Str.freeString(retStr); 286 return Str.toString(retStr); 287 } 288 289 /** 290 * Formats a size (for example the size of a file) into a human readable 291 * string. Sizes are rounded to the nearest size prefix (kB, MB, GB) 292 * and are displayed rounded to the nearest tenth. E.g. the file size 293 * 3292528 bytes will be converted into the string "3.2 MB". 294 * 295 * The prefix units base is 1000 (i.e. 1 kB is 1000 bytes). 296 * 297 * This string should be freed with g_free() when not needed any longer. 298 * 299 * See g_format_size_full() for more options about how the size might be 300 * formatted. 301 * 302 * Params: 303 * size = a size in bytes 304 * 305 * Returns: a newly-allocated formatted string containing a human readable 306 * file size 307 * 308 * Since: 2.30 309 */ 310 public static string formatSize(ulong size) 311 { 312 auto retStr = g_format_size(size); 313 314 scope(exit) Str.freeString(retStr); 315 return Str.toString(retStr); 316 } 317 318 /** 319 * Formats a size (for example the size of a file) into a human 320 * readable string. Sizes are rounded to the nearest size prefix 321 * (KB, MB, GB) and are displayed rounded to the nearest tenth. 322 * E.g. the file size 3292528 bytes will be converted into the 323 * string "3.1 MB". 324 * 325 * The prefix units base is 1024 (i.e. 1 KB is 1024 bytes). 326 * 327 * This string should be freed with g_free() when not needed any longer. 328 * 329 * Deprecated: This function is broken due to its use of SI 330 * suffixes to denote IEC units. Use g_format_size() instead. 331 * 332 * Params: 333 * size = a size in bytes 334 * 335 * Returns: a newly-allocated formatted string containing a human 336 * readable file size 337 * 338 * Since: 2.16 339 */ 340 public static string formatSizeForDisplay(long size) 341 { 342 auto retStr = g_format_size_for_display(size); 343 344 scope(exit) Str.freeString(retStr); 345 return Str.toString(retStr); 346 } 347 348 /** 349 * Formats a size. 350 * 351 * This function is similar to g_format_size() but allows for flags 352 * that modify the output. See #GFormatSizeFlags. 353 * 354 * Params: 355 * size = a size in bytes 356 * flags = #GFormatSizeFlags to modify the output 357 * 358 * Returns: a newly-allocated formatted string containing a human 359 * readable file size 360 * 361 * Since: 2.30 362 */ 363 public static string formatSizeFull(ulong size, GFormatSizeFlags flags) 364 { 365 auto retStr = g_format_size_full(size, flags); 366 367 scope(exit) Str.freeString(retStr); 368 return Str.toString(retStr); 369 } 370 371 /** 372 * Gets a human-readable name for the application, as set by 373 * g_set_application_name(). This name should be localized if 374 * possible, and is intended for display to the user. Contrast with 375 * g_get_prgname(), which gets a non-localized name. If 376 * g_set_application_name() has not been called, returns the result of 377 * g_get_prgname() (which may be %NULL if g_set_prgname() has also not 378 * been called). 379 * 380 * Returns: human-readable application name. may return %NULL 381 * 382 * Since: 2.2 383 */ 384 public static string getApplicationName() 385 { 386 return Str.toString(g_get_application_name()); 387 } 388 389 /** 390 * Gets the list of environment variables for the current process. 391 * 392 * The list is %NULL terminated and each item in the list is of the 393 * form 'NAME=VALUE'. 394 * 395 * This is equivalent to direct access to the 'environ' global variable, 396 * except portable. 397 * 398 * The return value is freshly allocated and it should be freed with 399 * g_strfreev() when it is no longer needed. 400 * 401 * Returns: the list of environment variables 402 * 403 * Since: 2.28 404 */ 405 public static string[] getEnviron() 406 { 407 auto retStr = g_get_environ(); 408 409 scope(exit) Str.freeStringArray(retStr); 410 return Str.toStringArray(retStr); 411 } 412 413 /** 414 * Gets the current directory. 415 * 416 * The returned string should be freed when no longer needed. 417 * The encoding of the returned string is system defined. 418 * On Windows, it is always UTF-8. 419 * 420 * Since GLib 2.40, this function will return the value of the "PWD" 421 * environment variable if it is set and it happens to be the same as 422 * the current directory. This can make a difference in the case that 423 * the current directory is the target of a symbolic link. 424 * 425 * Returns: the current directory 426 */ 427 public static string getCurrentDir() 428 { 429 auto retStr = g_get_current_dir(); 430 431 scope(exit) Str.freeString(retStr); 432 return Str.toString(retStr); 433 } 434 435 /** 436 * Gets the current user's home directory. 437 * 438 * As with most UNIX tools, this function will return the value of the 439 * `HOME` environment variable if it is set to an existing absolute path 440 * name, falling back to the `passwd` file in the case that it is unset. 441 * 442 * If the path given in `HOME` is non-absolute, does not exist, or is 443 * not a directory, the result is undefined. 444 * 445 * Before version 2.36 this function would ignore the `HOME` environment 446 * variable, taking the value from the `passwd` database instead. This was 447 * changed to increase the compatibility of GLib with other programs (and 448 * the XDG basedir specification) and to increase testability of programs 449 * based on GLib (by making it easier to run them from test frameworks). 450 * 451 * If your program has a strong requirement for either the new or the 452 * old behaviour (and if you don't wish to increase your GLib 453 * dependency to ensure that the new behaviour is in effect) then you 454 * should either directly check the `HOME` environment variable yourself 455 * or unset it before calling any functions in GLib. 456 * 457 * Returns: the current user's home directory 458 */ 459 public static string getHomeDir() 460 { 461 return Str.toString(g_get_home_dir()); 462 } 463 464 /** 465 * Return a name for the machine. 466 * 467 * The returned name is not necessarily a fully-qualified domain name, 468 * or even present in DNS or some other name service at all. It need 469 * not even be unique on your local network or site, but usually it 470 * is. Callers should not rely on the return value having any specific 471 * properties like uniqueness for security purposes. Even if the name 472 * of the machine is changed while an application is running, the 473 * return value from this function does not change. The returned 474 * string is owned by GLib and should not be modified or freed. If no 475 * name can be determined, a default fixed string "localhost" is 476 * returned. 477 * 478 * The encoding of the returned string is UTF-8. 479 * 480 * Returns: the host name of the machine. 481 * 482 * Since: 2.8 483 */ 484 public static string getHostName() 485 { 486 return Str.toString(g_get_host_name()); 487 } 488 489 /** 490 * Gets the name of the program. This name should not be localized, 491 * in contrast to g_get_application_name(). 492 * 493 * If you are using #GApplication the program name is set in 494 * g_application_run(). In case of GDK or GTK+ it is set in 495 * gdk_init(), which is called by gtk_init() and the 496 * #GtkApplication::startup handler. The program name is found by 497 * taking the last component of @argv[0]. 498 * 499 * Returns: the name of the program. The returned string belongs 500 * to GLib and must not be modified or freed. 501 */ 502 public static string getPrgname() 503 { 504 return Str.toString(g_get_prgname()); 505 } 506 507 /** 508 * Gets the real name of the user. This usually comes from the user's 509 * entry in the `passwd` file. The encoding of the returned string is 510 * system-defined. (On Windows, it is, however, always UTF-8.) If the 511 * real user name cannot be determined, the string "Unknown" is 512 * returned. 513 * 514 * Returns: the user's real name. 515 */ 516 public static string getRealName() 517 { 518 return Str.toString(g_get_real_name()); 519 } 520 521 /** 522 * Returns an ordered list of base directories in which to access 523 * system-wide configuration information. 524 * 525 * On UNIX platforms this is determined using the mechanisms described 526 * in the 527 * [XDG Base Directory Specification](http://www.freedesktop.org/Standards/basedir-spec). 528 * In this case the list of directories retrieved will be `XDG_CONFIG_DIRS`. 529 * 530 * On Windows it follows XDG Base Directory Specification if `XDG_CONFIG_DIRS` is defined. 531 * If `XDG_CONFIG_DIRS` is undefined, the directory that contains application 532 * data for all users is used instead. A typical path is 533 * `C:\Documents and Settings\All Users\Application Data`. 534 * This folder is used for application data 535 * that is not user specific. For example, an application can store 536 * a spell-check dictionary, a database of clip art, or a log file in the 537 * CSIDL_COMMON_APPDATA folder. This information will not roam and is available 538 * to anyone using the computer. 539 * 540 * Returns: a %NULL-terminated array of strings owned by GLib that must not be 541 * modified or freed. 542 * 543 * Since: 2.6 544 */ 545 public static string[] getSystemConfigDirs() 546 { 547 return Str.toStringArray(g_get_system_config_dirs()); 548 } 549 550 /** 551 * Returns an ordered list of base directories in which to access 552 * system-wide application data. 553 * 554 * On UNIX platforms this is determined using the mechanisms described 555 * in the 556 * [XDG Base Directory Specification](http://www.freedesktop.org/Standards/basedir-spec) 557 * In this case the list of directories retrieved will be `XDG_DATA_DIRS`. 558 * 559 * On Windows it follows XDG Base Directory Specification if `XDG_DATA_DIRS` is defined. 560 * If `XDG_DATA_DIRS` is undefined, 561 * the first elements in the list are the Application Data 562 * and Documents folders for All Users. (These can be determined only 563 * on Windows 2000 or later and are not present in the list on other 564 * Windows versions.) See documentation for CSIDL_COMMON_APPDATA and 565 * CSIDL_COMMON_DOCUMENTS. 566 * 567 * Then follows the "share" subfolder in the installation folder for 568 * the package containing the DLL that calls this function, if it can 569 * be determined. 570 * 571 * Finally the list contains the "share" subfolder in the installation 572 * folder for GLib, and in the installation folder for the package the 573 * application's .exe file belongs to. 574 * 575 * The installation folders above are determined by looking up the 576 * folder where the module (DLL or EXE) in question is located. If the 577 * folder's name is "bin", its parent is used, otherwise the folder 578 * itself. 579 * 580 * Note that on Windows the returned list can vary depending on where 581 * this function is called. 582 * 583 * Returns: a %NULL-terminated array of strings owned by GLib that must not be 584 * modified or freed. 585 * 586 * Since: 2.6 587 */ 588 public static string[] getSystemDataDirs() 589 { 590 return Str.toStringArray(g_get_system_data_dirs()); 591 } 592 593 /** 594 * Gets the directory to use for temporary files. 595 * 596 * On UNIX, this is taken from the `TMPDIR` environment variable. 597 * If the variable is not set, `P_tmpdir` is 598 * used, as defined by the system C library. Failing that, a 599 * hard-coded default of "/tmp" is returned. 600 * 601 * On Windows, the `TEMP` environment variable is used, with the 602 * root directory of the Windows installation (eg: "C:\") used 603 * as a default. 604 * 605 * The encoding of the returned string is system-defined. On Windows, 606 * it is always UTF-8. The return value is never %NULL or the empty 607 * string. 608 * 609 * Returns: the directory to use for temporary files. 610 */ 611 public static string getTmpDir() 612 { 613 return Str.toString(g_get_tmp_dir()); 614 } 615 616 /** 617 * Returns a base directory in which to store non-essential, cached 618 * data specific to particular user. 619 * 620 * On UNIX platforms this is determined using the mechanisms described 621 * in the 622 * [XDG Base Directory Specification](http://www.freedesktop.org/Standards/basedir-spec). 623 * In this case the directory retrieved will be `XDG_CACHE_HOME`. 624 * 625 * On Windows it follows XDG Base Directory Specification if `XDG_CACHE_HOME` is defined. 626 * If `XDG_CACHE_HOME` is undefined, the directory that serves as a common 627 * repository for temporary Internet files is used instead. A typical path is 628 * `C:\Documents and Settings\username\Local Settings\Temporary Internet Files`. 629 * See the [documentation for `CSIDL_INTERNET_CACHE`](https://msdn.microsoft.com/en-us/library/windows/desktop/bb762494%28v=vs.85%29.aspx#csidl_internet_cache). 630 * 631 * Returns: a string owned by GLib that must not be modified 632 * or freed. 633 * 634 * Since: 2.6 635 */ 636 public static string getUserCacheDir() 637 { 638 return Str.toString(g_get_user_cache_dir()); 639 } 640 641 /** 642 * Returns a base directory in which to store user-specific application 643 * configuration information such as user preferences and settings. 644 * 645 * On UNIX platforms this is determined using the mechanisms described 646 * in the 647 * [XDG Base Directory Specification](http://www.freedesktop.org/Standards/basedir-spec). 648 * In this case the directory retrieved will be `XDG_CONFIG_HOME`. 649 * 650 * On Windows it follows XDG Base Directory Specification if `XDG_CONFIG_HOME` is defined. 651 * If `XDG_CONFIG_HOME` is undefined, the folder to use for local (as opposed 652 * to roaming) application data is used instead. See the 653 * [documentation for `CSIDL_LOCAL_APPDATA`](https://msdn.microsoft.com/en-us/library/windows/desktop/bb762494%28v=vs.85%29.aspx#csidl_local_appdata). 654 * Note that in this case on Windows it will be the same 655 * as what g_get_user_data_dir() returns. 656 * 657 * Returns: a string owned by GLib that must not be modified 658 * or freed. 659 * 660 * Since: 2.6 661 */ 662 public static string getUserConfigDir() 663 { 664 return Str.toString(g_get_user_config_dir()); 665 } 666 667 /** 668 * Returns a base directory in which to access application data such 669 * as icons that is customized for a particular user. 670 * 671 * On UNIX platforms this is determined using the mechanisms described 672 * in the 673 * [XDG Base Directory Specification](http://www.freedesktop.org/Standards/basedir-spec). 674 * In this case the directory retrieved will be `XDG_DATA_HOME`. 675 * 676 * On Windows it follows XDG Base Directory Specification if `XDG_DATA_HOME` 677 * is defined. If `XDG_DATA_HOME` is undefined, the folder to use for local (as 678 * opposed to roaming) application data is used instead. See the 679 * [documentation for `CSIDL_LOCAL_APPDATA`](https://msdn.microsoft.com/en-us/library/windows/desktop/bb762494%28v=vs.85%29.aspx#csidl_local_appdata). 680 * Note that in this case on Windows it will be the same 681 * as what g_get_user_config_dir() returns. 682 * 683 * Returns: a string owned by GLib that must not be modified 684 * or freed. 685 * 686 * Since: 2.6 687 */ 688 public static string getUserDataDir() 689 { 690 return Str.toString(g_get_user_data_dir()); 691 } 692 693 /** 694 * Gets the user name of the current user. The encoding of the returned 695 * string is system-defined. On UNIX, it might be the preferred file name 696 * encoding, or something else, and there is no guarantee that it is even 697 * consistent on a machine. On Windows, it is always UTF-8. 698 * 699 * Returns: the user name of the current user. 700 */ 701 public static string getUserName() 702 { 703 return Str.toString(g_get_user_name()); 704 } 705 706 /** 707 * Returns a directory that is unique to the current user on the local 708 * system. 709 * 710 * This is determined using the mechanisms described 711 * in the 712 * [XDG Base Directory Specification](http://www.freedesktop.org/Standards/basedir-spec). 713 * This is the directory 714 * specified in the `XDG_RUNTIME_DIR` environment variable. 715 * In the case that this variable is not set, we return the value of 716 * g_get_user_cache_dir(), after verifying that it exists. 717 * 718 * Returns: a string owned by GLib that must not be 719 * modified or freed. 720 * 721 * Since: 2.28 722 */ 723 public static string getUserRuntimeDir() 724 { 725 return Str.toString(g_get_user_runtime_dir()); 726 } 727 728 /** 729 * Returns the full path of a special directory using its logical id. 730 * 731 * On UNIX this is done using the XDG special user directories. 732 * For compatibility with existing practise, %G_USER_DIRECTORY_DESKTOP 733 * falls back to `$HOME/Desktop` when XDG special user directories have 734 * not been set up. 735 * 736 * Depending on the platform, the user might be able to change the path 737 * of the special directory without requiring the session to restart; GLib 738 * will not reflect any change once the special directories are loaded. 739 * 740 * Params: 741 * directory = the logical id of special directory 742 * 743 * Returns: the path to the specified special directory, or 744 * %NULL if the logical id was not found. The returned string is owned by 745 * GLib and should not be modified or freed. 746 * 747 * Since: 2.14 748 */ 749 public static string getUserSpecialDir(GUserDirectory directory) 750 { 751 return Str.toString(g_get_user_special_dir(directory)); 752 } 753 754 /** 755 * Returns the value of an environment variable. 756 * 757 * On UNIX, the name and value are byte strings which might or might not 758 * be in some consistent character set and encoding. On Windows, they are 759 * in UTF-8. 760 * On Windows, in case the environment variable's value contains 761 * references to other environment variables, they are expanded. 762 * 763 * Params: 764 * variable = the environment variable to get 765 * 766 * Returns: the value of the environment variable, or %NULL if 767 * the environment variable is not found. The returned string 768 * may be overwritten by the next call to g_getenv(), g_setenv() 769 * or g_unsetenv(). 770 */ 771 public static string getenv(string variable) 772 { 773 return Str.toString(g_getenv(Str.toStringz(variable))); 774 } 775 776 /** 777 * Gets the names of all variables set in the environment. 778 * 779 * Programs that want to be portable to Windows should typically use 780 * this function and g_getenv() instead of using the environ array 781 * from the C library directly. On Windows, the strings in the environ 782 * array are in system codepage encoding, while in most of the typical 783 * use cases for environment variables in GLib-using programs you want 784 * the UTF-8 encoding that this function and g_getenv() provide. 785 * 786 * Returns: a %NULL-terminated list of strings which must be freed with 787 * g_strfreev(). 788 * 789 * Since: 2.8 790 */ 791 public static string[] listenv() 792 { 793 auto retStr = g_listenv(); 794 795 scope(exit) Str.freeStringArray(retStr); 796 return Str.toStringArray(retStr); 797 } 798 799 /** 800 * Set the pointer at the specified location to %NULL. 801 * 802 * Params: 803 * nullifyLocation = the memory address of the pointer. 804 */ 805 public static void nullifyPointer(void** nullifyLocation) 806 { 807 g_nullify_pointer(nullifyLocation); 808 } 809 810 /** 811 * Parses a string containing debugging options 812 * into a %guint containing bit flags. This is used 813 * within GDK and GTK+ to parse the debug options passed on the 814 * command line or through environment variables. 815 * 816 * If @string is equal to "all", all flags are set. Any flags 817 * specified along with "all" in @string are inverted; thus, 818 * "all,foo,bar" or "foo,bar,all" sets all flags except those 819 * corresponding to "foo" and "bar". 820 * 821 * If @string is equal to "help", all the available keys in @keys 822 * are printed out to standard error. 823 * 824 * Params: 825 * str = a list of debug options separated by colons, spaces, or 826 * commas, or %NULL. 827 * keys = pointer to an array of #GDebugKey which associate 828 * strings with bit flags. 829 * 830 * Returns: the combined set of bit flags. 831 */ 832 public static uint parseDebugString(string str, GDebugKey[] keys) 833 { 834 return g_parse_debug_string(Str.toStringz(str), keys.ptr, cast(uint)keys.length); 835 } 836 837 /** 838 * Gets the last component of the filename. 839 * 840 * If @file_name ends with a directory separator it gets the component 841 * before the last slash. If @file_name consists only of directory 842 * separators (and on Windows, possibly a drive letter), a single 843 * separator is returned. If @file_name is empty, it gets ".". 844 * 845 * Params: 846 * fileName = the name of the file 847 * 848 * Returns: a newly allocated string containing the last 849 * component of the filename 850 */ 851 public static string pathGetBasename(string fileName) 852 { 853 auto retStr = g_path_get_basename(Str.toStringz(fileName)); 854 855 scope(exit) Str.freeString(retStr); 856 return Str.toString(retStr); 857 } 858 859 /** 860 * Gets the directory components of a file name. 861 * 862 * If the file name has no directory components "." is returned. 863 * The returned string should be freed when no longer needed. 864 * 865 * Params: 866 * fileName = the name of the file 867 * 868 * Returns: the directory components of the file 869 */ 870 public static string pathGetDirname(string fileName) 871 { 872 auto retStr = g_path_get_dirname(Str.toStringz(fileName)); 873 874 scope(exit) Str.freeString(retStr); 875 return Str.toString(retStr); 876 } 877 878 /** 879 * Returns %TRUE if the given @file_name is an absolute file name. 880 * Note that this is a somewhat vague concept on Windows. 881 * 882 * On POSIX systems, an absolute file name is well-defined. It always 883 * starts from the single root directory. For example "/usr/local". 884 * 885 * On Windows, the concepts of current drive and drive-specific 886 * current directory introduce vagueness. This function interprets as 887 * an absolute file name one that either begins with a directory 888 * separator such as "\Users\tml" or begins with the root on a drive, 889 * for example "C:\Windows". The first case also includes UNC paths 890 * such as "\\\\myserver\docs\foo". In all cases, either slashes or 891 * backslashes are accepted. 892 * 893 * Note that a file name relative to the current drive root does not 894 * truly specify a file uniquely over time and across processes, as 895 * the current drive is a per-process value and can be changed. 896 * 897 * File names relative the current directory on some specific drive, 898 * such as "D:foo/bar", are not interpreted as absolute by this 899 * function, but they obviously are not relative to the normal current 900 * directory as returned by getcwd() or g_get_current_dir() 901 * either. Such paths should be avoided, or need to be handled using 902 * Windows-specific code. 903 * 904 * Params: 905 * fileName = a file name 906 * 907 * Returns: %TRUE if @file_name is absolute 908 */ 909 public static bool pathIsAbsolute(string fileName) 910 { 911 return g_path_is_absolute(Str.toStringz(fileName)) != 0; 912 } 913 914 /** 915 * Returns a pointer into @file_name after the root component, 916 * i.e. after the "/" in UNIX or "C:\" under Windows. If @file_name 917 * is not an absolute path it returns %NULL. 918 * 919 * Params: 920 * fileName = a file name 921 * 922 * Returns: a pointer into @file_name after the 923 * root component 924 */ 925 public static string pathSkipRoot(string fileName) 926 { 927 return Str.toString(g_path_skip_root(Str.toStringz(fileName))); 928 } 929 930 /** 931 * This is just like the standard C qsort() function, but 932 * the comparison routine accepts a user data argument. 933 * 934 * This is guaranteed to be a stable sort since version 2.32. 935 * 936 * Params: 937 * pbase = start of array to sort 938 * totalElems = elements in the array 939 * size = size of each element 940 * compareFunc = function to compare elements 941 * userData = data to pass to @compare_func 942 */ 943 public static void qsortWithData(void* pbase, int totalElems, size_t size, GCompareDataFunc compareFunc, void* userData) 944 { 945 g_qsort_with_data(pbase, totalElems, size, compareFunc, userData); 946 } 947 948 /** 949 * Resets the cache used for g_get_user_special_dir(), so 950 * that the latest on-disk version is used. Call this only 951 * if you just changed the data on disk yourself. 952 * 953 * Due to threadsafety issues this may cause leaking of strings 954 * that were previously returned from g_get_user_special_dir() 955 * that can't be freed. We ensure to only leak the data for 956 * the directories that actually changed value though. 957 * 958 * Since: 2.22 959 */ 960 public static void reloadUserSpecialDirsCache() 961 { 962 g_reload_user_special_dirs_cache(); 963 } 964 965 /** 966 * Sets a human-readable name for the application. This name should be 967 * localized if possible, and is intended for display to the user. 968 * Contrast with g_set_prgname(), which sets a non-localized name. 969 * g_set_prgname() will be called automatically by gtk_init(), 970 * but g_set_application_name() will not. 971 * 972 * Note that for thread safety reasons, this function can only 973 * be called once. 974 * 975 * The application name will be used in contexts such as error messages, 976 * or when displaying an application's name in the task list. 977 * 978 * Params: 979 * applicationName = localized name of the application 980 * 981 * Since: 2.2 982 */ 983 public static void setApplicationName(string applicationName) 984 { 985 g_set_application_name(Str.toStringz(applicationName)); 986 } 987 988 /** 989 * Sets the name of the program. This name should not be localized, 990 * in contrast to g_set_application_name(). 991 * 992 * If you are using #GApplication the program name is set in 993 * g_application_run(). In case of GDK or GTK+ it is set in 994 * gdk_init(), which is called by gtk_init() and the 995 * #GtkApplication::startup handler. The program name is found by 996 * taking the last component of @argv[0]. 997 * 998 * Note that for thread-safety reasons this function can only be called once. 999 * 1000 * Params: 1001 * prgname = the name of the program. 1002 */ 1003 public static void setPrgname(string prgname) 1004 { 1005 g_set_prgname(Str.toStringz(prgname)); 1006 } 1007 1008 /** 1009 * Sets an environment variable. On UNIX, both the variable's name and 1010 * value can be arbitrary byte strings, except that the variable's name 1011 * cannot contain '='. On Windows, they should be in UTF-8. 1012 * 1013 * Note that on some systems, when variables are overwritten, the memory 1014 * used for the previous variables and its value isn't reclaimed. 1015 * 1016 * You should be mindful of the fact that environment variable handling 1017 * in UNIX is not thread-safe, and your program may crash if one thread 1018 * calls g_setenv() while another thread is calling getenv(). (And note 1019 * that many functions, such as gettext(), call getenv() internally.) 1020 * This function is only safe to use at the very start of your program, 1021 * before creating any other threads (or creating objects that create 1022 * worker threads of their own). 1023 * 1024 * If you need to set up the environment for a child process, you can 1025 * use g_get_environ() to get an environment array, modify that with 1026 * g_environ_setenv() and g_environ_unsetenv(), and then pass that 1027 * array directly to execvpe(), g_spawn_async(), or the like. 1028 * 1029 * Params: 1030 * variable = the environment variable to set, must not 1031 * contain '='. 1032 * value = the value for to set the variable to. 1033 * overwrite = whether to change the variable if it already exists. 1034 * 1035 * Returns: %FALSE if the environment variable couldn't be set. 1036 * 1037 * Since: 2.4 1038 */ 1039 public static bool setenv(string variable, string value, bool overwrite) 1040 { 1041 return g_setenv(Str.toStringz(variable), Str.toStringz(value), overwrite) != 0; 1042 } 1043 1044 /** 1045 * Gets the smallest prime number from a built-in array of primes which 1046 * is larger than @num. This is used within GLib to calculate the optimum 1047 * size of a #GHashTable. 1048 * 1049 * The built-in array of primes ranges from 11 to 13845163 such that 1050 * each prime is approximately 1.5-2 times the previous prime. 1051 * 1052 * Params: 1053 * num = a #guint 1054 * 1055 * Returns: the smallest prime number from a built-in array of primes 1056 * which is larger than @num 1057 */ 1058 public static uint spacedPrimesClosest(uint num) 1059 { 1060 return g_spaced_primes_closest(num); 1061 } 1062 1063 /** 1064 * Removes an environment variable from the environment. 1065 * 1066 * Note that on some systems, when variables are overwritten, the 1067 * memory used for the previous variables and its value isn't reclaimed. 1068 * 1069 * You should be mindful of the fact that environment variable handling 1070 * in UNIX is not thread-safe, and your program may crash if one thread 1071 * calls g_unsetenv() while another thread is calling getenv(). (And note 1072 * that many functions, such as gettext(), call getenv() internally.) This 1073 * function is only safe to use at the very start of your program, before 1074 * creating any other threads (or creating objects that create worker 1075 * threads of their own). 1076 * 1077 * If you need to set up the environment for a child process, you can 1078 * use g_get_environ() to get an environment array, modify that with 1079 * g_environ_setenv() and g_environ_unsetenv(), and then pass that 1080 * array directly to execvpe(), g_spawn_async(), or the like. 1081 * 1082 * Params: 1083 * variable = the environment variable to remove, must 1084 * not contain '=' 1085 * 1086 * Since: 2.4 1087 */ 1088 public static void unsetenv(string variable) 1089 { 1090 g_unsetenv(Str.toStringz(variable)); 1091 } 1092 }