X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=ETL%2Ftrunk%2FETL%2F_stringf.h;h=2faa2d3bc315609b6d7e55500fb27e8edb7da532;hb=36d01e1527fda602a9aed07d209eb34e6770bca8;hp=b701444111a40a09ce752f1f2294423a944c7c69;hpb=ac34a4aa8bef4e87783d9ae2254a224c2db27ce8;p=synfig.git diff --git a/ETL/trunk/ETL/_stringf.h b/ETL/trunk/ETL/_stringf.h index b701444..2faa2d3 100644 --- a/ETL/trunk/ETL/_stringf.h +++ b/ETL/trunk/ETL/_stringf.h @@ -1,7 +1,7 @@ /* ========================================================================= ** Extended Template and Library ** stringf Prodecure Implementation -** $Id: _stringf.h,v 1.1.1.1 2005/01/04 01:31:48 darco Exp $ +** $Id$ ** ** Copyright (c) 2002 Robert B. Quattlebaum Jr. ** @@ -53,11 +53,7 @@ _ETL_BEGIN_CDECLS #else # ifdef HAVE_VSNPRINTF // This is the secondary method -# if defined(__CYGWIN__) || defined(_WIN32) -extern int vsnprintf(char *,unsigned int,const char*,va_list)ETL_NO_THROW; -# else -extern int vsnprintf(char *,int,const char*,va_list)ETL_NO_THROW; -# endif + extern int vsnprintf(char *,size_t,const char*,va_list)ETL_NO_THROW; # endif #endif @@ -199,7 +195,7 @@ is_absolute_path(const std::string &path) #ifdef WIN32 if(path.size()>=3 && path[1]==':' && (path[2]=='\\' || path[2]=='/')) return true; -#endif +#endif if(!path.empty() && path[0]==ETL_DIRECTORY_SEPERATOR) return true; return false; @@ -239,7 +235,7 @@ get_root_from_path(std::string path) { std::string ret; std::string::const_iterator iter; - + for(iter=path.begin();iter!=path.end();++iter) { if(*iter==ETL_DIRECTORY_SEPERATOR) @@ -272,7 +268,7 @@ cleanup_path(std::string path) std::string ret; while(basename(path)==".")path=dirname(path); - + while(!path.empty()) { std::string dir(get_root_from_path(path)); @@ -286,7 +282,7 @@ cleanup_path(std::string path) } path=remove_root_from_path(path); } - + // Remove any trailing directory seperators if(ret.size() && ret[ret.size()-1]==ETL_DIRECTORY_SEPERATOR) { @@ -299,7 +295,7 @@ inline std::string absolute_path(std::string path) { std::string ret(current_working_directory()); - + if(path.empty()) return cleanup_path(ret); if(is_absolute_path(path)) @@ -310,14 +306,14 @@ absolute_path(std::string path) inline std::string relative_path(std::string curr_path,std::string dest_path) -{ +{ // If dest_path is already a relative path, // then there is no need to do anything. if(!is_absolute_path(dest_path)) dest_path=absolute_path(dest_path); else dest_path=cleanup_path(dest_path); - + if(!is_absolute_path(curr_path)) curr_path=absolute_path(curr_path); else @@ -336,7 +332,7 @@ relative_path(std::string curr_path,std::string dest_path) { return basename(dest_path); } - + while(!dest_path.empty() && !curr_path.empty() && get_root_from_path(dest_path)==get_root_from_path(curr_path)) { dest_path=remove_root_from_path(dest_path); @@ -348,7 +344,7 @@ relative_path(std::string curr_path,std::string dest_path) dest_path=std::string("..")+ETL_DIRECTORY_SEPERATOR+dest_path; curr_path=remove_root_from_path(curr_path); } - + return dest_path; }