1*c8dee2aaSAndroid Build Coastguard Worker /* 2*c8dee2aaSAndroid Build Coastguard Worker * Copyright 2016 Google Inc. 3*c8dee2aaSAndroid Build Coastguard Worker * 4*c8dee2aaSAndroid Build Coastguard Worker * Use of this source code is governed by a BSD-style license that can be 5*c8dee2aaSAndroid Build Coastguard Worker * found in the LICENSE file. 6*c8dee2aaSAndroid Build Coastguard Worker */ 7*c8dee2aaSAndroid Build Coastguard Worker 8*c8dee2aaSAndroid Build Coastguard Worker #ifndef SkOSPath_DEFINED 9*c8dee2aaSAndroid Build Coastguard Worker #define SkOSPath_DEFINED 10*c8dee2aaSAndroid Build Coastguard Worker 11*c8dee2aaSAndroid Build Coastguard Worker #include "include/core/SkString.h" 12*c8dee2aaSAndroid Build Coastguard Worker 13*c8dee2aaSAndroid Build Coastguard Worker /** 14*c8dee2aaSAndroid Build Coastguard Worker * Functions for modifying SkStrings which represent paths on the filesystem. 15*c8dee2aaSAndroid Build Coastguard Worker */ 16*c8dee2aaSAndroid Build Coastguard Worker class SkOSPath { 17*c8dee2aaSAndroid Build Coastguard Worker public: 18*c8dee2aaSAndroid Build Coastguard Worker #ifdef _WIN32 19*c8dee2aaSAndroid Build Coastguard Worker static constexpr char SEPARATOR = '\\'; 20*c8dee2aaSAndroid Build Coastguard Worker #else 21*c8dee2aaSAndroid Build Coastguard Worker static constexpr char SEPARATOR = '/'; 22*c8dee2aaSAndroid Build Coastguard Worker #endif 23*c8dee2aaSAndroid Build Coastguard Worker 24*c8dee2aaSAndroid Build Coastguard Worker /** 25*c8dee2aaSAndroid Build Coastguard Worker * Assembles rootPath and relativePath into a single path, like this: 26*c8dee2aaSAndroid Build Coastguard Worker * rootPath/relativePath. 27*c8dee2aaSAndroid Build Coastguard Worker * It is okay to call with a NULL rootPath and/or relativePath. A path 28*c8dee2aaSAndroid Build Coastguard Worker * separator will still be inserted. 29*c8dee2aaSAndroid Build Coastguard Worker * 30*c8dee2aaSAndroid Build Coastguard Worker * Uses SkPATH_SEPARATOR, to work on all platforms. 31*c8dee2aaSAndroid Build Coastguard Worker */ 32*c8dee2aaSAndroid Build Coastguard Worker static SkString Join(const char* rootPath, const char* relativePath); 33*c8dee2aaSAndroid Build Coastguard Worker 34*c8dee2aaSAndroid Build Coastguard Worker /** 35*c8dee2aaSAndroid Build Coastguard Worker * Return the name of the file, ignoring the directory structure. 36*c8dee2aaSAndroid Build Coastguard Worker * Behaves like python's os.path.basename. If the fullPath is 37*c8dee2aaSAndroid Build Coastguard Worker * /dir/subdir/, an empty string is returned. 38*c8dee2aaSAndroid Build Coastguard Worker * @param fullPath Full path to the file. 39*c8dee2aaSAndroid Build Coastguard Worker * @return SkString The basename of the file - anything beyond the 40*c8dee2aaSAndroid Build Coastguard Worker * final slash, or the full name if there is no slash. 41*c8dee2aaSAndroid Build Coastguard Worker */ 42*c8dee2aaSAndroid Build Coastguard Worker static SkString Basename(const char* fullPath); 43*c8dee2aaSAndroid Build Coastguard Worker 44*c8dee2aaSAndroid Build Coastguard Worker /** 45*c8dee2aaSAndroid Build Coastguard Worker * Given a qualified file name returns the directory. 46*c8dee2aaSAndroid Build Coastguard Worker * Behaves like python's os.path.dirname. If the fullPath is 47*c8dee2aaSAndroid Build Coastguard Worker * /dir/subdir/ the return will be /dir/subdir/ 48*c8dee2aaSAndroid Build Coastguard Worker * @param fullPath Full path to the file. 49*c8dee2aaSAndroid Build Coastguard Worker * @return SkString The dir containing the file - anything preceding the 50*c8dee2aaSAndroid Build Coastguard Worker * final slash, or the full name if ending in a slash. 51*c8dee2aaSAndroid Build Coastguard Worker */ 52*c8dee2aaSAndroid Build Coastguard Worker static SkString Dirname(const char* fullPath); 53*c8dee2aaSAndroid Build Coastguard Worker }; 54*c8dee2aaSAndroid Build Coastguard Worker 55*c8dee2aaSAndroid Build Coastguard Worker #endif 56