1 /*****************************************************************************/
5 /* Handling of search paths */
9 /* (C) 2000-2013, Ullrich von Bassewitz */
10 /* Roemerstrasse 52 */
11 /* D-70794 Filderstadt */
12 /* EMail: uz@cc65.org */
15 /* This software is provided 'as-is', without any expressed or implied */
16 /* warranty. In no event will the authors be held liable for any damages */
17 /* arising from the use of this software. */
19 /* Permission is granted to anyone to use this software for any purpose, */
20 /* including commercial applications, and to alter it and redistribute it */
21 /* freely, subject to the following restrictions: */
23 /* 1. The origin of this software must not be misrepresented; you must not */
24 /* claim that you wrote the original software. If you use this software */
25 /* in a product, an acknowledgment in the product documentation would be */
26 /* appreciated but is not required. */
27 /* 2. Altered source versions must be plainly marked as such, and must not */
28 /* be misrepresented as being the original software. */
29 /* 3. This notice may not be removed or altered from any source */
32 /*****************************************************************************/
36 /* Exports facilities to search files in a list of directories. */
45 /*****************************************************************************/
47 /*****************************************************************************/
51 /* Convert argument to C string */
52 #define _STRINGIZE(arg) #arg
53 #define STRINGIZE(arg) _STRINGIZE(arg)
55 /* A search path is a pointer to the list */
56 typedef struct Collection SearchPath;
60 /*****************************************************************************/
62 /*****************************************************************************/
66 SearchPath* NewSearchPath (void);
67 /* Create a new, empty search path list */
69 void AddSearchPath (SearchPath* P, const char* NewPath);
70 /* Add a new search path to the end of an existing list */
72 void AddSearchPathFromEnv (SearchPath* P, const char* EnvVar);
73 /* Add a search path from an environment variable to the end of an existing
77 void AddSubSearchPathFromEnv (SearchPath* P, const char* EnvVar, const char* SubDir);
78 /* Add a search path from an environment variable, adding a subdirectory to
79 * the environment variable value.
82 void AddSubSearchPathFromWinBin (SearchPath* P, const char* SubDir);
84 * Add a search path from the running binary, adding a subdirectory to
85 * the parent directory of the directory containing the binary.
88 int PushSearchPath (SearchPath* P, const char* NewPath);
89 /* Add a new search path to the head of an existing search path list, provided
90 * that it's not already there. If the path is already at the first position,
91 * return zero, otherwise return a non zero value.
94 void PopSearchPath (SearchPath* P);
95 /* Remove a search path from the head of an existing search path list */
97 char* SearchFile (const SearchPath* P, const char* File);
98 /* Search for a file in a list of directories. Return a pointer to a malloced
99 * area that contains the complete path, if found, return 0 otherwise.
104 /* End of searchpath.h */