X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=kernel%2Fsrc%2FbbtkUtilities.h;h=bfad45561227dad6df11949bc2577822be9ce438;hb=75cc88fbe565b4ee1a627bab47e6703d8d3399f1;hp=2e771a94baca939286ac7941fb263774b738e661;hpb=342c21bb6c5f2ba6ba76aacb403ce1201a10957c;p=bbtk.git diff --git a/kernel/src/bbtkUtilities.h b/kernel/src/bbtkUtilities.h index 2e771a9..bfad455 100644 --- a/kernel/src/bbtkUtilities.h +++ b/kernel/src/bbtkUtilities.h @@ -3,8 +3,8 @@ Program: bbtk Module: $RCSfile: bbtkUtilities.h,v $ Language: C++ - Date: $Date: 2008/01/28 09:12:49 $ - Version: $Revision: 1.4 $ + Date: $Date: 2008/02/18 10:41:02 $ + Version: $Revision: 1.12 $ Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de l'Image). All rights reserved. See doc/license.txt or @@ -26,7 +26,7 @@ * \class bbtk::Utilities * \brief various usefull methods */ - + #ifndef __bbtkUtilities_h_INCLUDED__ #define __bbtkUtilities_h_INCLUDED__ @@ -39,6 +39,15 @@ #define BBTK_USE_TERMIOS_BASED_PROMPT #endif +#ifdef _MSC_VER + #include + #include +#else + #include + #include +#endif + +#include // std::toupper //#include "bbtkMessageManager.h" namespace bbtk @@ -46,10 +55,9 @@ namespace bbtk /// Holds various usefull methods struct BBTK_EXPORT Utilities { - // =================================================================================== - + // See : http://www.techbytes.ca/techbyte103.html for more O.S. static inline bool FileExists(std::string strFilename) { @@ -96,7 +104,7 @@ namespace bbtk { pkgname = name; } - + // remove {.so | dll} if any std::string::size_type dot_position = pkgname.find_last_of('.'); if (dot_position != std::string::npos){ @@ -120,7 +128,8 @@ namespace bbtk // WIN 32 mechanism // shared lib name = .dll - // remove {bb} if any +// EED Problem loading package call bbtkTools +// // remove {bb} if any if (memcmp (pkgname.c_str(), "bb", 2) == 0) { pkgname = pkgname.substr(2, pkgname.length()); } @@ -137,13 +146,15 @@ namespace bbtk // =================================================================================== - static std::string ExtractScriptName(const std::string &name) + static std::string ExtractScriptName(const std::string &name, + std::string& path) { std::string pkgname; std::string::size_type slash_position = name.find_last_of("/\\"); if (slash_position != std::string::npos) { pkgname =name.substr(slash_position+1,std::string::npos); + path = name.substr(0,slash_position); } else { pkgname = name; } @@ -170,9 +181,9 @@ namespace bbtk // tooHigh : true is user supplies a library pathname with too many "../" bool tooHigh = false; -//std::cout << "------------------cwd [" << cwd << "]" << std::endl; +//std::cout << "------------------cwd [" << cwd << "] name [" << name << "]" << std::endl; - if ( name[0] == '/' || name[0] == '\\' ) + if ( name[0] == '/' || name[1] == ':' ) // Linux or Windows absolute name { return(libname); } @@ -279,28 +290,59 @@ namespace bbtk // =================================================================================== - static inline std::string MakePkgnameFromPath(std::string path, std::string pkgname) + static inline std::string MakePkgnameFromPath(std::string path, std::string pkgname, bool addExt) { std::string libname = path; - char c = path[path.size()-1]; - if (c != '/' && c != '\\') - libname += ConfigurationFile::GetInstance().Get_file_separator (); - libname += pkgname; - libname += ".bbs"; + char c = path[path.size()-1]; + if (c != '/' && c != '\\') + { + libname += ConfigurationFile::GetInstance().Get_file_separator (); + } + libname += pkgname; + if (addExt) + { + int l = libname.size(); + if (l>4) + { + if (libname.substr(l-4, 4) != ".bbs") + { + libname = libname + ".bbs"; + } + } + } return libname; } // =================================================================================== static inline bool IsAtRoot(std::string cwd) - { + { if ( cwd == "/" // hope it gets / (for Linux) || (cwd.size() <= 3 && cwd[1] == ':') ) // hope it gets C: D: (for Windows) return (true); else return(false); -} + } + +// =================================================================================== +static bool IsDirectory(std::string const &dirName) +{ + struct stat fs; + + if ( stat(dirName.c_str(), &fs) == 0 ) + { +#if _WIN32 + return ((fs.st_mode & _S_IFDIR) != 0); +#else + return S_ISDIR(fs.st_mode); +#endif + } + else + { + return false; + } +} // =================================================================================== @@ -323,6 +365,29 @@ namespace bbtk right = ""; } } + //======================================================================= + static inline void SplitString ( const std::string& str, + const std::string& delimiters, + std::vector& tokens) + { + // Skip delimiters at beginning. + std::string::size_type lastPos = str.find_first_not_of(delimiters, 0); + // Find first delimiter. + std::string::size_type pos = str.find_first_of(delimiters, lastPos); + + while (std::string::npos != pos || std::string::npos != lastPos) + { + // Found a token, add it to the vector. + tokens.push_back(str.substr(lastPos, pos - lastPos)); + // Skip delimiters. Note the "not_of" + lastPos = str.find_first_not_of(delimiters, pos); + // Find next delimiter + pos = str.find_first_of(delimiters, lastPos); + } + + } + //======================================================================= + // =================================================================================== @@ -338,7 +403,114 @@ namespace bbtk return s; } } + +// =================================================================================== +/** + * \brief Explore a directory with possibility of recursion + * return number of files read + * @param dirpath directory to explore + * @param recursive whether we want recursion or not + */ +static int Explore(std::string const &dirpath, bool recursive, std::vector &Filenames) +{ + int numberOfFiles = 0; + std::string fileName; + + std::string dirName = dirpath; + +#ifdef _MSC_VER + WIN32_FIND_DATA fileData; + HANDLE hFile = FindFirstFile((dirName+"*").c_str(), &fileData); + + for(BOOL b = (hFile != INVALID_HANDLE_VALUE); b; + b = FindNextFile(hFile, &fileData)) + { + fileName = fileData.cFileName; + if ( fileData.dwFileAttributes & FILE_ATTRIBUTE_DIRECTORY ) + { + // Need to check for . and .. to avoid infinite loop + if ( fileName != "." && fileName != ".." && recursive ) + { + numberOfFiles += Explore(dirName+ "\\"+fileName,recursive,Filenames); + } + } + else + { + Filenames.push_back(dirName+fileName); + numberOfFiles++; + } + } + DWORD dwError = GetLastError(); + if (hFile != INVALID_HANDLE_VALUE) + FindClose(hFile); + if (dwError != ERROR_NO_MORE_FILES) + { + LPVOID lpMsgBuf; + FormatMessage(FORMAT_MESSAGE_ALLOCATE_BUFFER| + FORMAT_MESSAGE_FROM_SYSTEM| + FORMAT_MESSAGE_IGNORE_INSERTS, + NULL,GetLastError(), + MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT), // Default language + (LPTSTR) &lpMsgBuf,0,NULL); + + // ErrorMacro("FindNextFile error. Error is " << (char *)lpMsgBuf + // <<" for the directory : "<d_name; +//std::cout <<"in Explor filename[" << fileName << "]" << std::endl; + if( stat(fileName.c_str(), &buf) != 0 ) + { + //ErrorMacro( strerror(errno) ); + } + if ( S_ISREG(buf.st_mode) ) //is it a regular file? + { + Filenames.push_back( fileName ); + numberOfFiles++; + } + else if ( S_ISDIR(buf.st_mode) ) //directory? + { + if ( d->d_name[0] != '.' && recursive ) //we also skip hidden files + { + numberOfFiles += Explore( fileName, recursive, Filenames); + } + } + else + { + //ErrorMacro( "Unexpected error" ); + return -1; + } + } + if( closedir(dir) != 0 ) + { + // ErrorMacro( strerror(errno) ); + } +#endif + return numberOfFiles; + +} //======================================================================== // Usefull functions for html generation @@ -364,10 +536,21 @@ namespace bbtk replace( str, "<", "<" ); replace( str, ">", ">" ); } + + + //======================================================================== + // Usefull functions OPTIONS string //======================================================================== + + static bool loosematch(std::string stdLine,std::string stdOptions); + + + + }; + } // namespace bbtk #endif //#ifndef __bbtkUtilities_h_INCLUDED__