📄 path_test.cpp
字号:
// path_test program -------------------------------------------------------//
// Copyright Beman Dawes 2002.
// Use, modification, and distribution is subject to the Boost Software
// License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
// http://www.boost.org/LICENSE_1_0.txt)
// See library home page at http://www.boost.org/libs/filesystem
#include <boost/filesystem/operations.hpp>
#include <boost/filesystem/exception.hpp>
#include <boost/utility.hpp>
#include <iostream>
#include <string>
#include <cstring>
#include <cassert>
namespace fs = boost::filesystem;
using boost::filesystem::path;
using boost::next;
using boost::prior;
#include <boost/test/minimal.hpp>
#define PATH_CHECK( a, b ) check( a, b, __LINE__ )
namespace {
int errors;
void check( const fs::path & source,
const std::string & expected, int line )
{
if ( source.string()== expected ) return;
++errors;
std::cout << '(' << line << ") source.string(): \"" << source.string()
<< "\" != expected: \"" << expected
<< "\"" << std::endl;
}
void check_throw( const std::string & arg )
{
try
{
fs::path arg_path( arg );
++errors;
std::cout << "failed to throw with argument \"" << arg
<< "\"" << std::endl;
}
catch ( const fs::filesystem_error & /*ex*/ )
{
// std::cout << ex.what() << "\n";
}
}
} // unnamed namespace
int test_main( int, char*[] )
{
std::string platform( BOOST_PLATFORM );
// The choice of platform is make at runtime rather than compile-time
// so that compile errors for all platforms will be detected even though
// only the current platform is runtime tested.
# if defined( BOOST_POSIX )
platform = "POSIX";
# elif defined( BOOST_WINDOWS )
platform = "Windows";
# else
platform = ( platform == "Win32" || platform == "Win64" || platform == "Cygwin" )
? "Windows"
: "POSIX";
# endif
std::cout << "Platform is " << platform << '\n';
BOOST_CHECK( path::default_name_check_writable() );
BOOST_CHECK( path::default_name_check() == fs::portable_name );
BOOST_CHECK( !path::default_name_check_writable() );
bool default_name_check_threw = false;
try { path::default_name_check( fs::no_check ); }
catch ( const fs::filesystem_error & ) { default_name_check_threw = true; }
BOOST_CHECK( default_name_check_threw );
BOOST_CHECK( path::default_name_check() == fs::portable_name );
path p1( "fe/fi/fo/fum" );
path p2( p1 );
path p3;
BOOST_CHECK( p1.string() != p3.string() );
p3 = p2;
// p1.branch_path() = p2; // should fail
// *p1.begin() = ""; // should fail
// These verify various overloads don't cause compiler errors
fs::exists( "foo" );
fs::exists( std::string( "foo" ) );
fs::exists( p1 );
fs::exists( "foo" / p1 );
fs::exists( std::string( "foo" ) / p1 );
BOOST_CHECK( p1.string() == p2.string() );
BOOST_CHECK( p1.string() == p3.string() );
BOOST_CHECK( path( "foo" ).leaf() == "foo" );
BOOST_CHECK( path( "foo" ).branch_path().string() == "" );
BOOST_CHECK( p1.leaf() == "fum" );
BOOST_CHECK( p1.branch_path().string() == "fe/fi/fo" );
BOOST_CHECK( path( "" ).empty() == true );
BOOST_CHECK( path( "foo" ).empty() == false );
PATH_CHECK( "", "" );
PATH_CHECK( "foo", "foo" );
PATH_CHECK( "f", "f" );
PATH_CHECK( "foo/", "foo" );
PATH_CHECK( path("foo/").normalize(), "foo" );
PATH_CHECK( "f/", "f" );
PATH_CHECK( path("f/").normalize(), "f" );
PATH_CHECK( path("") / "foo", "foo" );
PATH_CHECK( path("foo") / "", "foo" );
PATH_CHECK( path( "/" ), "/" );
PATH_CHECK( path( "/" ) / "", "/" );
PATH_CHECK( path( "/f" ), "/f" );
PATH_CHECK( path( "/foo" ).normalize(), "/foo" );
PATH_CHECK( "/foo", "/foo" );
PATH_CHECK( path("") / "/foo", "/foo" );
PATH_CHECK( path("/foo") / "", "/foo" );
PATH_CHECK( "foo/", "foo" );
PATH_CHECK( path("") / "foo/", "foo" );
PATH_CHECK( path("foo") / "/", "foo" );
PATH_CHECK( "foo/bar", "foo/bar" );
PATH_CHECK( path( "foo/bar" ).normalize(), "foo/bar" );
PATH_CHECK( path("foo") / path("bar"), "foo/bar" ); // path arg
PATH_CHECK( path("foo") / "bar", "foo/bar" ); // const char * arg
PATH_CHECK( path("foo") / path("woo/bar").leaf(), "foo/bar" ); // const std::string & arg
PATH_CHECK( "foo" / path("bar"), "foo/bar" );
PATH_CHECK( "a/b", "a/b" ); // probe for length effects
PATH_CHECK( path("a") / "b", "a/b" );
PATH_CHECK( "..", ".." );
PATH_CHECK( path("..").normalize(), ".." );
PATH_CHECK( path("..") / "", ".." );
PATH_CHECK( path("") / "..", ".." );
PATH_CHECK( "../..", "../.." );
PATH_CHECK( path("../..").normalize(), "../.." );
PATH_CHECK( path("..") / ".." , "../.." );
PATH_CHECK( "/..", "/" );
PATH_CHECK( path("/..").normalize(), "/" );
PATH_CHECK( path("/") / ".." , "/" );
PATH_CHECK( "/../..", "/" );
PATH_CHECK( path("/../..").normalize(), "/" );
PATH_CHECK( path("/..") / ".." , "/" );
PATH_CHECK( "../foo", "../foo" );
PATH_CHECK( path("../foo").normalize(), "../foo" );
PATH_CHECK( path("..") / "foo" , "../foo" );
PATH_CHECK( "foo/..", "foo/.." );
PATH_CHECK( path("foo") / ".." , "foo/.." );
PATH_CHECK( path("foo/..").normalize(), "." );
PATH_CHECK( (path("foo") / "..").normalize() , "." );
PATH_CHECK( path( "foo/..bar", fs::no_check ), "foo/..bar" );
PATH_CHECK( path("foo/..bar", fs::no_check ).normalize(), "foo/..bar" );
PATH_CHECK( "../f", "../f" );
PATH_CHECK( path("../f").normalize(), "../f" );
PATH_CHECK( path("..") / "f" , "../f" );
PATH_CHECK( "/../f", "/f" );
PATH_CHECK( path("/../f").normalize(), "/f" );
PATH_CHECK( path("/..") / "f" , "/f" );
PATH_CHECK( "f/..", "f/.." );
PATH_CHECK( path("f") / ".." , "f/.." );
PATH_CHECK( path("f/..").normalize(), "." );
PATH_CHECK( (path("f") / "..").normalize() , "." );
PATH_CHECK( "foo/../..", "foo/../.." );
PATH_CHECK( path("foo/../..").normalize(), ".." );
PATH_CHECK( path("foo") / ".." / ".." , "foo/../.." );
PATH_CHECK( "foo/../../..", "foo/../../.." );
PATH_CHECK( path("foo/../../..").normalize(), "../.." );
PATH_CHECK( path("foo") / ".." / ".." / ".." , "foo/../../.." );
PATH_CHECK( "foo/../bar", "foo/../bar" );
PATH_CHECK( path("foo/../bar").normalize(), "bar" );
PATH_CHECK( path("foo") / ".." / "bar" , "foo/../bar" );
PATH_CHECK( "foo/bar/..", "foo/bar/.." );
PATH_CHECK( path("foo/bar/..").normalize(), "foo" );
PATH_CHECK( path("foo") / "bar" / ".." , "foo/bar/.." );
PATH_CHECK( "foo/bar/../..", "foo/bar/../.." );
PATH_CHECK( path("foo/bar/../..").normalize(), "." );
PATH_CHECK( path("foo") / "bar" / ".." / "..", "foo/bar/../.." );
PATH_CHECK( "foo/bar/../blah", "foo/bar/../blah" );
PATH_CHECK( path("foo/bar/../blah").normalize(), "foo/blah" );
PATH_CHECK( path("foo") / "bar" / ".." / "blah", "foo/bar/../blah" );
PATH_CHECK( "f/../b", "f/../b" );
PATH_CHECK( path("f/../b").normalize(), "b" );
PATH_CHECK( path("f") / ".." / "b" , "f/../b" );
PATH_CHECK( "f/b/..", "f/b/.." );
PATH_CHECK( path("f/b/..").normalize(), "f" );
PATH_CHECK( path("f") / "b" / ".." , "f/b/.." );
PATH_CHECK( "f/b/../a", "f/b/../a" );
PATH_CHECK( path("f/b/../a").normalize(), "f/a" );
PATH_CHECK( path("f") / "b" / ".." / "a", "f/b/../a" );
PATH_CHECK( "foo/bar/blah/../..", "foo/bar/blah/../.." );
PATH_CHECK( path("foo/bar/blah/../..").normalize(), "foo" );
PATH_CHECK( path("foo") / "bar" / "blah" / ".." / "..", "foo/bar/blah/../.." );
PATH_CHECK( "foo/bar/blah/../../bletch", "foo/bar/blah/../../bletch" );
PATH_CHECK( path("foo/bar/blah/../../bletch").normalize(), "foo/bletch" );
PATH_CHECK( path("foo") / "bar" / "blah" / ".." / ".." / "bletch", "foo/bar/blah/../../bletch" );
PATH_CHECK( path("...", fs::portable_posix_name ), "..." );
PATH_CHECK( path("....", fs::portable_posix_name ), "...." );
PATH_CHECK( path("foo/...", fs::portable_posix_name ), "foo/..." );
PATH_CHECK( path("foo/...", fs::portable_posix_name ).normalize(), "foo/..." );
PATH_CHECK( path("abc.", fs::portable_posix_name ), "abc." );
PATH_CHECK( path("abc..", fs::portable_posix_name ), "abc.." );
PATH_CHECK( path("foo/abc.", fs::portable_posix_name ), "foo/abc." );
PATH_CHECK( path("foo/abc..", fs::portable_posix_name ), "foo/abc.." );
PATH_CHECK( path(".abc", fs::no_check), ".abc" );
PATH_CHECK( "a.c", "a.c" );
PATH_CHECK( path("..abc", fs::no_check), "..abc" );
PATH_CHECK( "a..c", "a..c" );
PATH_CHECK( path("foo/.abc", fs::no_check), "foo/.abc" );
PATH_CHECK( "foo/a.c", "foo/a.c" );
PATH_CHECK( path("foo/..abc", fs::no_check), "foo/..abc" );
PATH_CHECK( path("foo/..abc", fs::no_check).normalize(), "foo/..abc" );
PATH_CHECK( "foo/a..c", "foo/a..c" );
PATH_CHECK( ".", "." );
PATH_CHECK( path("") / ".", "." );
PATH_CHECK( "./foo", "foo" );
PATH_CHECK( path(".") / "foo", "foo" );
PATH_CHECK( "./..", ".." );
PATH_CHECK( path(".") / "..", ".." );
PATH_CHECK( "./../foo", "../foo" );
PATH_CHECK( "foo/.", "foo" );
PATH_CHECK( path("foo") / ".", "foo" );
PATH_CHECK( "../.", ".." );
PATH_CHECK( path("..") / ".", ".." );
PATH_CHECK( "./.", "." );
PATH_CHECK( path(".") / ".", "." );
PATH_CHECK( "././.", "." );
PATH_CHECK( path(".") / "." / ".", "." );
PATH_CHECK( "./foo/.", "foo" );
PATH_CHECK( path(".") / "foo" / ".", "foo" );
PATH_CHECK( "foo/./bar", "foo/bar" );
PATH_CHECK( path("foo") / "." / "bar", "foo/bar" );
PATH_CHECK( "foo/./.", "foo" );
PATH_CHECK( path("foo") / "." / ".", "foo" );
PATH_CHECK( "foo/./..", "foo/.." );
PATH_CHECK( path("foo") / "." / "..", "foo/.." );
PATH_CHECK( "foo/./../bar", "foo/../bar" );
PATH_CHECK( "foo/../.", "foo/.." );
PATH_CHECK( path(".") / "." / "..", ".." );
PATH_CHECK( "././..", ".." );
PATH_CHECK( path(".") / "." / "..", ".." );
PATH_CHECK( "./../.", ".." );
PATH_CHECK( path(".") / ".." / ".", ".." );
PATH_CHECK( ".././.", ".." );
PATH_CHECK( path("..") / "." / ".", ".." );
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -