| 
									
										
										
										
											2011-02-18 13:58:08 +00:00
										 |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2008-12-20 10:02:00 +00:00
										 |  |  |  * This program is free software; you can redistribute it and/or | 
					
						
							|  |  |  |  * modify it under the terms of the GNU General Public License | 
					
						
							|  |  |  |  * as published by the Free Software Foundation; either version 2 | 
					
						
							|  |  |  |  * of the License, or (at your option) any later version. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  |  * GNU General Public License for more details. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * You should have received a copy of the GNU General Public License | 
					
						
							|  |  |  |  * along with this program; if not, write to the Free Software Foundation, | 
					
						
							| 
									
										
										
										
											2010-02-12 13:34:04 +00:00
										 |  |  |  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. | 
					
						
							| 
									
										
										
										
											2008-12-20 10:02:00 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * The Original Code is Copyright (C) 2001-2002 by NaN Holding BV. | 
					
						
							|  |  |  |  * All rights reserved. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2020-08-07 09:50:34 +02:00
										 |  |  | #pragma once
 | 
					
						
							| 
									
										
										
										
											2008-12-20 10:02:00 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-02-18 08:08:12 +11:00
										 |  |  | /** \file
 | 
					
						
							|  |  |  |  * \ingroup bli | 
					
						
							| 
									
										
										
										
											2011-02-18 13:58:08 +00:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-08 18:16:39 +02:00
										 |  |  | #include "BLI_compiler_attrs.h"
 | 
					
						
							|  |  |  | #include "BLI_utildefines.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-04 16:20:42 +00:00
										 |  |  | #ifdef __cplusplus
 | 
					
						
							|  |  |  | extern "C" { | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Sets the specified environment variable to the specified value, | 
					
						
							|  |  |  |  * and clears it if `val == NULL`. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2014-01-31 03:09:01 +11:00
										 |  |  | void BLI_setenv(const char *env, const char *val) ATTR_NONNULL(1); | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Only set an environment variable if already not there. | 
					
						
							|  |  |  |  * Like Unix `setenv(env, val, 0);` | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * (not used anywhere). | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2014-01-31 03:09:01 +11:00
										 |  |  | void BLI_setenv_if_new(const char *env, const char *val) ATTR_NONNULL(1); | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Get an environment variable, result has to be used immediately. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * On windows #getenv gets its variables from a static copy of the environment variables taken at | 
					
						
							|  |  |  |  * process start-up, causing it to not pick up on environment variables created during runtime. | 
					
						
							|  |  |  |  * This function uses an alternative method to get environment variables that does pick up on | 
					
						
							|  |  |  |  * runtime environment variables. The result will be UTF-8 encoded. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2018-09-05 14:31:10 +10:00
										 |  |  | const char *BLI_getenv(const char *env) ATTR_NONNULL(1); | 
					
						
							| 
									
										
										
										
											2009-04-11 02:18:24 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Returns in `string` the concatenation of `dir` and `file` (also with `relabase` on the | 
					
						
							|  |  |  |  * front if specified and `dir` begins with "//"). Normalizes all occurrences of path | 
					
						
							|  |  |  |  * separators, including ensuring there is exactly one between the copies of `dir` and `file`, | 
					
						
							|  |  |  |  * and between the copies of `relabase` and `dir`. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param relabase: Optional prefix to substitute for "//" on front of `dir`. | 
					
						
							|  |  |  |  * \param string: Area to return result. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | void BLI_make_file_string(const char *relabase, char *string, const char *dir, const char *file); | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Ensures that the parent directory of `name` exists. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return true on success (i.e. given path now exists on file-system), false otherwise. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-04-17 12:04:38 +02:00
										 |  |  | bool BLI_make_existing_file(const char *name); | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Converts `/foo/bar.txt` to `/foo/` and `bar.txt` | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * - Won't change \a string. | 
					
						
							|  |  |  |  * - Won't create any directories. | 
					
						
							|  |  |  |  * - Doesn't use CWD, or deal with relative paths. | 
					
						
							|  |  |  |  * - Only fill's in \a dir and \a file when they are non NULL. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2022-01-12 11:42:54 +11:00
										 |  |  | void BLI_split_dirfile(const char *string, char *dir, char *file, size_t dirlen, size_t filelen); | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Copies the parent directory part of string into `dir`, max length `dirlen`. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2022-01-12 11:42:54 +11:00
										 |  |  | void BLI_split_dir_part(const char *string, char *dir, size_t dirlen); | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Copies the leaf filename part of string into `file`, max length `filelen`. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2022-01-12 11:42:54 +11:00
										 |  |  | void BLI_split_file_part(const char *string, char *file, size_t filelen); | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Returns a pointer to the last extension (e.g. the position of the last period). | 
					
						
							|  |  |  |  * Returns NULL if there is no extension. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2019-08-13 15:35:48 +02:00
										 |  |  | const char *BLI_path_extension(const char *filepath) ATTR_NONNULL(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Append a filename to a dir, ensuring slash separates. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2022-01-12 11:42:54 +11:00
										 |  |  | void BLI_path_append(char *__restrict dst, size_t maxlen, const char *__restrict file) | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     ATTR_NONNULL(); | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Simple appending of filename to dir, does not check for valid path! | 
					
						
							|  |  |  |  * Puts result into `dst`, which may be same area as `dir`. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \note Consider using #BLI_path_join for more general path joining | 
					
						
							|  |  |  |  * that de-duplicates separators and can handle an arbitrary number of paths. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2020-09-04 20:59:13 +02:00
										 |  |  | void BLI_join_dirfile(char *__restrict dst, | 
					
						
							| 
									
										
										
										
											2022-01-12 11:42:54 +11:00
										 |  |  |                       size_t maxlen, | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |                       const char *__restrict dir, | 
					
						
							|  |  |  |                       const char *__restrict file) ATTR_NONNULL(); | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Join multiple strings into a path, ensuring only a single path separator between each, | 
					
						
							|  |  |  |  * and trailing slash is kept. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \note If you want a trailing slash, add `SEP_STR` as the last path argument, | 
					
						
							|  |  |  |  * duplicate slashes will be cleaned up. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2022-01-12 11:42:54 +11:00
										 |  |  | size_t BLI_path_join(char *__restrict dst, size_t dst_len, const char *path_first, ...) | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     ATTR_NONNULL(1, 3) ATTR_SENTINEL(0); | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Like Python's `os.path.basename()` | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return The pointer into \a path string immediately after last slash, | 
					
						
							|  |  |  |  * or start of \a path if none found. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2014-01-31 03:09:01 +11:00
										 |  |  | const char *BLI_path_basename(const char *path) ATTR_NONNULL() ATTR_WARN_UNUSED_RESULT; | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Get an element of the path at an index, eg: | 
					
						
							|  |  |  |  * "/some/path/file.txt" where an index of: | 
					
						
							|  |  |  |  * - 0 or -3: "some" | 
					
						
							|  |  |  |  * - 1 or -2: "path" | 
					
						
							|  |  |  |  * - 2 or -1: "file.txt" | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Ignores multiple slashes at any point in the path (including start/end). | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | bool BLI_path_name_at_index(const char *__restrict path, | 
					
						
							| 
									
										
										
										
											2022-01-07 11:38:08 +11:00
										 |  |  |                             int index, | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |                             int *__restrict r_offset, | 
					
						
							|  |  |  |                             int *__restrict r_len) ATTR_NONNULL() ATTR_WARN_UNUSED_RESULT; | 
					
						
							| 
									
										
										
										
											2012-06-22 15:38:49 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-09-27 15:22:53 +02:00
										 |  |  | /** Return true only if #containee_path is contained in #container_path. */ | 
					
						
							|  |  |  | bool BLI_path_contains(const char *container_path, | 
					
						
							|  |  |  |                        const char *containee_path) ATTR_WARN_UNUSED_RESULT; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2022-01-07 15:13:31 +11:00
										 |  |  |  * \return pointer to the leftmost path separator in string (or NULL when not found). | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | const char *BLI_path_slash_find(const char *string) ATTR_NONNULL() ATTR_WARN_UNUSED_RESULT; | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * \return pointer to the rightmost path separator in string (or NULL when not found). | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2020-04-07 12:02:21 +10:00
										 |  |  | const char *BLI_path_slash_rfind(const char *string) ATTR_NONNULL() ATTR_WARN_UNUSED_RESULT; | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Appends a slash to string if there isn't one there already. | 
					
						
							|  |  |  |  * Returns the new length of the string. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2020-04-07 12:02:21 +10:00
										 |  |  | int BLI_path_slash_ensure(char *string) ATTR_NONNULL(); | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Removes the last slash and everything after it to the end of string, if there is one. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2020-04-07 12:02:21 +10:00
										 |  |  | void BLI_path_slash_rstrip(char *string) ATTR_NONNULL(); | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Changes to the path separators to the native ones for this OS. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2020-04-07 12:02:21 +10:00
										 |  |  | void BLI_path_slash_native(char *path) ATTR_NONNULL(); | 
					
						
							| 
									
										
										
										
											2010-10-27 06:41:48 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-06 06:05:31 +10:00
										 |  |  | #ifdef _WIN32
 | 
					
						
							| 
									
										
										
										
											2022-01-12 11:42:54 +11:00
										 |  |  | bool BLI_path_program_extensions_add_win32(char *name, size_t maxlen); | 
					
						
							| 
									
										
										
										
											2015-05-06 06:05:31 +10:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Search for a binary (executable) | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2022-01-12 11:42:54 +11:00
										 |  |  | bool BLI_path_program_search(char *fullname, size_t maxlen, const char *name); | 
					
						
							| 
									
										
										
										
											2015-05-06 06:05:31 +10:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * \return true when `str` end with `ext` (case insensitive). | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | bool BLI_path_extension_check(const char *str, const char *ext) | 
					
						
							|  |  |  |     ATTR_NONNULL() ATTR_WARN_UNUSED_RESULT; | 
					
						
							| 
									
										
										
										
											2018-06-17 16:13:24 +02:00
										 |  |  | bool BLI_path_extension_check_n(const char *str, ...) ATTR_NONNULL(1) ATTR_SENTINEL(0); | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * \return true when `str` ends with any of the suffixes in `ext_array`. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | bool BLI_path_extension_check_array(const char *str, const char **ext_array) | 
					
						
							|  |  |  |     ATTR_NONNULL() ATTR_WARN_UNUSED_RESULT; | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Semicolon separated wildcards, eg: `*.zip;*.py;*.exe` | 
					
						
							|  |  |  |  * does `str` match any of the semicolon-separated glob patterns in #fnmatch. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | bool BLI_path_extension_check_glob(const char *str, const char *ext_fnmatch) | 
					
						
							|  |  |  |     ATTR_NONNULL() ATTR_WARN_UNUSED_RESULT; | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Does basic validation of the given glob string, to prevent common issues from string | 
					
						
							|  |  |  |  * truncation. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * For now, only forbids last group to be a wildcard-only one, if there are more than one group | 
					
						
							|  |  |  |  * (i.e. things like `*.txt;*.cpp;*` are changed to `*.txt;*.cpp;`) | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \returns true if it had to modify given \a ext_fnmatch pattern. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2018-06-18 12:26:47 +02:00
										 |  |  | bool BLI_path_extension_glob_validate(char *ext_fnmatch) ATTR_NONNULL(); | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Removes any existing extension on the end of \a path and appends \a ext. | 
					
						
							|  |  |  |  * \return false if there was no room. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2018-06-17 16:13:24 +02:00
										 |  |  | bool BLI_path_extension_replace(char *path, size_t maxlen, const char *ext) ATTR_NONNULL(); | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Strip's trailing '.'s and adds the extension only when needed | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2018-06-17 16:13:24 +02:00
										 |  |  | bool BLI_path_extension_ensure(char *path, size_t maxlen, const char *ext) ATTR_NONNULL(); | 
					
						
							| 
									
										
										
										
											2021-12-16 16:52:47 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Ensure `filepath` has a file component, adding `filename` when it's empty or ends with a slash. | 
					
						
							|  |  |  |  * \return true if the `filename` was appended to `filepath`. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2020-04-07 12:02:21 +10:00
										 |  |  | bool BLI_path_filename_ensure(char *filepath, size_t maxlen, const char *filename) ATTR_NONNULL(); | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Looks for a sequence of decimal digits in string, preceding any filename extension, | 
					
						
							|  |  |  |  * returning the integer value if found, or 0 if not. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param string: String to scan. | 
					
						
							|  |  |  |  * \param head: Optional area to return copy of part of string prior to digits, | 
					
						
							|  |  |  |  * or before dot if no digits. | 
					
						
							|  |  |  |  * \param tail: Optional area to return copy of part of string following digits, | 
					
						
							|  |  |  |  * or from dot if no digits. | 
					
						
							|  |  |  |  * \param r_num_len: Optional to return number of digits found. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2020-09-04 20:59:13 +02:00
										 |  |  | int BLI_path_sequence_decode(const char *string, | 
					
						
							|  |  |  |                              char *head, | 
					
						
							|  |  |  |                              char *tail, | 
					
						
							|  |  |  |                              unsigned short *r_num_len); | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Returns in area pointed to by string a string of the form `<head><pic><tail>`, | 
					
						
							|  |  |  |  * where pic is formatted as `numlen` digits with leading zeroes. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2020-04-07 12:02:21 +10:00
										 |  |  | void BLI_path_sequence_encode( | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     char *string, const char *head, const char *tail, unsigned short numlen, int pic); | 
					
						
							| 
									
										
										
										
											2008-12-20 10:02:00 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Remove redundant characters from \a path and optionally make absolute. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param relabase: The path this is relative to, or ignored when NULL. | 
					
						
							|  |  |  |  * \param path: Can be any input, and this function converts it to a regular full path. | 
					
						
							|  |  |  |  * Also removes garbage from directory paths, like `/../` or double slashes etc. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \note \a path isn't protected for max string names. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2020-04-07 12:02:21 +10:00
										 |  |  | void BLI_path_normalize(const char *relabase, char *path) ATTR_NONNULL(2); | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Cleanup file-path ensuring a trailing slash. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \note Same as #BLI_path_normalize but adds a trailing slash. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2020-04-07 12:02:21 +10:00
										 |  |  | void BLI_path_normalize_dir(const char *relabase, char *dir) ATTR_NONNULL(2); | 
					
						
							| 
									
										
										
										
											2008-12-20 10:02:00 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Make given name safe to be used in paths. | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
											  
											
												UDIM: Support virtual filenames
This implements the design detailed in T92696 to support virtual
filenames for UDIM textures. Currently, the following 2 substitution
tokens are supported:
| Token | Meaning |
| ----- | ---- |
| <UDIM>   | 1001 + u-tile + v-tile * 10 |
| <UVTILE> | Equivalent to u<u-tile + 1>_v<v-tile + 1> |
Example for u-tile of 3 and v-tile of 1:
filename.<UDIM>_ver0023.png   --> filename.1014_ver0023.png
filename.<UVTILE>_ver0023.png --> filename.u4_v2_ver0023.png
For image loading, the existing workflow is unchanged. A user can select
one or more image files, belonging to one or more UDIM tile sets, and
have Blender load them all as it does today. Now the <UVTILE> format is
"guessed" just as the <UDIM> format was guessed before.
If guessing fails, the user can simply go into the Image Editor and type
the proper substitution in the filename. Once typing is complete,
Blender will reload the files and correctly fill the tiles. This
workflow is new as attempting to fix the guessing in current versions
did not really work, and the user was often stuck with a confusing
situation.
For image saving, the existing workflow is changed slightly. Currently,
when saving, a user has to be sure to type the filename of the first
tile (e.g. filename.1001.png) to save the entire UDIM set. The number
could differ if they start at a different tile etc. This is confusing.
Now, the user should type a filename containing the appropriate
substitution token. By default Blender will fill in a default name using
the <UDIM> token but the user is free to save out images using <UVTILE>
if they wish.
Differential Revision: https://developer.blender.org/D13057
											
										 
											2021-12-30 22:06:23 -08:00
										 |  |  |  * \param allow_tokens: Permit the usage of '<' and '>' characters. This can be | 
					
						
							|  |  |  |  * leveraged by higher layers to support "virtual filenames" which contain | 
					
						
							|  |  |  |  * substitution markers delineated between the two characters. | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  |  * \return true if \a fname was changed, false otherwise. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * For now, simply replaces reserved chars (as listed in | 
					
						
							|  |  |  |  * https://en.wikipedia.org/wiki/Filename#Reserved_characters_and_words )
 | 
					
						
							|  |  |  |  * by underscores ('_'). | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \note Space case ' ' is a bit of an edge case here - in theory it is allowed, | 
					
						
							|  |  |  |  * but again can be an issue in some cases, so we simply replace it by an underscore too | 
					
						
							|  |  |  |  * (good practice anyway). | 
					
						
							|  |  |  |  * REMOVED based on popular demand (see T45900). | 
					
						
							|  |  |  |  * Percent '%' char is a bit same case - not recommended to use it, | 
					
						
							|  |  |  |  * but supported by all decent file-systems/operating-systems around. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \note On Windows, it also ensures there is no '.' (dot char) at the end of the file, | 
					
						
							|  |  |  |  * this can lead to issues. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \note On Windows, it also checks for forbidden names | 
					
						
							|  |  |  |  * (see https://msdn.microsoft.com/en-us/library/windows/desktop/aa365247%28v=vs.85%29.aspx ).
 | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
											  
											
												UDIM: Support virtual filenames
This implements the design detailed in T92696 to support virtual
filenames for UDIM textures. Currently, the following 2 substitution
tokens are supported:
| Token | Meaning |
| ----- | ---- |
| <UDIM>   | 1001 + u-tile + v-tile * 10 |
| <UVTILE> | Equivalent to u<u-tile + 1>_v<v-tile + 1> |
Example for u-tile of 3 and v-tile of 1:
filename.<UDIM>_ver0023.png   --> filename.1014_ver0023.png
filename.<UVTILE>_ver0023.png --> filename.u4_v2_ver0023.png
For image loading, the existing workflow is unchanged. A user can select
one or more image files, belonging to one or more UDIM tile sets, and
have Blender load them all as it does today. Now the <UVTILE> format is
"guessed" just as the <UDIM> format was guessed before.
If guessing fails, the user can simply go into the Image Editor and type
the proper substitution in the filename. Once typing is complete,
Blender will reload the files and correctly fill the tiles. This
workflow is new as attempting to fix the guessing in current versions
did not really work, and the user was often stuck with a confusing
situation.
For image saving, the existing workflow is changed slightly. Currently,
when saving, a user has to be sure to type the filename of the first
tile (e.g. filename.1001.png) to save the entire UDIM set. The number
could differ if they start at a different tile etc. This is confusing.
Now, the user should type a filename containing the appropriate
substitution token. By default Blender will fill in a default name using
the <UDIM> token but the user is free to save out images using <UVTILE>
if they wish.
Differential Revision: https://developer.blender.org/D13057
											
										 
											2021-12-30 22:06:23 -08:00
										 |  |  | bool BLI_filename_make_safe_ex(char *fname, bool allow_tokens) ATTR_NONNULL(1); | 
					
						
							| 
									
										
										
										
											2015-07-14 18:42:22 +02:00
										 |  |  | bool BLI_filename_make_safe(char *fname) ATTR_NONNULL(1); | 
					
						
							| 
									
										
											  
											
												UDIM: Support virtual filenames
This implements the design detailed in T92696 to support virtual
filenames for UDIM textures. Currently, the following 2 substitution
tokens are supported:
| Token | Meaning |
| ----- | ---- |
| <UDIM>   | 1001 + u-tile + v-tile * 10 |
| <UVTILE> | Equivalent to u<u-tile + 1>_v<v-tile + 1> |
Example for u-tile of 3 and v-tile of 1:
filename.<UDIM>_ver0023.png   --> filename.1014_ver0023.png
filename.<UVTILE>_ver0023.png --> filename.u4_v2_ver0023.png
For image loading, the existing workflow is unchanged. A user can select
one or more image files, belonging to one or more UDIM tile sets, and
have Blender load them all as it does today. Now the <UVTILE> format is
"guessed" just as the <UDIM> format was guessed before.
If guessing fails, the user can simply go into the Image Editor and type
the proper substitution in the filename. Once typing is complete,
Blender will reload the files and correctly fill the tiles. This
workflow is new as attempting to fix the guessing in current versions
did not really work, and the user was often stuck with a confusing
situation.
For image saving, the existing workflow is changed slightly. Currently,
when saving, a user has to be sure to type the filename of the first
tile (e.g. filename.1001.png) to save the entire UDIM set. The number
could differ if they start at a different tile etc. This is confusing.
Now, the user should type a filename containing the appropriate
substitution token. By default Blender will fill in a default name using
the <UDIM> token but the user is free to save out images using <UVTILE>
if they wish.
Differential Revision: https://developer.blender.org/D13057
											
										 
											2021-12-30 22:06:23 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Make given path OS-safe. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \return true if \a path was changed, false otherwise. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2015-07-14 18:42:22 +02:00
										 |  |  | bool BLI_path_make_safe(char *path) ATTR_NONNULL(1); | 
					
						
							| 
									
										
										
										
											2015-01-16 18:48:59 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Go back one directory. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Replaces path with the path of its parent directory, returning true if | 
					
						
							|  |  |  |  * it was able to find a parent directory within the path. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2020-04-07 12:02:21 +10:00
										 |  |  | bool BLI_path_parent_dir(char *path) ATTR_NONNULL(); | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Go back until the directory is found. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Strips off nonexistent (or non-accessible) sub-directories from the end of `dir`, | 
					
						
							|  |  |  |  * leaving the path of the lowest-level directory that does exist and we can read. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2020-04-07 12:02:21 +10:00
										 |  |  | bool BLI_path_parent_dir_until_exists(char *path) ATTR_NONNULL(); | 
					
						
							| 
									
										
										
										
											2008-12-20 10:02:00 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * If path begins with "//", strips that and replaces it with `basepath` directory. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \note Also converts drive-letter prefix to something more sensible | 
					
						
							|  |  |  |  * if this is a non-drive-letter-based system. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param path: The path to convert. | 
					
						
							|  |  |  |  * \param basepath: The directory to base relative paths with. | 
					
						
							|  |  |  |  * \return true if the path was relative (started with "//"). | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | bool BLI_path_abs(char *path, const char *basepath) ATTR_NONNULL(); | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Replaces "#" character sequence in last slash-separated component of `path` | 
					
						
							|  |  |  |  * with frame as decimal integer, with leading zeroes as necessary, to make digits digits. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2014-02-01 00:51:53 +11:00
										 |  |  | bool BLI_path_frame(char *path, int frame, int digits) ATTR_NONNULL(); | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Replaces "#" character sequence in last slash-separated component of `path` | 
					
						
							|  |  |  |  * with sta and end as decimal integers, with leading zeroes as necessary, to make digits | 
					
						
							|  |  |  |  * digits each, with a hyphen in-between. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2014-02-01 00:51:53 +11:00
										 |  |  | bool BLI_path_frame_range(char *path, int sta, int end, int digits) ATTR_NONNULL(); | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Get the frame from a filename formatted by blender's frame scheme | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2015-06-04 20:40:11 +02:00
										 |  |  | bool BLI_path_frame_get(char *path, int *r_frame, int *numdigits) ATTR_NONNULL(); | 
					
						
							| 
									
										
										
										
											2021-12-16 16:52:47 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Given a `path` with digits representing frame numbers, replace the digits with the '#' | 
					
						
							|  |  |  |  * character and extract the extension. | 
					
						
							|  |  |  |  * So:      `/some/path_123.jpeg` | 
					
						
							|  |  |  |  * Becomes: `/some/path_###` with `r_ext` set to `.jpeg`. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | void BLI_path_frame_strip(char *path, char *r_ext) ATTR_NONNULL(); | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Check if we have '#' chars, usable for #BLI_path_frame, #BLI_path_frame_range | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2014-02-01 00:51:53 +11:00
										 |  |  | bool BLI_path_frame_check_chars(const char *path) ATTR_NONNULL(); | 
					
						
							| 
									
										
										
										
											2021-12-16 16:17:28 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Checks for a relative path (ignoring Blender's "//") prefix | 
					
						
							|  |  |  |  * (unlike `!BLI_path_is_rel(path)`). | 
					
						
							|  |  |  |  * When false, #BLI_path_abs_from_cwd would expand the absolute path. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | bool BLI_path_is_abs_from_cwd(const char *path) ATTR_NONNULL(); | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Checks for relative path, expanding them relative to the current working directory. | 
					
						
							| 
									
										
										
										
											2021-12-16 16:17:28 +11:00
										 |  |  |  * \returns true if the expansion was performed. | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  |  * | 
					
						
							|  |  |  |  * \note Should only be called with command line paths. | 
					
						
							|  |  |  |  * This is _not_ something Blender's internal paths support, instead they use the "//" prefix. | 
					
						
							|  |  |  |  * In most cases #BLI_path_abs should be used instead. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2022-01-12 11:42:54 +11:00
										 |  |  | bool BLI_path_abs_from_cwd(char *path, size_t maxlen) ATTR_NONNULL(); | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Replaces `file` with a relative version (prefixed by "//") such that #BLI_path_abs, given | 
					
						
							|  |  |  |  * the same `relfile`, will convert it back to its original value. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2014-02-01 00:51:53 +11:00
										 |  |  | void BLI_path_rel(char *file, const char *relfile) ATTR_NONNULL(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Does path begin with the special "//" prefix that Blender uses to indicate | 
					
						
							|  |  |  |  * a path relative to the .blend file. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2014-02-01 00:51:53 +11:00
										 |  |  | bool BLI_path_is_rel(const char *path) ATTR_NONNULL() ATTR_WARN_UNUSED_RESULT; | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Return true if the path is a UNC share. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2014-04-21 16:49:35 +02:00
										 |  |  | bool BLI_path_is_unc(const char *path); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Creates a display string from path to be used menus and the user interface. | 
					
						
							|  |  |  |  * Like `bpy.path.display_name()`. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2018-08-28 15:12:14 +02:00
										 |  |  | void BLI_path_to_display_name(char *display_name, int maxlen, const char *name) ATTR_NONNULL(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-04-21 16:49:35 +02:00
										 |  |  | #if defined(WIN32)
 | 
					
						
							| 
									
										
										
										
											2020-04-08 16:29:46 +10:00
										 |  |  | void BLI_path_normalize_unc_16(wchar_t *path_16); | 
					
						
							| 
									
										
										
										
											2020-04-07 12:02:21 +10:00
										 |  |  | void BLI_path_normalize_unc(char *path_16, int maxlen); | 
					
						
							| 
									
										
										
										
											2014-04-21 16:49:35 +02:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2012-08-29 10:32:38 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Appends a suffix to the string, fitting it before the extension | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * string = Foo.png, suffix = 123, separator = _ | 
					
						
							|  |  |  |  * Foo.png -> Foo_123.png | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param string: original (and final) string | 
					
						
							|  |  |  |  * \param maxlen: Maximum length of string | 
					
						
							|  |  |  |  * \param suffix: String to append to the original string | 
					
						
							|  |  |  |  * \param sep: Optional separator character | 
					
						
							|  |  |  |  * \return true if succeeded | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | bool BLI_path_suffix(char *string, size_t maxlen, const char *suffix, const char *sep) | 
					
						
							|  |  |  |     ATTR_NONNULL(); | 
					
						
							| 
									
										
										
										
											2014-04-16 14:25:23 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  | /* Path string comparisons: case-insensitive for Windows, case-sensitive otherwise. */ | 
					
						
							| 
									
										
										
										
											2013-06-18 18:42:29 +00:00
										 |  |  | #if defined(WIN32)
 | 
					
						
							| 
									
										
										
										
											2011-04-06 06:03:48 +00:00
										 |  |  | #  define BLI_path_cmp BLI_strcasecmp
 | 
					
						
							|  |  |  | #  define BLI_path_ncmp BLI_strncasecmp
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | #  define BLI_path_cmp strcmp
 | 
					
						
							|  |  |  | #  define BLI_path_ncmp strncmp
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  | /* These values need to be hard-coded in structs, dna does not recognize defines */ | 
					
						
							|  |  |  | /* also defined in `DNA_space_types.h`. */ | 
					
						
							| 
									
										
										
										
											2012-09-03 22:04:14 +00:00
										 |  |  | #ifndef FILE_MAXDIR
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | #  define FILE_MAXDIR 768
 | 
					
						
							|  |  |  | #  define FILE_MAXFILE 256
 | 
					
						
							|  |  |  | #  define FILE_MAX 1024
 | 
					
						
							| 
									
										
										
										
											2012-09-03 22:04:14 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-24 05:23:03 +11:00
										 |  |  | #ifdef WIN32
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | #  define SEP '\\'
 | 
					
						
							|  |  |  | #  define ALTSEP '/'
 | 
					
						
							|  |  |  | #  define SEP_STR "\\"
 | 
					
						
							| 
									
										
										
										
											2017-03-24 05:23:03 +11:00
										 |  |  | #  define ALTSEP_STR "/"
 | 
					
						
							|  |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | #  define SEP '/'
 | 
					
						
							|  |  |  | #  define ALTSEP '\\'
 | 
					
						
							|  |  |  | #  define SEP_STR "/"
 | 
					
						
							| 
									
										
										
										
											2017-03-24 05:23:03 +11:00
										 |  |  | #  define ALTSEP_STR "\\"
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-26 16:58:02 +01:00
										 |  |  | /* Parent and current dir helpers. */ | 
					
						
							|  |  |  | #define FILENAME_PARENT ".."
 | 
					
						
							|  |  |  | #define FILENAME_CURRENT "."
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-09 20:01:44 +11:00
										 |  |  | /* Avoid calling `strcmp` on one or two chars! */ | 
					
						
							| 
									
										
										
										
											2015-01-26 16:58:02 +01:00
										 |  |  | #define FILENAME_IS_PARENT(_n) (((_n)[0] == '.') && ((_n)[1] == '.') && ((_n)[2] == '\0'))
 | 
					
						
							|  |  |  | #define FILENAME_IS_CURRENT(_n) (((_n)[0] == '.') && ((_n)[1] == '\0'))
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | #define FILENAME_IS_CURRPAR(_n) \
 | 
					
						
							|  |  |  |   (((_n)[0] == '.') && (((_n)[1] == '\0') || (((_n)[1] == '.') && ((_n)[2] == '\0')))) | 
					
						
							| 
									
										
										
										
											2015-01-26 16:58:02 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-04 16:20:42 +00:00
										 |  |  | #ifdef __cplusplus
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #endif
 |