X-Git-Url: http://git.tdb.fi/?p=libs%2Fcore.git;a=blobdiff_plain;f=source%2Futils.h;h=8139a7e4c073f4f7d8640608ae85b4cce5b79e4e;hp=faf5ef7f261e038e2e1d688ec013d150b93369cd;hb=e6fec68039fb5212993d687d352c540e407e6d96;hpb=bfbb7edfb2ae76d23f26e0b22787617ff621747d diff --git a/source/utils.h b/source/utils.h index faf5ef7..8139a7e 100644 --- a/source/utils.h +++ b/source/utils.h @@ -1,19 +1,20 @@ -/* -This file is part of libmsppath -Copyright © 2006 Mikko Rasa, Mikkosoft Productions +/* $Id$ + +This file is part of libmspfs +Copyright © 2006-2008 Mikko Rasa, Mikkosoft Productions Distributed under the LGPL */ -#ifndef MSP_PATH_UTILS_H_ -#define MSP_PATH_UTILS_H_ + +#ifndef MSP_FS_UTILS_H_ +#define MSP_FS_UTILS_H_ #include -#include #include #include -#include "path.h" namespace Msp { -namespace Path { + +class Path; struct Filename { @@ -21,25 +22,64 @@ struct Filename std::string ext; }; -extern Path fix_case(const Path &); -extern int mkpath(const Path &, int); -extern int rmdir(const Path &, bool =false); -extern std::list list_files(const Path &); -extern bool exists(const Path &); -extern Filename splitext(const std::string &); -extern int fnmatch(const std::string &, const Path &); -extern Path relative(const Path &, const Path &); +Path fix_case(const Path &path); + +/// Creates a directory +void mkdir(const Path &path, int mode); + +/// Creates a directory and any required parent directories +void mkpath(const Path &path, int mode); + +/// Removes a directory +void rmdir(const Path &path); + +/// Removes a directory and anything it contains +void rmdirs(const Path &path); + +/// Removes a file +void unlink(const Path &path); + +/// Lists the contents of a directory +std::list list_files(const Path &path); + +Filename splitext(const std::string &); +int fnmatch(const std::string &, const Path &); + +/// Makes a path relative to some base path. That is, base/result==path. +Path relative(const Path &path, const Path &base); + +std::string basename(const std::string &); + +/// Tests for existence of a file +bool exists(const Path &path); + +/// Tests whether a path refers to an existing directory +bool is_dir(const Path &paht); + +/** +Gets information about a file. Returns 0 on success or -1 on error. This +version can be used to check for file existence and get information in one +call. +*/ +int stat(const Path &fn, struct stat &st); + +/** +Returns information about a file. This version throws an exception if an error +occurs. +*/ +struct stat stat(const Path &fn); + +Path getcwd(); -inline int stat(const Path &fn, struct stat &st) -{ return ::stat(fn.str().c_str(), &st); } +/// Returns the user's home directory +Path get_home_dir(); -inline Path getcwd() -{ char buf[1024]; return ::getcwd(buf, sizeof(buf)); } +/// Changes the current working directory +void chdir(const Path &); inline bool is_windows_drive(const std::string &p) { return (p.size()==2 && ((p[0]>='A' && p[0]<='Z') || (p[0]>='a' && p[0]<='z')) && p[1]==':'); } -} // namespace Path } // namespace Msp #endif