mirror of
				https://github.com/pocoproject/poco.git
				synced 2025-10-25 10:09:36 +02:00 
			
		
		
		
	trunk/branch integration: Path::popFrontDirectory()
This commit is contained in:
		| @@ -50,7 +50,11 @@ | |||||||
| #elif defined(POCO_OS_FAMILY_UNIX) | #elif defined(POCO_OS_FAMILY_UNIX) | ||||||
| #include "Path_UNIX.cpp" | #include "Path_UNIX.cpp" | ||||||
| #elif defined(POCO_OS_FAMILY_WINDOWS) && defined(POCO_WIN32_UTF8) | #elif defined(POCO_OS_FAMILY_WINDOWS) && defined(POCO_WIN32_UTF8) | ||||||
|  | #if defined(_WIN32_WCE) | ||||||
|  | #include "Path_WINCE.cpp" | ||||||
|  | #else | ||||||
| #include "Path_WIN32U.cpp" | #include "Path_WIN32U.cpp" | ||||||
|  | #endif | ||||||
| #elif defined(POCO_OS_FAMILY_WINDOWS) | #elif defined(POCO_OS_FAMILY_WINDOWS) | ||||||
| #include "Path_WIN32.cpp" | #include "Path_WIN32.cpp" | ||||||
| #endif | #endif | ||||||
| @@ -521,6 +525,15 @@ void Path::popDirectory() | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | void Path::popFrontDirectory() | ||||||
|  | { | ||||||
|  |         poco_assert (!_dirs.empty()); | ||||||
|  |          | ||||||
|  |         StringVec::iterator it = _dirs.begin(); | ||||||
|  |         _dirs.erase(it); | ||||||
|  | } | ||||||
|  |  | ||||||
|  |          | ||||||
| void Path::setFileName(const std::string& name) | void Path::setFileName(const std::string& name) | ||||||
| { | { | ||||||
|         _name = name; |         _name = name; | ||||||
| @@ -678,12 +691,14 @@ void Path::parseUnix(const std::string& path) | |||||||
|                                 { |                                 { | ||||||
|                                         if (!name.empty() && *(name.rbegin()) == ':') |                                         if (!name.empty() && *(name.rbegin()) == ':') | ||||||
|                                         { |                                         { | ||||||
| 						_device.assign(name, 0, name.length() - 1); |  | ||||||
|                                                 _absolute = true; |                                                 _absolute = true; | ||||||
|  |                                                 _device.assign(name, 0, name.length() - 1); | ||||||
|                                         } |                                         } | ||||||
|                                         else |                                         else | ||||||
|  |                                         { | ||||||
|                                                 pushDirectory(name); |                                                 pushDirectory(name); | ||||||
|                                         } |                                         } | ||||||
|  |                                 } | ||||||
|                                 else pushDirectory(name); |                                 else pushDirectory(name); | ||||||
|                         } |                         } | ||||||
|                         else _name = name; |                         else _name = name; | ||||||
| @@ -714,11 +729,11 @@ void Path::parseWindows(const std::string& path) | |||||||
|                         char d = *it++; |                         char d = *it++; | ||||||
|                         if (it != end && *it == ':') // drive letter |                         if (it != end && *it == ':') // drive letter | ||||||
|                         { |                         { | ||||||
| 				if (_absolute || !(d >= 'a' && d <= 'z' || d >= 'A' && d <= 'Z')) throw PathSyntaxException(path); |                                 if (_absolute || !((d >= 'a' && d <= 'z') || (d >= 'A' && d <= 'Z'))) throw PathSyntaxException(path); | ||||||
|                                 _absolute = true; |                                 _absolute = true; | ||||||
|                                 _device += d; |                                 _device += d; | ||||||
|                                 ++it; |                                 ++it; | ||||||
| 				if (it == end || *it != '\\' && *it != '/') throw PathSyntaxException(path); |                                 if (it == end || (*it != '\\' && *it != '/')) throw PathSyntaxException(path); | ||||||
|                                 ++it; |                                 ++it; | ||||||
|                         } |                         } | ||||||
|                         else --it; |                         else --it; | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| // | // | ||||||
| // Path_UNIX.cpp | // Path_UNIX.cpp | ||||||
| // | // | ||||||
| // $Id: //poco/svn/Foundation/src/Path_UNIX.cpp#2 $ | // $Id: //poco/1.4/Foundation/src/Path_UNIX.cpp#3 $ | ||||||
| // | // | ||||||
| // Library: Foundation | // Library: Foundation | ||||||
| // Package: Filesystem | // Package: Filesystem | ||||||
| @@ -37,11 +37,13 @@ | |||||||
| #include "Poco/Path_UNIX.h" | #include "Poco/Path_UNIX.h" | ||||||
| #include "Poco/Exception.h" | #include "Poco/Exception.h" | ||||||
| #include "Poco/Environment_UNIX.h" | #include "Poco/Environment_UNIX.h" | ||||||
|  | #include "Poco/Ascii.h" | ||||||
| #include <unistd.h> | #include <unistd.h> | ||||||
| #include <stdlib.h> | #include <stdlib.h> | ||||||
| #include <sys/types.h> | #include <sys/types.h> | ||||||
|  | #if !defined(POCO_VXWORKS) | ||||||
| #include <pwd.h> | #include <pwd.h> | ||||||
| #include <cctype> | #endif | ||||||
| #include <climits> | #include <climits> | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -69,6 +71,12 @@ std::string PathImpl::currentImpl() | |||||||
|  |  | ||||||
| std::string PathImpl::homeImpl() | std::string PathImpl::homeImpl() | ||||||
| { | { | ||||||
|  | #if defined(POCO_VXWORKS) | ||||||
|  |         if (EnvironmentImpl::hasImpl("HOME")) | ||||||
|  |                 return EnvironmentImpl::getImpl("HOME"); | ||||||
|  |         else | ||||||
|  |                 return "/"; | ||||||
|  | #else | ||||||
|         std::string path; |         std::string path; | ||||||
|         struct passwd* pwd = getpwuid(getuid()); |         struct passwd* pwd = getpwuid(getuid()); | ||||||
|         if (pwd) |         if (pwd) | ||||||
| @@ -84,6 +92,7 @@ std::string PathImpl::homeImpl() | |||||||
|         std::string::size_type n = path.size(); |         std::string::size_type n = path.size(); | ||||||
|         if (n > 0 && path[n - 1] != '/') path.append("/"); |         if (n > 0 && path[n - 1] != '/') path.append("/"); | ||||||
|         return path; |         return path; | ||||||
|  | #endif | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -107,7 +116,11 @@ std::string PathImpl::tempImpl() | |||||||
|  |  | ||||||
| std::string PathImpl::nullImpl() | std::string PathImpl::nullImpl() | ||||||
| { | { | ||||||
|  | #if defined(POCO_VXWORKS) | ||||||
|  |         return "/null"; | ||||||
|  | #else | ||||||
|         return "/dev/null"; |         return "/dev/null"; | ||||||
|  | #endif | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -139,7 +152,7 @@ std::string PathImpl::expandImpl(const std::string& path) | |||||||
|                         } |                         } | ||||||
|                         else |                         else | ||||||
|                         { |                         { | ||||||
| 				while (it != end && (std::isalnum(*it) || *it == '_')) var += *it++; |                                 while (it != end && (Ascii::isAlphaNumeric(*it) || *it == '_')) var += *it++; | ||||||
|                         } |                         } | ||||||
|                         char* val = getenv(var.c_str()); |                         char* val = getenv(var.c_str()); | ||||||
|                         if (val) result += val; |                         if (val) result += val; | ||||||
|   | |||||||
| @@ -44,7 +44,7 @@ namespace Poco { | |||||||
|  |  | ||||||
| std::string PathImpl::currentImpl() | std::string PathImpl::currentImpl() | ||||||
| { | { | ||||||
| 	char buffer[_MAX_PATH]; |         char buffer[MAX_PATH]; | ||||||
|         DWORD n = GetCurrentDirectoryA(sizeof(buffer), buffer); |         DWORD n = GetCurrentDirectoryA(sizeof(buffer), buffer); | ||||||
|         if (n > 0 && n < sizeof(buffer)) |         if (n > 0 && n < sizeof(buffer)) | ||||||
|         { |         { | ||||||
| @@ -70,16 +70,18 @@ std::string PathImpl::homeImpl() | |||||||
|  |  | ||||||
| std::string PathImpl::tempImpl() | std::string PathImpl::tempImpl() | ||||||
| { | { | ||||||
| 	char buffer[_MAX_PATH]; |         char buffer[MAX_PATH]; | ||||||
|         DWORD n = GetTempPathA(sizeof(buffer), buffer); |         DWORD n = GetTempPathA(sizeof(buffer), buffer); | ||||||
|         if (n > 0 && n < sizeof(buffer)) |         if (n > 0 && n < sizeof(buffer)) | ||||||
|         { |         { | ||||||
|  |                 n = GetLongPathNameA(buffer.begin(), buffer.begin(), static_cast<DWORD>(buffer.size())); | ||||||
|  |                 if (n <= 0) throw SystemException("Cannot get temporary directory long path name"); | ||||||
|                 std::string result(buffer, n); |                 std::string result(buffer, n); | ||||||
|                 if (result[n - 1] != '\\') |                 if (result[n - 1] != '\\') | ||||||
|                         result.append("\\"); |                         result.append("\\"); | ||||||
|                 return result; |                 return result; | ||||||
|         } |         } | ||||||
| 	else throw SystemException("Cannot get current directory"); |         else throw SystemException("Cannot get temporary directory"); | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -91,7 +93,7 @@ std::string PathImpl::nullImpl() | |||||||
|  |  | ||||||
| std::string PathImpl::expandImpl(const std::string& path) | std::string PathImpl::expandImpl(const std::string& path) | ||||||
| { | { | ||||||
| 	char buffer[_MAX_PATH]; |         char buffer[MAX_PATH]; | ||||||
|         DWORD n = ExpandEnvironmentStringsA(path.c_str(), buffer, sizeof(buffer)); |         DWORD n = ExpandEnvironmentStringsA(path.c_str(), buffer, sizeof(buffer)); | ||||||
|         if (n > 0 && n < sizeof(buffer)) |         if (n > 0 && n < sizeof(buffer)) | ||||||
|                 return std::string(buffer, n - 1); |                 return std::string(buffer, n - 1); | ||||||
|   | |||||||
| @@ -56,7 +56,7 @@ std::string PathImpl::currentImpl() | |||||||
|                 if (n > 0 && n <= len) |                 if (n > 0 && n <= len) | ||||||
|                 { |                 { | ||||||
|                         UnicodeConverter::toUTF8(buffer.begin(), result); |                         UnicodeConverter::toUTF8(buffer.begin(), result); | ||||||
| 			if (result[n - 1] != '\\') |                         if (result[result.size() - 1] != '\\') | ||||||
|                                 result.append("\\"); |                                 result.append("\\"); | ||||||
|                         return result; |                         return result; | ||||||
|                 } |                 } | ||||||
| @@ -82,13 +82,15 @@ std::string PathImpl::tempImpl() | |||||||
|         DWORD n = GetTempPathW(static_cast<DWORD>(buffer.size()), buffer.begin()); |         DWORD n = GetTempPathW(static_cast<DWORD>(buffer.size()), buffer.begin()); | ||||||
|         if (n > 0) |         if (n > 0) | ||||||
|         { |         { | ||||||
|  |                 n = GetLongPathNameW(buffer.begin(), buffer.begin(), static_cast<DWORD>(buffer.size())); | ||||||
|  |                 if (n <= 0) throw SystemException("Cannot get temporary directory long path name"); | ||||||
|                 std::string result; |                 std::string result; | ||||||
|                 UnicodeConverter::toUTF8(buffer.begin(), result); |                 UnicodeConverter::toUTF8(buffer.begin(), result); | ||||||
| 		if (result[n - 1] != '\\') |                 if (result[result.size() - 1] != '\\') | ||||||
|                         result.append("\\"); |                         result.append("\\"); | ||||||
|                 return result; |                 return result; | ||||||
|         } |         } | ||||||
| 	throw SystemException("Cannot get current directory"); |         throw SystemException("Cannot get temporary directory path"); | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Marian Krivos
					Marian Krivos