diff options
Diffstat (limited to 'linden/indra/llvfs')
-rw-r--r-- | linden/indra/llvfs/lldir.cpp | 107 | ||||
-rw-r--r-- | linden/indra/llvfs/lldir.h | 24 | ||||
-rw-r--r-- | linden/indra/llvfs/lldir_linux.cpp | 2 | ||||
-rw-r--r-- | linden/indra/llvfs/lldir_linux.h | 2 | ||||
-rw-r--r-- | linden/indra/llvfs/lldir_mac.cpp | 2 | ||||
-rw-r--r-- | linden/indra/llvfs/lldir_mac.h | 2 | ||||
-rw-r--r-- | linden/indra/llvfs/lldir_win32.cpp | 2 | ||||
-rw-r--r-- | linden/indra/llvfs/lldir_win32.h | 2 |
8 files changed, 106 insertions, 37 deletions
diff --git a/linden/indra/llvfs/lldir.cpp b/linden/indra/llvfs/lldir.cpp index 084d3aa..246595a 100644 --- a/linden/indra/llvfs/lldir.cpp +++ b/linden/indra/llvfs/lldir.cpp | |||
@@ -59,18 +59,8 @@ LLDir_Linux gDirUtil; | |||
59 | 59 | ||
60 | LLDir *gDirUtilp = (LLDir *)&gDirUtil; | 60 | LLDir *gDirUtilp = (LLDir *)&gDirUtil; |
61 | 61 | ||
62 | LLDir::LLDir() | 62 | LLDir::LLDir() |
63 | : mAppName(""), | 63 | : mDirDelimiter("/") // fallback to forward slash if not overridden |
64 | mExecutablePathAndName(""), | ||
65 | mExecutableFilename(""), | ||
66 | mExecutableDir(""), | ||
67 | mAppRODataDir(""), | ||
68 | mOSUserDir(""), | ||
69 | mOSUserAppDir(""), | ||
70 | mLindenUserDir(""), | ||
71 | mCAFile(""), | ||
72 | mTempDir(""), | ||
73 | mDirDelimiter("") | ||
74 | { | 64 | { |
75 | } | 65 | } |
76 | 66 | ||
@@ -125,7 +115,7 @@ S32 LLDir::deleteFilesInDir(const std::string &dirname, const std::string &mask) | |||
125 | const std::string LLDir::findFile(const std::string &filename, | 115 | const std::string LLDir::findFile(const std::string &filename, |
126 | const std::string searchPath1, | 116 | const std::string searchPath1, |
127 | const std::string searchPath2, | 117 | const std::string searchPath2, |
128 | const std::string searchPath3) | 118 | const std::string searchPath3) const |
129 | { | 119 | { |
130 | std::vector<std::string> search_paths; | 120 | std::vector<std::string> search_paths; |
131 | search_paths.push_back(searchPath1); | 121 | search_paths.push_back(searchPath1); |
@@ -246,12 +236,37 @@ const std::string &LLDir::getSkinDir() const | |||
246 | return mSkinDir; | 236 | return mSkinDir; |
247 | } | 237 | } |
248 | 238 | ||
239 | const std::string &LLDir::getUserSkinDir() const | ||
240 | { | ||
241 | return mUserSkinDir; | ||
242 | } | ||
243 | |||
244 | const std::string& LLDir::getDefaultSkinDir() const | ||
245 | { | ||
246 | return mDefaultSkinDir; | ||
247 | } | ||
248 | |||
249 | const std::string LLDir::getSkinBaseDir() const | ||
250 | { | ||
251 | std::string dir = getAppRODataDir(); | ||
252 | dir += mDirDelimiter; | ||
253 | dir += "skins"; | ||
254 | |||
255 | return dir; | ||
256 | } | ||
257 | |||
258 | |||
249 | std::string LLDir::getExpandedFilename(ELLPath location, const std::string& filename) const | 259 | std::string LLDir::getExpandedFilename(ELLPath location, const std::string& filename) const |
250 | { | 260 | { |
251 | return getExpandedFilename(location, "", filename); | 261 | return getExpandedFilename(location, "", filename); |
252 | } | 262 | } |
253 | 263 | ||
254 | std::string LLDir::getExpandedFilename(ELLPath location, const std::string& subdir, const std::string& in_filename) const | 264 | std::string LLDir::getExpandedFilename(ELLPath location, const std::string& subdir, const std::string& filename) const |
265 | { | ||
266 | return getExpandedFilename(location, "", subdir, filename); | ||
267 | } | ||
268 | |||
269 | std::string LLDir::getExpandedFilename(ELLPath location, const std::string& subdir1, const std::string& subdir2, const std::string& in_filename) const | ||
255 | { | 270 | { |
256 | std::string prefix; | 271 | std::string prefix; |
257 | switch (location) | 272 | switch (location) |
@@ -324,13 +339,11 @@ std::string LLDir::getExpandedFilename(ELLPath location, const std::string& subd | |||
324 | prefix += "skins"; | 339 | prefix += "skins"; |
325 | break; | 340 | break; |
326 | 341 | ||
327 | case LL_PATH_HTML: | 342 | //case LL_PATH_HTML: |
328 | prefix = getAppRODataDir(); | 343 | // prefix = getSkinDir(); |
329 | prefix += mDirDelimiter; | 344 | // prefix += mDirDelimiter; |
330 | prefix += "skins"; | 345 | // prefix += "html"; |
331 | prefix += mDirDelimiter; | 346 | // break; |
332 | prefix += "html"; | ||
333 | break; | ||
334 | 347 | ||
335 | case LL_PATH_MOZILLA_PROFILE: | 348 | case LL_PATH_MOZILLA_PROFILE: |
336 | prefix = getOSUserAppDir(); | 349 | prefix = getOSUserAppDir(); |
@@ -343,15 +356,16 @@ std::string LLDir::getExpandedFilename(ELLPath location, const std::string& subd | |||
343 | } | 356 | } |
344 | 357 | ||
345 | std::string filename = in_filename; | 358 | std::string filename = in_filename; |
346 | if (!subdir.empty()) | 359 | if (!subdir2.empty()) |
347 | { | 360 | { |
348 | filename = subdir + mDirDelimiter + in_filename; | 361 | filename = subdir2 + mDirDelimiter + filename; |
349 | } | 362 | } |
350 | else | 363 | |
364 | if (!subdir1.empty()) | ||
351 | { | 365 | { |
352 | filename = in_filename; | 366 | filename = subdir1 + mDirDelimiter + filename; |
353 | } | 367 | } |
354 | 368 | ||
355 | std::string expanded_filename; | 369 | std::string expanded_filename; |
356 | if (!filename.empty()) | 370 | if (!filename.empty()) |
357 | { | 371 | { |
@@ -381,6 +395,31 @@ std::string LLDir::getExpandedFilename(ELLPath location, const std::string& subd | |||
381 | return expanded_filename; | 395 | return expanded_filename; |
382 | } | 396 | } |
383 | 397 | ||
398 | std::string LLDir::findSkinnedFilename(const std::string &filename) const | ||
399 | { | ||
400 | return findSkinnedFilename("", "", filename); | ||
401 | } | ||
402 | |||
403 | std::string LLDir::findSkinnedFilename(const std::string &subdir, const std::string &filename) const | ||
404 | { | ||
405 | return findSkinnedFilename("", subdir, filename); | ||
406 | } | ||
407 | |||
408 | std::string LLDir::findSkinnedFilename(const std::string &subdir1, const std::string &subdir2, const std::string &filename) const | ||
409 | { | ||
410 | // generate subdirectory path fragment, e.g. "/foo/bar", "/foo", "" | ||
411 | std::string subdirs = ((subdir1.empty() ? "" : mDirDelimiter) + subdir1) | ||
412 | + ((subdir2.empty() ? "" : mDirDelimiter) + subdir2); | ||
413 | |||
414 | std::string found_file = findFile(filename, | ||
415 | getUserSkinDir() + subdirs, // first look in user skin override | ||
416 | getSkinDir() + subdirs, // then in current skin | ||
417 | getDefaultSkinDir() + subdirs); // and last in default skin | ||
418 | |||
419 | return found_file; | ||
420 | } | ||
421 | |||
422 | |||
384 | std::string LLDir::getTempFilename() const | 423 | std::string LLDir::getTempFilename() const |
385 | { | 424 | { |
386 | LLUUID random_uuid; | 425 | LLUUID random_uuid; |
@@ -464,6 +503,22 @@ void LLDir::setSkinFolder(const std::string &skin_folder) | |||
464 | mSkinDir += "skins"; | 503 | mSkinDir += "skins"; |
465 | mSkinDir += mDirDelimiter; | 504 | mSkinDir += mDirDelimiter; |
466 | mSkinDir += skin_folder; | 505 | mSkinDir += skin_folder; |
506 | |||
507 | // user modifications to current skin | ||
508 | // e.g. c:\documents and settings\users\username\application data\second life\skins\dazzle | ||
509 | mUserSkinDir = getOSUserAppDir(); | ||
510 | mUserSkinDir += mDirDelimiter; | ||
511 | mUserSkinDir += "skins"; | ||
512 | mUserSkinDir += mDirDelimiter; | ||
513 | mUserSkinDir += skin_folder; | ||
514 | |||
515 | // base skin which is used as fallback for all skinned files | ||
516 | // e.g. c:\program files\secondlife\skins\default | ||
517 | mDefaultSkinDir = getAppRODataDir(); | ||
518 | mDefaultSkinDir += mDirDelimiter; | ||
519 | mDefaultSkinDir += "skins"; | ||
520 | mDefaultSkinDir += mDirDelimiter; | ||
521 | mDefaultSkinDir += "default"; | ||
467 | } | 522 | } |
468 | 523 | ||
469 | bool LLDir::setCacheDir(const std::string &path) | 524 | bool LLDir::setCacheDir(const std::string &path) |
diff --git a/linden/indra/llvfs/lldir.h b/linden/indra/llvfs/lldir.h index c8eeaa2..8734c44 100644 --- a/linden/indra/llvfs/lldir.h +++ b/linden/indra/llvfs/lldir.h | |||
@@ -32,6 +32,7 @@ | |||
32 | #ifndef LL_LLDIR_H | 32 | #ifndef LL_LLDIR_H |
33 | #define LL_LLDIR_H | 33 | #define LL_LLDIR_H |
34 | 34 | ||
35 | // these numbers *may* get serialized, so we need to be explicit | ||
35 | typedef enum ELLPath | 36 | typedef enum ELLPath |
36 | { | 37 | { |
37 | LL_PATH_NONE = 0, | 38 | LL_PATH_NONE = 0, |
@@ -49,8 +50,8 @@ typedef enum ELLPath | |||
49 | LL_PATH_CHAT_LOGS = 12, | 50 | LL_PATH_CHAT_LOGS = 12, |
50 | LL_PATH_PER_ACCOUNT_CHAT_LOGS = 13, | 51 | LL_PATH_PER_ACCOUNT_CHAT_LOGS = 13, |
51 | LL_PATH_MOZILLA_PROFILE = 14, | 52 | LL_PATH_MOZILLA_PROFILE = 14, |
52 | LL_PATH_HTML = 15, | 53 | // LL_PATH_HTML = 15, |
53 | LL_PATH_COUNT = 16 | 54 | LL_PATH_LAST = 16 |
54 | } ELLPath; | 55 | } ELLPath; |
55 | 56 | ||
56 | 57 | ||
@@ -69,9 +70,9 @@ class LLDir | |||
69 | virtual BOOL getNextFileInDir(const std::string &dirname, const std::string &mask, std::string &fname, BOOL wrap) = 0; | 70 | virtual BOOL getNextFileInDir(const std::string &dirname, const std::string &mask, std::string &fname, BOOL wrap) = 0; |
70 | virtual void getRandomFileInDir(const std::string &dirname, const std::string &mask, std::string &fname) = 0; | 71 | virtual void getRandomFileInDir(const std::string &dirname, const std::string &mask, std::string &fname) = 0; |
71 | virtual std::string getCurPath() = 0; | 72 | virtual std::string getCurPath() = 0; |
72 | virtual BOOL fileExists(const std::string &filename) = 0; | 73 | virtual BOOL fileExists(const std::string &filename) const = 0; |
73 | 74 | ||
74 | const std::string findFile(const std::string &filename, const std::string searchPath1 = "", const std::string searchPath2 = "", const std::string searchPath3 = ""); | 75 | const std::string findFile(const std::string &filename, const std::string searchPath1 = "", const std::string searchPath2 = "", const std::string searchPath3 = "") const; |
75 | const std::string &getExecutablePathAndName() const; // Full pathname of the executable | 76 | const std::string &getExecutablePathAndName() const; // Full pathname of the executable |
76 | const std::string &getAppName() const; // install directory under progams/ ie "SecondLife" | 77 | const std::string &getAppName() const; // install directory under progams/ ie "SecondLife" |
77 | const std::string &getExecutableDir() const; // Directory where the executable is located | 78 | const std::string &getExecutableDir() const; // Directory where the executable is located |
@@ -88,10 +89,21 @@ class LLDir | |||
88 | const std::string &getCAFile() const; // File containing TLS certificate authorities | 89 | const std::string &getCAFile() const; // File containing TLS certificate authorities |
89 | const std::string &getDirDelimiter() const; // directory separator for platform (ie. '\' or '/' or ':') | 90 | const std::string &getDirDelimiter() const; // directory separator for platform (ie. '\' or '/' or ':') |
90 | const std::string &getSkinDir() const; // User-specified skin folder. | 91 | const std::string &getSkinDir() const; // User-specified skin folder. |
92 | const std::string &getUserSkinDir() const; // User-specified skin folder with user modifications. e.g. c:\documents and settings\username\application data\second life\skins\curskin | ||
93 | const std::string &getDefaultSkinDir() const; // folder for default skin. e.g. c:\program files\second life\skins\default | ||
94 | const std::string getSkinBaseDir() const; // folder that contains all installed skins (not user modifications). e.g. c:\program files\second life\skins | ||
91 | 95 | ||
92 | // Expanded filename | 96 | // Expanded filename |
93 | std::string getExpandedFilename(ELLPath location, const std::string &filename) const; | 97 | std::string getExpandedFilename(ELLPath location, const std::string &filename) const; |
94 | std::string getExpandedFilename(ELLPath location, const std::string &subdir, const std::string &filename) const; | 98 | std::string getExpandedFilename(ELLPath location, const std::string &subdir, const std::string &filename) const; |
99 | std::string getExpandedFilename(ELLPath location, const std::string &subdir1, const std::string &subdir2, const std::string &filename) const; | ||
100 | |||
101 | // these methods search the various skin paths for the specified file in the following order: | ||
102 | // getUserSkinDir(), getSkinDir(), getDefaultSkinDir() | ||
103 | std::string findSkinnedFilename(const std::string &filename) const; | ||
104 | std::string findSkinnedFilename(const std::string &subdir, const std::string &filename) const; | ||
105 | std::string findSkinnedFilename(const std::string &subdir1, const std::string &subdir2, const std::string &filename) const; | ||
106 | |||
95 | 107 | ||
96 | // random filename in common temporary directory | 108 | // random filename in common temporary directory |
97 | std::string getTempFilename() const; | 109 | std::string getTempFilename() const; |
@@ -120,7 +132,9 @@ protected: | |||
120 | std::string mTempDir; | 132 | std::string mTempDir; |
121 | std::string mCacheDir; | 133 | std::string mCacheDir; |
122 | std::string mDirDelimiter; | 134 | std::string mDirDelimiter; |
123 | std::string mSkinDir; // Location for u ser-specified skin info. | 135 | std::string mSkinDir; // Location for current skin info. |
136 | std::string mDefaultSkinDir; // Location for default skin info. | ||
137 | std::string mUserSkinDir; // Location for user-modified skin info. | ||
124 | }; | 138 | }; |
125 | 139 | ||
126 | void dir_exists_or_crash(const std::string &dir_name); | 140 | void dir_exists_or_crash(const std::string &dir_name); |
diff --git a/linden/indra/llvfs/lldir_linux.cpp b/linden/indra/llvfs/lldir_linux.cpp index 0e4e0a2..9aa4da3 100644 --- a/linden/indra/llvfs/lldir_linux.cpp +++ b/linden/indra/llvfs/lldir_linux.cpp | |||
@@ -349,7 +349,7 @@ std::string LLDir_Linux::getCurPath() | |||
349 | } | 349 | } |
350 | 350 | ||
351 | 351 | ||
352 | BOOL LLDir_Linux::fileExists(const std::string &filename) | 352 | BOOL LLDir_Linux::fileExists(const std::string &filename) const |
353 | { | 353 | { |
354 | struct stat stat_data; | 354 | struct stat stat_data; |
355 | // Check the age of the file | 355 | // Check the age of the file |
diff --git a/linden/indra/llvfs/lldir_linux.h b/linden/indra/llvfs/lldir_linux.h index 4815fe9..99925c1 100644 --- a/linden/indra/llvfs/lldir_linux.h +++ b/linden/indra/llvfs/lldir_linux.h | |||
@@ -49,7 +49,7 @@ public: | |||
49 | virtual U32 countFilesInDir(const std::string &dirname, const std::string &mask); | 49 | virtual U32 countFilesInDir(const std::string &dirname, const std::string &mask); |
50 | virtual BOOL getNextFileInDir(const std::string &dirname, const std::string &mask, std::string &fname, BOOL wrap); | 50 | virtual BOOL getNextFileInDir(const std::string &dirname, const std::string &mask, std::string &fname, BOOL wrap); |
51 | virtual void getRandomFileInDir(const std::string &dirname, const std::string &mask, std::string &fname); | 51 | virtual void getRandomFileInDir(const std::string &dirname, const std::string &mask, std::string &fname); |
52 | /*virtual*/ BOOL fileExists(const std::string &filename); | 52 | /*virtual*/ BOOL fileExists(const std::string &filename) const; |
53 | 53 | ||
54 | private: | 54 | private: |
55 | DIR *mDirp; | 55 | DIR *mDirp; |
diff --git a/linden/indra/llvfs/lldir_mac.cpp b/linden/indra/llvfs/lldir_mac.cpp index f67a487..8b1be53 100644 --- a/linden/indra/llvfs/lldir_mac.cpp +++ b/linden/indra/llvfs/lldir_mac.cpp | |||
@@ -361,7 +361,7 @@ std::string LLDir_Mac::getCurPath() | |||
361 | 361 | ||
362 | 362 | ||
363 | 363 | ||
364 | BOOL LLDir_Mac::fileExists(const std::string &filename) | 364 | BOOL LLDir_Mac::fileExists(const std::string &filename) const |
365 | { | 365 | { |
366 | struct stat stat_data; | 366 | struct stat stat_data; |
367 | // Check the age of the file | 367 | // Check the age of the file |
diff --git a/linden/indra/llvfs/lldir_mac.h b/linden/indra/llvfs/lldir_mac.h index 73c964d..beb8c93 100644 --- a/linden/indra/llvfs/lldir_mac.h +++ b/linden/indra/llvfs/lldir_mac.h | |||
@@ -49,7 +49,7 @@ public: | |||
49 | virtual U32 countFilesInDir(const std::string &dirname, const std::string &mask); | 49 | virtual U32 countFilesInDir(const std::string &dirname, const std::string &mask); |
50 | virtual BOOL getNextFileInDir(const std::string &dirname, const std::string &mask, std::string &fname, BOOL wrap); | 50 | virtual BOOL getNextFileInDir(const std::string &dirname, const std::string &mask, std::string &fname, BOOL wrap); |
51 | virtual void getRandomFileInDir(const std::string &dirname, const std::string &ask, std::string &fname); | 51 | virtual void getRandomFileInDir(const std::string &dirname, const std::string &ask, std::string &fname); |
52 | virtual BOOL fileExists(const std::string &filename); | 52 | virtual BOOL fileExists(const std::string &filename) const; |
53 | 53 | ||
54 | private: | 54 | private: |
55 | int mCurrentDirIndex; | 55 | int mCurrentDirIndex; |
diff --git a/linden/indra/llvfs/lldir_win32.cpp b/linden/indra/llvfs/lldir_win32.cpp index ae87aa1..8904dff 100644 --- a/linden/indra/llvfs/lldir_win32.cpp +++ b/linden/indra/llvfs/lldir_win32.cpp | |||
@@ -338,7 +338,7 @@ std::string LLDir_Win32::getCurPath() | |||
338 | } | 338 | } |
339 | 339 | ||
340 | 340 | ||
341 | BOOL LLDir_Win32::fileExists(const std::string &filename) | 341 | BOOL LLDir_Win32::fileExists(const std::string &filename) const |
342 | { | 342 | { |
343 | llstat stat_data; | 343 | llstat stat_data; |
344 | // Check the age of the file | 344 | // Check the age of the file |
diff --git a/linden/indra/llvfs/lldir_win32.h b/linden/indra/llvfs/lldir_win32.h index 2744ea2..e988d39 100644 --- a/linden/indra/llvfs/lldir_win32.h +++ b/linden/indra/llvfs/lldir_win32.h | |||
@@ -46,7 +46,7 @@ public: | |||
46 | /*virtual*/ U32 countFilesInDir(const std::string &dirname, const std::string &mask); | 46 | /*virtual*/ U32 countFilesInDir(const std::string &dirname, const std::string &mask); |
47 | /*virtual*/ BOOL getNextFileInDir(const std::string &dirname, const std::string &mask, std::string &fname, BOOL wrap); | 47 | /*virtual*/ BOOL getNextFileInDir(const std::string &dirname, const std::string &mask, std::string &fname, BOOL wrap); |
48 | /*virtual*/ void getRandomFileInDir(const std::string &dirname, const std::string &mask, std::string &fname); | 48 | /*virtual*/ void getRandomFileInDir(const std::string &dirname, const std::string &mask, std::string &fname); |
49 | /*virtual*/ BOOL fileExists(const std::string &filename); | 49 | /*virtual*/ BOOL fileExists(const std::string &filename) const; |
50 | 50 | ||
51 | private: | 51 | private: |
52 | BOOL LLDir_Win32::getNextFileInDir(const llutf16string &dirname, const std::string &mask, std::string &fname, BOOL wrap); | 52 | BOOL LLDir_Win32::getNextFileInDir(const llutf16string &dirname, const std::string &mask, std::string &fname, BOOL wrap); |