mirror of
https://github.com/reactos/reactos.git
synced 2024-12-29 02:25:17 +00:00
Fix rbuild compilation, by adding Path::RelativeFromDirectory method
svn path=/trunk/; revision=17580
This commit is contained in:
parent
2142e2dfaf
commit
b5fbf00480
2 changed files with 13 additions and 6 deletions
|
@ -172,21 +172,27 @@ Path::RelativeFromWorkingDirectory ()
|
||||||
string
|
string
|
||||||
Path::RelativeFromWorkingDirectory ( const string& path )
|
Path::RelativeFromWorkingDirectory ( const string& path )
|
||||||
{
|
{
|
||||||
vector<string> vwork, vpath, vout;
|
return Path::RelativeFromDirectory ( path, working_directory );
|
||||||
Path::Split ( vwork, working_directory, true );
|
}
|
||||||
|
|
||||||
|
string
|
||||||
|
Path::RelativeFromDirectory ( const string& path, const string& base_directory )
|
||||||
|
{
|
||||||
|
vector<string> vbase, vpath, vout;
|
||||||
|
Path::Split ( vbase, base_directory, true );
|
||||||
Path::Split ( vpath, path, true );
|
Path::Split ( vpath, path, true );
|
||||||
#ifdef WIN32
|
#ifdef WIN32
|
||||||
// this squirreliness is b/c win32 has drive letters and *nix doesn't...
|
// this squirreliness is b/c win32 has drive letters and *nix doesn't...
|
||||||
// not possible to do relative across different drive letters
|
// not possible to do relative across different drive letters
|
||||||
if ( vwork[0] != vpath[0] )
|
if ( vbase[0] != vpath[0] )
|
||||||
return path;
|
return path;
|
||||||
#endif
|
#endif
|
||||||
size_t i = 0;
|
size_t i = 0;
|
||||||
while ( i < vwork.size() && i < vpath.size() && vwork[i] == vpath[i] )
|
while ( i < vbase.size() && i < vpath.size() && vbase[i] == vpath[i] )
|
||||||
++i;
|
++i;
|
||||||
if ( i < vwork.size() )
|
if ( i < vbase.size() )
|
||||||
{
|
{
|
||||||
// path goes above our working directory, we will need some ..'s
|
// path goes above our base directory, we will need some ..'s
|
||||||
for ( size_t j = 0; j < i; j++ )
|
for ( size_t j = 0; j < i; j++ )
|
||||||
vout.push_back ( ".." );
|
vout.push_back ( ".." );
|
||||||
}
|
}
|
||||||
|
|
|
@ -44,6 +44,7 @@ public:
|
||||||
|
|
||||||
std::string RelativeFromWorkingDirectory ();
|
std::string RelativeFromWorkingDirectory ();
|
||||||
static std::string RelativeFromWorkingDirectory ( const std::string& path );
|
static std::string RelativeFromWorkingDirectory ( const std::string& path );
|
||||||
|
static std::string RelativeFromDirectory ( const std::string& path, const std::string& base_directory);
|
||||||
|
|
||||||
static void Split ( std::vector<std::string>& out,
|
static void Split ( std::vector<std::string>& out,
|
||||||
const std::string& path,
|
const std::string& path,
|
||||||
|
|
Loading…
Reference in a new issue