]> git.mxchange.org Git - simgear.git/commitdiff
Add a routines that takes a search path (separated by sgSearchPathSep) and
authorcurt <curt>
Fri, 8 Aug 2003 19:54:49 +0000 (19:54 +0000)
committercurt <curt>
Fri, 8 Aug 2003 19:54:49 +0000 (19:54 +0000)
seperates them into a vector of strings which it then returns.

simgear/misc/sg_path.cxx
simgear/misc/sg_path.hxx

index dc9be8eb627350b7e06b6c5e03bc5255f940d73a..1aeb12cefd59c52dbf8742ed44c722e6b886ebb5 100644 (file)
 // $Id$
 
 
+#include <simgear/compiler.h>
+
 #include <simgear_config.h>
 #include <stdio.h>
 
 #include "sg_path.hxx"
 
 
+/**
+ * define directory path separators
+ */
+
+#ifdef macintosh
+static const char sgDirPathSep = ':';
+static const char sgDirPathSepBad = '/';
+#else
+static const char sgDirPathSep = '/';
+static const char sgDirPathSepBad = ':';
+#endif
+static const char sgSearchPathSep = ';';
+
+
 // If Unix, replace all ":" with "/".  If MacOS, replace all "/" with
 // ":" it should go without saying that neither of these characters
 // should be used in file or directory names.  In windoze, allow the
@@ -44,8 +60,8 @@ SGPath::fix()
            continue;
        }
 #endif
-       if ( path[i] == SG_BAD_PATH_SEP ) {
-           path[i] = SG_PATH_SEP;
+       if ( path[i] == sgDirPathSepBad ) {
+           path[i] = sgDirPathSep;
        }
     }
 }
@@ -83,8 +99,8 @@ void SGPath::append( const string& p ) {
     if ( path.size() == 0 ) {
        path = p;
     } else {
-       if ( p[0] != SG_PATH_SEP ) {
-           path += SG_PATH_SEP;
+       if ( p[0] != sgDirPathSep ) {
+           path += sgDirPathSep;
        }
        path += p;
     }
@@ -106,7 +122,7 @@ void SGPath::concat( const string& p ) {
 
 // Get the file part of the path (everything after the last path sep)
 string SGPath::file() const {
-    int index = path.rfind(SG_PATH_SEP);
+    int index = path.rfind(sgDirPathSep);
     if (index >= 0) {
        return path.substr(index + 1);
     } else {
@@ -117,7 +133,7 @@ string SGPath::file() const {
 
 // get the directory part of the path.
 string SGPath::dir() const {
-    int index = path.rfind(SG_PATH_SEP);
+    int index = path.rfind(sgDirPathSep);
     if (index >= 0) {
        return path.substr(0, index);
     } else {
@@ -153,3 +169,25 @@ bool SGPath::exists() const {
     fclose(fp);
     return true;
 }
+
+
+string_list sgPathSplit( const string &search_path ) {
+    string tmp = search_path;
+    string_list result;
+    result.clear();
+
+    bool done = false;
+
+    while ( !done ) {
+        int index = tmp.find(sgSearchPathSep);
+        if (index >= 0) {
+            result.push_back( tmp.substr(0, index) );
+            tmp = tmp.substr( index + 1 );
+        } else {
+            result.push_back( tmp );
+            done = true;
+        }
+    }
+
+    return result;
+}
index 9b0e5939472d158e6df2e58f698ec39f6d969b5b..bdb45e01e74d78e8af654086990636e29cc08bb9 100644 (file)
 
 
 #include <simgear/compiler.h>
-
 #include STL_STRING
 
-SG_USING_STD(string);
-
+#include <simgear/math/sg_types.hxx>
 
-#ifdef macintosh
-#  define SG_PATH_SEP ':'
-#  define SG_BAD_PATH_SEP '/'
-#else
-#  define SG_PATH_SEP '/'
-#  define SG_BAD_PATH_SEP ':'
-#endif
+SG_USING_STD(string);
 
 
 /**
@@ -141,6 +133,12 @@ private:
 };
 
 
+/**
+ * Split a directory search path into a vector of individual paths
+ */
+string_list sgPathSplit( const string &search_path );
+
+
 #endif // _SG_PATH_HXX