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". The returned string 294 * is UTF-8, and may use a non-breaking space to separate the number and units, 295 * to ensure they aren’t separated when line wrapped. 296 * 297 * The prefix units base is 1000 (i.e. 1 kB is 1000 bytes). 298 * 299 * This string should be freed with g_free() when not needed any longer. 300 * 301 * See g_format_size_full() for more options about how the size might be 302 * formatted. 303 * 304 * Params: 305 * size = a size in bytes 306 * 307 * Returns: a newly-allocated formatted string containing a human readable 308 * file size 309 * 310 * Since: 2.30 311 */ 312 public static string formatSize(ulong size) 313 { 314 auto retStr = g_format_size(size); 315 316 scope(exit) Str.freeString(retStr); 317 return Str.toString(retStr); 318 } 319 320 /** 321 * Formats a size (for example the size of a file) into a human 322 * readable string. Sizes are rounded to the nearest size prefix 323 * (KB, MB, GB) and are displayed rounded to the nearest tenth. 324 * E.g. the file size 3292528 bytes will be converted into the 325 * string "3.1 MB". 326 * 327 * The prefix units base is 1024 (i.e. 1 KB is 1024 bytes). 328 * 329 * This string should be freed with g_free() when not needed any longer. 330 * 331 * Deprecated: This function is broken due to its use of SI 332 * suffixes to denote IEC units. Use g_format_size() instead. 333 * 334 * Params: 335 * size = a size in bytes 336 * 337 * Returns: a newly-allocated formatted string containing a human 338 * readable file size 339 * 340 * Since: 2.16 341 */ 342 public static string formatSizeForDisplay(long size) 343 { 344 auto retStr = g_format_size_for_display(size); 345 346 scope(exit) Str.freeString(retStr); 347 return Str.toString(retStr); 348 } 349 350 /** 351 * Formats a size. 352 * 353 * This function is similar to g_format_size() but allows for flags 354 * that modify the output. See #GFormatSizeFlags. 355 * 356 * Params: 357 * size = a size in bytes 358 * flags = #GFormatSizeFlags to modify the output 359 * 360 * Returns: a newly-allocated formatted string containing a human 361 * readable file size 362 * 363 * Since: 2.30 364 */ 365 public static string formatSizeFull(ulong size, GFormatSizeFlags flags) 366 { 367 auto retStr = g_format_size_full(size, flags); 368 369 scope(exit) Str.freeString(retStr); 370 return Str.toString(retStr); 371 } 372 373 /** 374 * Gets a human-readable name for the application, as set by 375 * g_set_application_name(). This name should be localized if 376 * possible, and is intended for display to the user. Contrast with 377 * g_get_prgname(), which gets a non-localized name. If 378 * g_set_application_name() has not been called, returns the result of 379 * g_get_prgname() (which may be %NULL if g_set_prgname() has also not 380 * been called). 381 * 382 * Returns: human-readable application name. may return %NULL 383 * 384 * Since: 2.2 385 */ 386 public static string getApplicationName() 387 { 388 return Str.toString(g_get_application_name()); 389 } 390 391 /** 392 * Gets the list of environment variables for the current process. 393 * 394 * The list is %NULL terminated and each item in the list is of the 395 * form 'NAME=VALUE'. 396 * 397 * This is equivalent to direct access to the 'environ' global variable, 398 * except portable. 399 * 400 * The return value is freshly allocated and it should be freed with 401 * g_strfreev() when it is no longer needed. 402 * 403 * Returns: the list of environment variables 404 * 405 * Since: 2.28 406 */ 407 public static string[] getEnviron() 408 { 409 auto retStr = g_get_environ(); 410 411 scope(exit) Str.freeStringArray(retStr); 412 return Str.toStringArray(retStr); 413 } 414 415 /** 416 * Gets the current directory. 417 * 418 * The returned string should be freed when no longer needed. 419 * The encoding of the returned string is system defined. 420 * On Windows, it is always UTF-8. 421 * 422 * Since GLib 2.40, this function will return the value of the "PWD" 423 * environment variable if it is set and it happens to be the same as 424 * the current directory. This can make a difference in the case that 425 * the current directory is the target of a symbolic link. 426 * 427 * Returns: the current directory 428 */ 429 public static string getCurrentDir() 430 { 431 auto retStr = g_get_current_dir(); 432 433 scope(exit) Str.freeString(retStr); 434 return Str.toString(retStr); 435 } 436 437 /** 438 * Gets the current user's home directory. 439 * 440 * As with most UNIX tools, this function will return the value of the 441 * `HOME` environment variable if it is set to an existing absolute path 442 * name, falling back to the `passwd` file in the case that it is unset. 443 * 444 * If the path given in `HOME` is non-absolute, does not exist, or is 445 * not a directory, the result is undefined. 446 * 447 * Before version 2.36 this function would ignore the `HOME` environment 448 * variable, taking the value from the `passwd` database instead. This was 449 * changed to increase the compatibility of GLib with other programs (and 450 * the XDG basedir specification) and to increase testability of programs 451 * based on GLib (by making it easier to run them from test frameworks). 452 * 453 * If your program has a strong requirement for either the new or the 454 * old behaviour (and if you don't wish to increase your GLib 455 * dependency to ensure that the new behaviour is in effect) then you 456 * should either directly check the `HOME` environment variable yourself 457 * or unset it before calling any functions in GLib. 458 * 459 * Returns: the current user's home directory 460 */ 461 public static string getHomeDir() 462 { 463 return Str.toString(g_get_home_dir()); 464 } 465 466 /** 467 * Return a name for the machine. 468 * 469 * The returned name is not necessarily a fully-qualified domain name, 470 * or even present in DNS or some other name service at all. It need 471 * not even be unique on your local network or site, but usually it 472 * is. Callers should not rely on the return value having any specific 473 * properties like uniqueness for security purposes. Even if the name 474 * of the machine is changed while an application is running, the 475 * return value from this function does not change. The returned 476 * string is owned by GLib and should not be modified or freed. If no 477 * name can be determined, a default fixed string "localhost" is 478 * returned. 479 * 480 * The encoding of the returned string is UTF-8. 481 * 482 * Returns: the host name of the machine. 483 * 484 * Since: 2.8 485 */ 486 public static string getHostName() 487 { 488 return Str.toString(g_get_host_name()); 489 } 490 491 /** 492 * Gets the name of the program. This name should not be localized, 493 * in contrast to g_get_application_name(). 494 * 495 * If you are using #GApplication the program name is set in 496 * g_application_run(). In case of GDK or GTK+ it is set in 497 * gdk_init(), which is called by gtk_init() and the 498 * #GtkApplication::startup handler. The program name is found by 499 * taking the last component of @argv[0]. 500 * 501 * Returns: the name of the program. The returned string belongs 502 * to GLib and must not be modified or freed. 503 */ 504 public static string getPrgname() 505 { 506 return Str.toString(g_get_prgname()); 507 } 508 509 /** 510 * Gets the real name of the user. This usually comes from the user's 511 * entry in the `passwd` file. The encoding of the returned string is 512 * system-defined. (On Windows, it is, however, always UTF-8.) If the 513 * real user name cannot be determined, the string "Unknown" is 514 * returned. 515 * 516 * Returns: the user's real name. 517 */ 518 public static string getRealName() 519 { 520 return Str.toString(g_get_real_name()); 521 } 522 523 /** 524 * Returns an ordered list of base directories in which to access 525 * system-wide configuration information. 526 * 527 * On UNIX platforms this is determined using the mechanisms described 528 * in the 529 * [XDG Base Directory Specification](http://www.freedesktop.org/Standards/basedir-spec). 530 * In this case the list of directories retrieved will be `XDG_CONFIG_DIRS`. 531 * 532 * On Windows it follows XDG Base Directory Specification if `XDG_CONFIG_DIRS` is defined. 533 * If `XDG_CONFIG_DIRS` is undefined, the directory that contains application 534 * data for all users is used instead. A typical path is 535 * `C:\Documents and Settings\All Users\Application Data`. 536 * This folder is used for application data 537 * that is not user specific. For example, an application can store 538 * a spell-check dictionary, a database of clip art, or a log file in the 539 * CSIDL_COMMON_APPDATA folder. This information will not roam and is available 540 * to anyone using the computer. 541 * 542 * Returns: a %NULL-terminated array of strings owned by GLib that must not be 543 * modified or freed. 544 * 545 * Since: 2.6 546 */ 547 public static string[] getSystemConfigDirs() 548 { 549 return Str.toStringArray(g_get_system_config_dirs()); 550 } 551 552 /** 553 * Returns an ordered list of base directories in which to access 554 * system-wide application data. 555 * 556 * On UNIX platforms this is determined using the mechanisms described 557 * in the 558 * [XDG Base Directory Specification](http://www.freedesktop.org/Standards/basedir-spec) 559 * In this case the list of directories retrieved will be `XDG_DATA_DIRS`. 560 * 561 * On Windows it follows XDG Base Directory Specification if `XDG_DATA_DIRS` is defined. 562 * If `XDG_DATA_DIRS` is undefined, 563 * the first elements in the list are the Application Data 564 * and Documents folders for All Users. (These can be determined only 565 * on Windows 2000 or later and are not present in the list on other 566 * Windows versions.) See documentation for CSIDL_COMMON_APPDATA and 567 * CSIDL_COMMON_DOCUMENTS. 568 * 569 * Then follows the "share" subfolder in the installation folder for 570 * the package containing the DLL that calls this function, if it can 571 * be determined. 572 * 573 * Finally the list contains the "share" subfolder in the installation 574 * folder for GLib, and in the installation folder for the package the 575 * application's .exe file belongs to. 576 * 577 * The installation folders above are determined by looking up the 578 * folder where the module (DLL or EXE) in question is located. If the 579 * folder's name is "bin", its parent is used, otherwise the folder 580 * itself. 581 * 582 * Note that on Windows the returned list can vary depending on where 583 * this function is called. 584 * 585 * Returns: a %NULL-terminated array of strings owned by GLib that must not be 586 * modified or freed. 587 * 588 * Since: 2.6 589 */ 590 public static string[] getSystemDataDirs() 591 { 592 return Str.toStringArray(g_get_system_data_dirs()); 593 } 594 595 /** 596 * Gets the directory to use for temporary files. 597 * 598 * On UNIX, this is taken from the `TMPDIR` environment variable. 599 * If the variable is not set, `P_tmpdir` is 600 * used, as defined by the system C library. Failing that, a 601 * hard-coded default of "/tmp" is returned. 602 * 603 * On Windows, the `TEMP` environment variable is used, with the 604 * root directory of the Windows installation (eg: "C:\") used 605 * as a default. 606 * 607 * The encoding of the returned string is system-defined. On Windows, 608 * it is always UTF-8. The return value is never %NULL or the empty 609 * string. 610 * 611 * Returns: the directory to use for temporary files. 612 */ 613 public static string getTmpDir() 614 { 615 return Str.toString(g_get_tmp_dir()); 616 } 617 618 /** 619 * Returns a base directory in which to store non-essential, cached 620 * data specific to particular user. 621 * 622 * On UNIX platforms this is determined using the mechanisms described 623 * in the 624 * [XDG Base Directory Specification](http://www.freedesktop.org/Standards/basedir-spec). 625 * In this case the directory retrieved will be `XDG_CACHE_HOME`. 626 * 627 * On Windows it follows XDG Base Directory Specification if `XDG_CACHE_HOME` is defined. 628 * If `XDG_CACHE_HOME` is undefined, the directory that serves as a common 629 * repository for temporary Internet files is used instead. A typical path is 630 * `C:\Documents and Settings\username\Local Settings\Temporary Internet Files`. 631 * 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). 632 * 633 * Returns: a string owned by GLib that must not be modified 634 * or freed. 635 * 636 * Since: 2.6 637 */ 638 public static string getUserCacheDir() 639 { 640 return Str.toString(g_get_user_cache_dir()); 641 } 642 643 /** 644 * Returns a base directory in which to store user-specific application 645 * configuration information such as user preferences and settings. 646 * 647 * On UNIX platforms this is determined using the mechanisms described 648 * in the 649 * [XDG Base Directory Specification](http://www.freedesktop.org/Standards/basedir-spec). 650 * In this case the directory retrieved will be `XDG_CONFIG_HOME`. 651 * 652 * On Windows it follows XDG Base Directory Specification if `XDG_CONFIG_HOME` is defined. 653 * If `XDG_CONFIG_HOME` is undefined, the folder to use for local (as opposed 654 * to roaming) application data is used instead. See the 655 * [documentation for `CSIDL_LOCAL_APPDATA`](https://msdn.microsoft.com/en-us/library/windows/desktop/bb762494%28v=vs.85%29.aspx#csidl_local_appdata). 656 * Note that in this case on Windows it will be the same 657 * as what g_get_user_data_dir() returns. 658 * 659 * Returns: a string owned by GLib that must not be modified 660 * or freed. 661 * 662 * Since: 2.6 663 */ 664 public static string getUserConfigDir() 665 { 666 return Str.toString(g_get_user_config_dir()); 667 } 668 669 /** 670 * Returns a base directory in which to access application data such 671 * as icons that is customized for a particular user. 672 * 673 * On UNIX platforms this is determined using the mechanisms described 674 * in the 675 * [XDG Base Directory Specification](http://www.freedesktop.org/Standards/basedir-spec). 676 * In this case the directory retrieved will be `XDG_DATA_HOME`. 677 * 678 * On Windows it follows XDG Base Directory Specification if `XDG_DATA_HOME` 679 * is defined. If `XDG_DATA_HOME` is undefined, the folder to use for local (as 680 * opposed to roaming) application data is used instead. See the 681 * [documentation for `CSIDL_LOCAL_APPDATA`](https://msdn.microsoft.com/en-us/library/windows/desktop/bb762494%28v=vs.85%29.aspx#csidl_local_appdata). 682 * Note that in this case on Windows it will be the same 683 * as what g_get_user_config_dir() returns. 684 * 685 * Returns: a string owned by GLib that must not be modified 686 * or freed. 687 * 688 * Since: 2.6 689 */ 690 public static string getUserDataDir() 691 { 692 return Str.toString(g_get_user_data_dir()); 693 } 694 695 /** 696 * Gets the user name of the current user. The encoding of the returned 697 * string is system-defined. On UNIX, it might be the preferred file name 698 * encoding, or something else, and there is no guarantee that it is even 699 * consistent on a machine. On Windows, it is always UTF-8. 700 * 701 * Returns: the user name of the current user. 702 */ 703 public static string getUserName() 704 { 705 return Str.toString(g_get_user_name()); 706 } 707 708 /** 709 * Returns a directory that is unique to the current user on the local 710 * system. 711 * 712 * This is determined using the mechanisms described 713 * in the 714 * [XDG Base Directory Specification](http://www.freedesktop.org/Standards/basedir-spec). 715 * This is the directory 716 * specified in the `XDG_RUNTIME_DIR` environment variable. 717 * In the case that this variable is not set, we return the value of 718 * g_get_user_cache_dir(), after verifying that it exists. 719 * 720 * Returns: a string owned by GLib that must not be 721 * modified or freed. 722 * 723 * Since: 2.28 724 */ 725 public static string getUserRuntimeDir() 726 { 727 return Str.toString(g_get_user_runtime_dir()); 728 } 729 730 /** 731 * Returns the full path of a special directory using its logical id. 732 * 733 * On UNIX this is done using the XDG special user directories. 734 * For compatibility with existing practise, %G_USER_DIRECTORY_DESKTOP 735 * falls back to `$HOME/Desktop` when XDG special user directories have 736 * not been set up. 737 * 738 * Depending on the platform, the user might be able to change the path 739 * of the special directory without requiring the session to restart; GLib 740 * will not reflect any change once the special directories are loaded. 741 * 742 * Params: 743 * directory = the logical id of special directory 744 * 745 * Returns: the path to the specified special directory, or 746 * %NULL if the logical id was not found. The returned string is owned by 747 * GLib and should not be modified or freed. 748 * 749 * Since: 2.14 750 */ 751 public static string getUserSpecialDir(GUserDirectory directory) 752 { 753 return Str.toString(g_get_user_special_dir(directory)); 754 } 755 756 /** 757 * Returns the value of an environment variable. 758 * 759 * On UNIX, the name and value are byte strings which might or might not 760 * be in some consistent character set and encoding. On Windows, they are 761 * in UTF-8. 762 * On Windows, in case the environment variable's value contains 763 * references to other environment variables, they are expanded. 764 * 765 * Params: 766 * variable = the environment variable to get 767 * 768 * Returns: the value of the environment variable, or %NULL if 769 * the environment variable is not found. The returned string 770 * may be overwritten by the next call to g_getenv(), g_setenv() 771 * or g_unsetenv(). 772 */ 773 public static string getenv(string variable) 774 { 775 return Str.toString(g_getenv(Str.toStringz(variable))); 776 } 777 778 /** 779 * Gets the names of all variables set in the environment. 780 * 781 * Programs that want to be portable to Windows should typically use 782 * this function and g_getenv() instead of using the environ array 783 * from the C library directly. On Windows, the strings in the environ 784 * array are in system codepage encoding, while in most of the typical 785 * use cases for environment variables in GLib-using programs you want 786 * the UTF-8 encoding that this function and g_getenv() provide. 787 * 788 * Returns: a %NULL-terminated list of strings which must be freed with 789 * g_strfreev(). 790 * 791 * Since: 2.8 792 */ 793 public static string[] listenv() 794 { 795 auto retStr = g_listenv(); 796 797 scope(exit) Str.freeStringArray(retStr); 798 return Str.toStringArray(retStr); 799 } 800 801 /** 802 * Set the pointer at the specified location to %NULL. 803 * 804 * Params: 805 * nullifyLocation = the memory address of the pointer. 806 */ 807 public static void nullifyPointer(void** nullifyLocation) 808 { 809 g_nullify_pointer(nullifyLocation); 810 } 811 812 /** 813 * Parses a string containing debugging options 814 * into a %guint containing bit flags. This is used 815 * within GDK and GTK+ to parse the debug options passed on the 816 * command line or through environment variables. 817 * 818 * If @string is equal to "all", all flags are set. Any flags 819 * specified along with "all" in @string are inverted; thus, 820 * "all,foo,bar" or "foo,bar,all" sets all flags except those 821 * corresponding to "foo" and "bar". 822 * 823 * If @string is equal to "help", all the available keys in @keys 824 * are printed out to standard error. 825 * 826 * Params: 827 * string_ = a list of debug options separated by colons, spaces, or 828 * commas, or %NULL. 829 * keys = pointer to an array of #GDebugKey which associate 830 * strings with bit flags. 831 * 832 * Returns: the combined set of bit flags. 833 */ 834 public static uint parseDebugString(string string_, GDebugKey[] keys) 835 { 836 return g_parse_debug_string(Str.toStringz(string_), keys.ptr, cast(uint)keys.length); 837 } 838 839 /** 840 * Gets the last component of the filename. 841 * 842 * If @file_name ends with a directory separator it gets the component 843 * before the last slash. If @file_name consists only of directory 844 * separators (and on Windows, possibly a drive letter), a single 845 * separator is returned. If @file_name is empty, it gets ".". 846 * 847 * Params: 848 * fileName = the name of the file 849 * 850 * Returns: a newly allocated string containing the last 851 * component of the filename 852 */ 853 public static string pathGetBasename(string fileName) 854 { 855 auto retStr = g_path_get_basename(Str.toStringz(fileName)); 856 857 scope(exit) Str.freeString(retStr); 858 return Str.toString(retStr); 859 } 860 861 /** 862 * Gets the directory components of a file name. For example, the directory 863 * component of `/usr/bin/test` is `/usr/bin`. The directory component of `/` 864 * is `/`. 865 * 866 * If the file name has no directory components "." is returned. 867 * The returned string should be freed when no longer needed. 868 * 869 * Params: 870 * fileName = the name of the file 871 * 872 * Returns: the directory components of the file 873 */ 874 public static string pathGetDirname(string fileName) 875 { 876 auto retStr = g_path_get_dirname(Str.toStringz(fileName)); 877 878 scope(exit) Str.freeString(retStr); 879 return Str.toString(retStr); 880 } 881 882 /** 883 * Returns %TRUE if the given @file_name is an absolute file name. 884 * Note that this is a somewhat vague concept on Windows. 885 * 886 * On POSIX systems, an absolute file name is well-defined. It always 887 * starts from the single root directory. For example "/usr/local". 888 * 889 * On Windows, the concepts of current drive and drive-specific 890 * current directory introduce vagueness. This function interprets as 891 * an absolute file name one that either begins with a directory 892 * separator such as "\Users\tml" or begins with the root on a drive, 893 * for example "C:\Windows". The first case also includes UNC paths 894 * such as "\\\\myserver\docs\foo". In all cases, either slashes or 895 * backslashes are accepted. 896 * 897 * Note that a file name relative to the current drive root does not 898 * truly specify a file uniquely over time and across processes, as 899 * the current drive is a per-process value and can be changed. 900 * 901 * File names relative the current directory on some specific drive, 902 * such as "D:foo/bar", are not interpreted as absolute by this 903 * function, but they obviously are not relative to the normal current 904 * directory as returned by getcwd() or g_get_current_dir() 905 * either. Such paths should be avoided, or need to be handled using 906 * Windows-specific code. 907 * 908 * Params: 909 * fileName = a file name 910 * 911 * Returns: %TRUE if @file_name is absolute 912 */ 913 public static bool pathIsAbsolute(string fileName) 914 { 915 return g_path_is_absolute(Str.toStringz(fileName)) != 0; 916 } 917 918 /** 919 * Returns a pointer into @file_name after the root component, 920 * i.e. after the "/" in UNIX or "C:\" under Windows. If @file_name 921 * is not an absolute path it returns %NULL. 922 * 923 * Params: 924 * fileName = a file name 925 * 926 * Returns: a pointer into @file_name after the 927 * root component 928 */ 929 public static string pathSkipRoot(string fileName) 930 { 931 return Str.toString(g_path_skip_root(Str.toStringz(fileName))); 932 } 933 934 /** 935 * This is just like the standard C qsort() function, but 936 * the comparison routine accepts a user data argument. 937 * 938 * This is guaranteed to be a stable sort since version 2.32. 939 * 940 * Params: 941 * pbase = start of array to sort 942 * totalElems = elements in the array 943 * size = size of each element 944 * compareFunc = function to compare elements 945 * userData = data to pass to @compare_func 946 */ 947 public static void qsortWithData(void* pbase, int totalElems, size_t size, GCompareDataFunc compareFunc, void* userData) 948 { 949 g_qsort_with_data(pbase, totalElems, size, compareFunc, userData); 950 } 951 952 /** 953 * Resets the cache used for g_get_user_special_dir(), so 954 * that the latest on-disk version is used. Call this only 955 * if you just changed the data on disk yourself. 956 * 957 * Due to thread safety issues this may cause leaking of strings 958 * that were previously returned from g_get_user_special_dir() 959 * that can't be freed. We ensure to only leak the data for 960 * the directories that actually changed value though. 961 * 962 * Since: 2.22 963 */ 964 public static void reloadUserSpecialDirsCache() 965 { 966 g_reload_user_special_dirs_cache(); 967 } 968 969 /** 970 * Sets a human-readable name for the application. This name should be 971 * localized if possible, and is intended for display to the user. 972 * Contrast with g_set_prgname(), which sets a non-localized name. 973 * g_set_prgname() will be called automatically by gtk_init(), 974 * but g_set_application_name() will not. 975 * 976 * Note that for thread safety reasons, this function can only 977 * be called once. 978 * 979 * The application name will be used in contexts such as error messages, 980 * or when displaying an application's name in the task list. 981 * 982 * Params: 983 * applicationName = localized name of the application 984 * 985 * Since: 2.2 986 */ 987 public static void setApplicationName(string applicationName) 988 { 989 g_set_application_name(Str.toStringz(applicationName)); 990 } 991 992 /** 993 * Sets the name of the program. This name should not be localized, 994 * in contrast to g_set_application_name(). 995 * 996 * If you are using #GApplication the program name is set in 997 * g_application_run(). In case of GDK or GTK+ it is set in 998 * gdk_init(), which is called by gtk_init() and the 999 * #GtkApplication::startup handler. The program name is found by 1000 * taking the last component of @argv[0]. 1001 * 1002 * Note that for thread-safety reasons this function can only be called once. 1003 * 1004 * Params: 1005 * prgname = the name of the program. 1006 */ 1007 public static void setPrgname(string prgname) 1008 { 1009 g_set_prgname(Str.toStringz(prgname)); 1010 } 1011 1012 /** 1013 * Sets an environment variable. On UNIX, both the variable's name and 1014 * value can be arbitrary byte strings, except that the variable's name 1015 * cannot contain '='. On Windows, they should be in UTF-8. 1016 * 1017 * Note that on some systems, when variables are overwritten, the memory 1018 * used for the previous variables and its value isn't reclaimed. 1019 * 1020 * You should be mindful of the fact that environment variable handling 1021 * in UNIX is not thread-safe, and your program may crash if one thread 1022 * calls g_setenv() while another thread is calling getenv(). (And note 1023 * that many functions, such as gettext(), call getenv() internally.) 1024 * This function is only safe to use at the very start of your program, 1025 * before creating any other threads (or creating objects that create 1026 * worker threads of their own). 1027 * 1028 * If you need to set up the environment for a child process, you can 1029 * use g_get_environ() to get an environment array, modify that with 1030 * g_environ_setenv() and g_environ_unsetenv(), and then pass that 1031 * array directly to execvpe(), g_spawn_async(), or the like. 1032 * 1033 * Params: 1034 * variable = the environment variable to set, must not 1035 * contain '='. 1036 * value = the value for to set the variable to. 1037 * overwrite = whether to change the variable if it already exists. 1038 * 1039 * Returns: %FALSE if the environment variable couldn't be set. 1040 * 1041 * Since: 2.4 1042 */ 1043 public static bool setenv(string variable, string value, bool overwrite) 1044 { 1045 return g_setenv(Str.toStringz(variable), Str.toStringz(value), overwrite) != 0; 1046 } 1047 1048 /** 1049 * Gets the smallest prime number from a built-in array of primes which 1050 * is larger than @num. This is used within GLib to calculate the optimum 1051 * size of a #GHashTable. 1052 * 1053 * The built-in array of primes ranges from 11 to 13845163 such that 1054 * each prime is approximately 1.5-2 times the previous prime. 1055 * 1056 * Params: 1057 * num = a #guint 1058 * 1059 * Returns: the smallest prime number from a built-in array of primes 1060 * which is larger than @num 1061 */ 1062 public static uint spacedPrimesClosest(uint num) 1063 { 1064 return g_spaced_primes_closest(num); 1065 } 1066 1067 /** 1068 * Removes an environment variable from the environment. 1069 * 1070 * Note that on some systems, when variables are overwritten, the 1071 * memory used for the previous variables and its value isn't reclaimed. 1072 * 1073 * You should be mindful of the fact that environment variable handling 1074 * in UNIX is not thread-safe, and your program may crash if one thread 1075 * calls g_unsetenv() while another thread is calling getenv(). (And note 1076 * that many functions, such as gettext(), call getenv() internally.) This 1077 * function is only safe to use at the very start of your program, before 1078 * creating any other threads (or creating objects that create worker 1079 * threads of their own). 1080 * 1081 * If you need to set up the environment for a child process, you can 1082 * use g_get_environ() to get an environment array, modify that with 1083 * g_environ_setenv() and g_environ_unsetenv(), and then pass that 1084 * array directly to execvpe(), g_spawn_async(), or the like. 1085 * 1086 * Params: 1087 * variable = the environment variable to remove, must 1088 * not contain '=' 1089 * 1090 * Since: 2.4 1091 */ 1092 public static void unsetenv(string variable) 1093 { 1094 g_unsetenv(Str.toStringz(variable)); 1095 } 1096 1097 /** 1098 * Gets the canonical file name from @filename. All triple slashes are turned into 1099 * single slashes, and all `..` and `.`s resolved against @relative_to. 1100 * 1101 * Symlinks are not followed, and the returned path is guaranteed to be absolute. 1102 * 1103 * If @filename is an absolute path, @relative_to is ignored. Otherwise, 1104 * @relative_to will be prepended to @filename to make it absolute. @relative_to 1105 * must be an absolute path, or %NULL. If @relative_to is %NULL, it'll fallback 1106 * to g_get_current_dir(). 1107 * 1108 * This function never fails, and will canonicalize file paths even if they don't 1109 * exist. 1110 * 1111 * No file system I/O is done. 1112 * 1113 * Params: 1114 * filename = the name of the file 1115 * relativeTo = the relative directory, or %NULL 1116 * to use the current working directory 1117 * 1118 * Returns: a newly allocated string with the 1119 * canonical file path 1120 * 1121 * Since: 2.58 1122 */ 1123 public static string canonicalizeFilename(string filename, string relativeTo) 1124 { 1125 auto retStr = g_canonicalize_filename(Str.toStringz(filename), Str.toStringz(relativeTo)); 1126 1127 scope(exit) Str.freeString(retStr); 1128 return Str.toString(retStr); 1129 } 1130 }