本文整理汇总了C++中path类的典型用法代码示例。如果您正苦于以下问题:C++ path类的具体用法?C++ path怎么用?C++ path使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。
在下文中一共展示了path类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: remove
bool remove(const path & p) {
int ret = ::remove(p.string().c_str());
return !ret || ret == ENOENT || ret == ENOTDIR;
}
示例2:
bool operator<(const path& lhs, const path& rhs) noexcept
{
return lhs.compare(rhs) < 0;
}
示例3: ExtractCurrentFile
long ExtractCurrentFile ( path parent, unzFile uf )
{
long error = UNZ_OK;
char filename_inzip[PATH_MAX];
unz_file_info64 file_info;
error = unzGetCurrentFileInfo64 ( uf, &file_info, filename_inzip, sizeof ( filename_inzip ), NULL, 0, NULL, 0 );
path file = filename_inzip;
file.make_preferred();
parent.make_preferred();
if ( error == UNZ_OK ) {
std::string macos = "__MACOSX";
if ( file.string().compare ( 0, macos.length(), macos ) == 0 ) {
return kNoError;
}
path to_write = parent / file;
create_directories ( to_write.parent_path() );
if ( file.filename().string() == "." ) {
create_directory ( to_write );
} else {
error = unzOpenCurrentFilePassword ( uf, NULL );
if ( error == UNZ_OK ) {
char * buffer = new char [ WRITEBUFFERSIZE ];
boost::filesystem::ofstream output_file ( to_write, std::ios_base::binary );
output_file.exceptions ( boost::filesystem::ofstream::badbit | boost::filesystem::ofstream::failbit );
long bytes_read = 0;
do {
bytes_read = unzReadCurrentFile ( uf, (void *)buffer, WRITEBUFFERSIZE );
if ( bytes_read > 0 ) {
output_file.write ( buffer, bytes_read );
} else if ( bytes_read < 0 ) {
error = bytes_read;
}
} while ( bytes_read > 0 );
output_file.close();
ChangeFileDate ( to_write, file_info.tmu_date );
delete [] buffer;
}
// don't lose the error
int close_error = unzCloseCurrentFile ( uf );
if ( error == UNZ_OK ) {
error = close_error;
}
}
}
return error;
} // ExtractCurrentFile
示例4: pushFlowThrowPath
void pushFlowThrowPath(const path& p, const F& pFlow) {
for (typename path::const_iterator v = p.begin(); v != p.end() - 1; ++v) {
flows.at(*v).at(*(v + 1)) += pFlow;
flows.at(*(v + 1)).at(*v) -= pFlow;
}
}
示例5: swap
void swap(path& lhs, path& rhs) noexcept
{
lhs.swap(rhs);
}
示例6: getFileSize
boost::intmax_t getFileSize(path &myPath){
if ( !exists(myPath) )
throw std::string("file "+myPath.string()+" doesn't exist");
return file_size(myPath);
}
示例7: getExectuablePath
/***************************
Find liblightsparkBACKENDplugin libraries
****************************/
void PluginManager::findPlugins()
{
//Search for all files under the plugins directory
//Verify if they are audio plugins
//If true, add to list of audio plugins
#ifdef _WIN32
const path plugins_folder = getExectuablePath();
#else
const path plugins_folder = string(PRIVATELIBDIR) + "/plugins/";
#endif
const string pattern ( "liblightspark+[A-Za-z]+plugin.*" );
//Stuff used by/for pcre
const char* patternError;
int patternErrorOffset;
pcre* file_pattern = pcre_compile ( pattern.c_str(), 0, &patternError, &patternErrorOffset, NULL );
if(patternError)
throw RunTimeException("PluginManager::findPlugins(): can't compile file_pattern");
//We don't expect any captured substrings, so 3 ints should be enough
#if defined DEBUG
LOG(LOG_INFO, "Looking for plugins under " << plugins_folder << " for pattern " << pattern);
#endif
if ( !is_directory ( plugins_folder ) )
{
LOG ( LOG_ERROR, _ ( ( ( string ) ( "The plugins folder doesn't exists under " + plugins_folder.string() ) ).c_str() ) );
}
else
{
for ( directory_iterator itr ( plugins_folder ), end_itr; itr != end_itr; ++itr )
{
if ( is_regular_file ( *itr ) ) //Is it a real file? This will remove symlink
{
#if BOOST_VERSION >= 104600
string leaf_name = itr->path().filename().string();
#else
string leaf_name = itr->path().filename();
#endif
int patternOvector[3];
int rc=pcre_exec(file_pattern, NULL, leaf_name.c_str(), leaf_name.length(), 0, 0, patternOvector, 3);
if ( rc > 0 ) // Does it answer to the desired pattern?
{
#if BOOST_VERSION >= 104600
path fullpath = plugins_folder.string();
#else
path fullpath = plugins_folder.directory_string();
#endif
fullpath /= leaf_name;
//Try to load the file and see if it's an audio plugin
if ( GModule* h_plugin = g_module_open( fullpath.string().c_str(), G_MODULE_BIND_LAZY) )
{
PLUGIN_FACTORY p_factory_function;
PLUGIN_CLEANUP p_cleanup_function;
if ( g_module_symbol(h_plugin, "create", (void**)&p_factory_function)
&& g_module_symbol(h_plugin, "release", (void**)&p_cleanup_function) )
{ //Does it contain the LS IPlugin?
IPlugin *p_plugin = p_factory_function (); //Instanciate the plugin
LOG ( LOG_INFO, _ ( "A plugin was found. Adding it to the list." ) );
addPluginToList ( p_plugin, fullpath.string() ); //Add the plugin info to the audio plugins list
p_cleanup_function ( p_plugin );
g_module_close ( h_plugin );
}
else //If doesn't implement our IPlugin interface entry points, close it
{
g_module_close( h_plugin );
}
}
}
}
}
}
pcre_free(file_pattern);
}
示例8: file_size
size_type filesys::file_size(const path & p)
{
struct stat stats;
if (stat(p.c_str(), &stats) != 0) return 0;
return stats.st_size;
}
示例9: BOOST_THROW_EXCEPTION
/// \brief Attempt to parse the specified options
///
/// \pre All previously added options_blocks must still exist
///
/// \pre The two parameters must be in the standard argc/argv configuration
///
/// Note that the two input parameters are taken const
/// (including the argv being (a pointer to) an array of const pointers *to const*)
/// so they will remain untouched.
///
/// \post The options will be parsed and ready for querying
void executable_options::parse_options(const int &argc, ///< The argc from command line parameters
const char * const argv[] ///< The argv from command line parameters
) {
// Check the options haven't already been processed
if (processed_options) {
BOOST_THROW_EXCEPTION(invalid_argument_exception("Cannot process options once they have already been processed"));
}
// Create two options_description, one complete and another containing all visible options
options_description full_po_desc ( DEFAULT_PROG_OPS_LINE_LENGTH );
options_description visible_po_desc( DEFAULT_PROG_OPS_LINE_LENGTH );
// Frustratingly, Boost 1.41 (as used by orengobuild64) won't accept a const argv, so
// it's necessary to construct a fake argc/argv here
argc_argv_faker fake_argc_argv(argc, argv);
int new_argc = fake_argc_argv.get_argc();
char * * new_argv = fake_argc_argv.get_argv();
// Add each of the options_blocks to po_desc
for (options_block * const options_block_ptr : all_options_blocks) {
const options_description hidden_opts = options_block_ptr->get_hidden_options_description( DEFAULT_PROG_OPS_LINE_LENGTH );
const options_description visible_opts = options_block_ptr->get_visible_options_description( DEFAULT_PROG_OPS_LINE_LENGTH );
full_po_desc.add( hidden_opts );
full_po_desc.add( visible_opts );
visible_po_desc.add( visible_opts );
}
// Attempt the parses and catch any exceptions
//
// The parses are performed in decreasing order of precedence
// (ie options specified via the command line should take precedence over those
// specified via environment variables so it comes first)
//
// \todo If this gets any more complicated then consider putting each of these
// different parses into different objects (presumably of classes deriving from
// a single ABC).
string parsing_approach = "";
try {
// Parse options from the command line
parsing_approach = "from the command line";
const positional_options_description positionals = get_positional_options();
processed_options = true;
store(
command_line_parser(
new_argc,
new_argv
).options(
full_po_desc
).positional(
positionals
).run(),
vm
);
// Parse any environment variables prefixed with "CATH_TOOLS_"
// and just silently ignore any unknown options
parsing_approach = "from global environment variables with prefix " + CATH_TOOLS_ENVIRONMENT_VARIABLE_PREFIX;
//! [Using env_var_option_name_handler]
store(
parse_environment(
full_po_desc,
env_var_option_name_handler(
CATH_TOOLS_ENVIRONMENT_VARIABLE_PREFIX,
true,
full_po_desc
)
),
vm
);
//! [Using env_var_option_name_handler]
// Parse any configuration file called cath_tools.conf
const path located_cath_tools_conf_file = find_file(CATH_TOOLS_CONF_FILE_SEARCH_PATH, CATH_TOOLS_CONF_FILE.string());
if (!located_cath_tools_conf_file.empty()) {
// cerr << "Parsing configuration from file " << CATH_TOOLS_CONF_FILE << endl;
parsing_approach = "from the global configuration file " + located_cath_tools_conf_file.string();
ifstream config_file_stream;
open_ifstream(config_file_stream, CATH_TOOLS_CONF_FILE);
store(parse_config_file(config_file_stream, full_po_desc, true), vm);
config_file_stream.close();
}
// All parsing is complete so call notify, which will trigger any
// post-parsing hooks to get called
notify(vm);
}
catch (std::exception &e) {
error_or_help_string = get_program_name() + ": Error in parsing program options (" + parsing_approach + "): " + e.what();
}
//.........这里部分代码省略.........
示例10: fopen
// ----------------------------------------------------------------------------
Track::Track(path file)
{
m_valid = true;
FILE* pFile;
pFile = fopen(file.c_str(), "rb");
if (!pFile)
{
m_valid = false;
stringw emsg = _("Editor failed to open file:\n \"");
emsg += file;
emsg += "\"";
MsgWndw::get()->showMsg(emsg);
return;
}
// SIGN
u64 sign;
fread(&sign, sizeof(u64), 1, pFile);
if (sign != TOP_SECRET_SIGNATURE_NUMBER)
{
MsgWndw::get()->showMsg(_("File can not be opened: signature failed."));
m_valid = false;
fclose(pFile);
return;
}
// TRACK NAME
u8 size;
wchar_t* c;
fread(&size, sizeof(u8), 1, pFile);
if (!Editor::isValidSize(size))
{
fclose(pFile); m_valid = false;
MsgWndw::get()->showMsg(_("File loading failed!"));
return;
}
c = new wchar_t[size];
fread(c, sizeof(wchar_t), size, pFile);
m_track_name = c;
delete[] c;
// DESIGNER NAME
fread(&size, sizeof(u8), 1, pFile);
if (!Editor::isValidSize(size))
{
fclose(pFile); m_valid = false;
MsgWndw::get()->showMsg(_("File loading failed!"));
return;
}
c = new wchar_t[size];
fread(c, sizeof(wchar_t), size, pFile);
m_designer = c;
delete[] c;
// FILE NAME
c8* cc;
fread(&size, sizeof(u8), 1, pFile);
if (!Editor::isValidSize(size))
{
fclose(pFile); m_valid = false;
MsgWndw::get()->showMsg(_("File loading failed!"));
return;
}
cc = new c8[size];
fread(cc, sizeof(c8), size, pFile);
m_file_name = cc;
delete[] cc;
// MUSIC
fread(&size, sizeof(u8), 1, pFile);
if (!Editor::isValidSize(size))
{
fclose(pFile); m_valid = false;
MsgWndw::get()->showMsg(_("File loading failed!"));
return;
}
cc = new c8[size];
fread(cc, sizeof(c8), size, pFile);
m_music = cc;
delete[] cc;
// TERRAIN
ISceneManager* sm = Editor::getEditor()->getSceneManager();
m_terrain = new Terrain(sm->getRootSceneNode(), sm, 1, pFile);
if (!m_terrain->isValid())
{
fclose(pFile);
MsgWndw::get()->showMsg(_("Loading failed :invalid terrain!"));
m_valid = false;
return;
}
// SKY
Sky* s = Viewport::get()->getSky();
delete s;
//.........这里部分代码省略.........
示例11: froot
/***************************
Find liblightsparkBACKENDplugin libraries
****************************/
void PluginManager::findPlugins()
{
//Search for all files under ${PRIVATELIBDIR}/plugins
//Verify if they are audio plugins
//If true, add to list of audio plugins
string froot ( PRIVATELIBDIR ), fplugins ( "/plugins/" ); //LS should always look in the plugins folder, nowhere else
const path plugins_folder = froot + fplugins;
const string pattern ( "liblightspark+[A-Za-z]+plugin.so" );
//Stuff used by/for pcre
const char* patternError;
int patternErrorOffset;
pcre* file_pattern = pcre_compile ( pattern.c_str(), 0, &patternError, &patternErrorOffset, NULL );
if(patternError)
throw RunTimeException("PluginManager::findPlugins(): can't compile file_pattern");
//We don't expect any captured substrings, so 3 ints should be enough
int patternOvector[3];
#if defined DEBUG
cout << "Looking for plugins under " << plugins_folder << " for pattern " << pattern << endl;
#endif
if ( !is_directory ( plugins_folder ) )
{
LOG ( LOG_ERROR, _ ( ( ( string ) ( "The plugins folder doesn't exists under " + plugins_folder.string() ) ).c_str() ) );
}
else
{
for ( recursive_directory_iterator itr ( plugins_folder ), end_itr; itr != end_itr; ++itr )
{
if ( is_regular_file ( itr.status() ) ) //Is it a real file? This will remove symlink
{
string leaf_name = itr->path().filename();
int rc=pcre_exec(file_pattern, NULL, leaf_name.c_str(), leaf_name.length(), 0, 0, patternOvector, 3);
if ( rc > 0 ) // Does it answer to the desired pattern?
{
string fullpath = plugins_folder.directory_string() + leaf_name;
//Try to load the file and see if it's an audio plugin
if ( HMODULE h_plugin = LoadLib ( fullpath ) )
{
PLUGIN_FACTORY p_factory_function = ( PLUGIN_FACTORY ) ExtractLibContent ( h_plugin, "create" );
PLUGIN_CLEANUP p_cleanup_function = ( PLUGIN_CLEANUP ) ExtractLibContent ( h_plugin, "release" );
if ( p_factory_function != NULL && p_cleanup_function != NULL ) //Does it contain the LS IPlugin?
{
IPlugin *p_plugin = ( *p_factory_function ) (); //Instanciate the plugin
LOG ( LOG_NO_INFO, _ ( "A plugin was found. Adding it to the list." ) );
addPluginToList ( p_plugin, fullpath ); //Add the plugin info to the audio plugins list
( *p_cleanup_function ) ( p_plugin );
CloseLib ( h_plugin );
}
else //If doesn't implement our IPlugin interface entry points, close it
{
CloseLib ( h_plugin );
}
}
}
}
}
}
pcre_free(file_pattern);
}
示例12: encrypt
void encrypt(path &filesPlace, path &keysPlace) {
if (!groupes.size()) {
std::cout << "Files are not grouped" << std::endl;
return;
}
for (auto it : groupes) {
std::ostringstream dataToEncode;
auto group = it.second;
for (auto currentFile : group) {
std::ifstream input(filesPlace.string() + currentFile, std::ios::binary);
if (!input.is_open()) {
std::cout << "Wrong directory: " << filesPlace.string();
exit(0);
}
//Obtaining file data
std::string buffer((
std::istreambuf_iterator<char >(input)),
(std::istreambuf_iterator<char >()));
//Encode to hex if file is an image
if (it.first.second == IMAGE) {
std::string encoded_image;
bn::encode_b16(buffer.begin(), buffer.end(), std::back_inserter(encoded_image));
dataToEncode << currentFile << std::endl << encoded_image.size() << std::endl << encoded_image;
}
else {
dataToEncode << currentFile << std::endl << buffer.size() << std::endl << buffer;
}
input.close();
}
//Size of files to decode
int size = dataToEncode.tellp();
DES_cblock key;
DES_random_key(&key);
DES_key_schedule key_schedule;
DES_set_key_checked(&key, &key_schedule);
//ncbc block magic
size_t len = (size + 7) / 8 * 8;
char *output = new char[len + 1];
DES_cblock ivec;
memset((char*)&ivec, 0, sizeof(ivec));
DES_ncbc_encrypt((unsigned char *)&dataToEncode.str()[0],
(unsigned char *)output, size, &key_schedule, &ivec, DES_ENCRYPT);
std::string Day = std::to_string(it.first.first);
std::string Type = it.first.second == TEXT ? "txt" : "image";
std::string encodedFileName = Type + "_" + Day;
std::ofstream outputFile(filesPlace.string() + encodedFileName,
std::ofstream::in | std::ofstream::trunc | std::ofstream::binary);
std::ofstream outputKey(keysPlace.string() + encodedFileName + "_key",
std::ofstream::in | std::ofstream::trunc | std::ofstream::binary);
if (!outputFile.is_open()) {
std::cout << "Cannot create output file: " << encodedFileName;
exit(0);
}
outputFile.write(output, len);
if (!outputKey.is_open()) {
std::cout << "Cannot create output key for file: " << encodedFileName;
exit(0);
}
outputKey.write((char *)key, sizeof(key));
outputFile.close();
outputKey.close();
}
}
示例13: decrypt
void decrypt(path &filePlace, path &keyPlace) {
std::ifstream fileToDecode(filePlace.string(), std::ios::binary);
std::ifstream fileWithKey(keyPlace.string(), std::ios::binary);
if (!fileToDecode.is_open()) {
std::cout << "Cannot open file to decode: " << filePlace.filename().string();
exit(0);
}
if (!fileWithKey.is_open()) {
std::cout << "Cannot open file with key: " << keyPlace.filename().string();
exit(0);
}
DES_cblock key;
fileWithKey.read((char *)key, file_size(keyPlace));
DES_key_schedule key_schedule;
DES_set_key_checked(&key, &key_schedule);
DES_cblock ivec;
memset((char*)&ivec, 0, sizeof(ivec));
char *inputData = new char[file_size(filePlace)];
char *outputData = new char[file_size(filePlace)];
memset(inputData, 0, file_size(filePlace));
memset(outputData, 0, file_size(filePlace));
fileToDecode.read(inputData, file_size(filePlace));
DES_ncbc_encrypt((unsigned char *)inputData, (unsigned char *)outputData,
file_size(filePlace), &key_schedule, &ivec, DES_DECRYPT);
std::stringstream outputDataStream(outputData);
std::string newFileName;
std::string size;
//Loop for file data
while (std::getline(outputDataStream, newFileName)) {
std::getline(outputDataStream, size);
int fileSize = std::stoi(size);
std::string newData;
newData.resize(fileSize + 1);
outputDataStream.read(&newData[0], fileSize);
std::ofstream outputFile;
//if on Linux
if (filePlace.parent_path().string()[0] == '/') {
outputFile.open(filePlace.parent_path().string() + "/" + newFileName,
std::ofstream::out | std::ofstream::trunc | std::ofstream::binary);
}
else {
outputFile.open(filePlace.parent_path().string() + "\\" + newFileName,
std::ofstream::out | std::ofstream::trunc | std::ofstream::binary);
}
if (!outputFile.is_open()) {
std::cout << "Cannot create new file: " << newFileName;
exit(0);
}
//If it`s an image then decode back
path p(newFileName);
if (p.extension() != ".txt") {
char *decoded_image = new char[fileSize + 1];
bn::decode_b16(newData.begin(), newData.end(), decoded_image);
outputFile.write(decoded_image, fileSize);
}
else {
outputFile.write(&newData[0], fileSize);
}
outputFile.close();
}
fileToDecode.close();
fileWithKey.close();
delete[] inputData;
delete[] outputData;
}
示例14: addHighLevelShaderMaterialFromFiles
//! Like IGPUProgrammingServices::addShaderMaterial() (look there for a detailed description),
//! but tries to load the programs from files.
s32 CNullDriver::addHighLevelShaderMaterialFromFiles(
const path& vertexShaderProgramFileName,
const c8* vertexShaderEntryPointName,
E_VERTEX_SHADER_TYPE vsCompileTarget,
const path& pixelShaderProgramFileName,
const c8* pixelShaderEntryPointName,
E_PIXEL_SHADER_TYPE psCompileTarget,
const path& geometryShaderProgramFileName,
const c8* geometryShaderEntryPointName,
E_GEOMETRY_SHADER_TYPE gsCompileTarget,
E_PRIMITIVE_TYPE inType, E_PRIMITIVE_TYPE outType,
u32 verticesOut,
IShaderConstantSetCallBack* callback,
E_MATERIAL_TYPE baseMaterial,
s32 userData, E_GPU_SHADING_LANGUAGE shadingLang)
{
IReadFile* vsfile = 0;
IReadFile* psfile = 0;
IReadFile* gsfile = 0;
if (vertexShaderProgramFileName.size() )
{
vsfile = FileSystem->createAndOpenFile(vertexShaderProgramFileName);
if (!vsfile)
{
Printer::log("Could not open vertex shader program file",
vertexShaderProgramFileName, ELL_WARNING);
}
}
if (pixelShaderProgramFileName.size() )
{
psfile = FileSystem->createAndOpenFile(pixelShaderProgramFileName);
if (!psfile)
{
Printer::log("Could not open pixel shader program file",
pixelShaderProgramFileName, ELL_WARNING);
}
}
if (geometryShaderProgramFileName.size() )
{
gsfile = FileSystem->createAndOpenFile(geometryShaderProgramFileName);
if (!gsfile)
{
Printer::log("Could not open geometry shader program file",
geometryShaderProgramFileName, ELL_WARNING);
}
}
s32 result = addHighLevelShaderMaterialFromFiles(
vsfile, vertexShaderEntryPointName, vsCompileTarget,
psfile, pixelShaderEntryPointName, psCompileTarget,
gsfile, geometryShaderEntryPointName, gsCompileTarget,
inType, outType, verticesOut,
callback, baseMaterial, userData, shadingLang);
if (psfile)
psfile->releaseRef();
if (vsfile)
vsfile->releaseRef();
if (gsfile)
gsfile->releaseRef();
return result;
}
示例15: __rename
void __rename(const path& from, const path& to, std::error_code *ec) {
if (::rename(from.c_str(), to.c_str()) == -1)
set_or_throw(ec, "rename", from, to);
else if (ec)
ec->clear();
}