X-Git-Url: http://git.tdb.fi/?p=libs%2Fcore.git;a=blobdiff_plain;f=source%2Futils.h;h=6a4c55add16f7ec305d40341d7f65fe48d65710b;hp=961ad499674666629ecc7b635d04032e2b5d63ac;hb=fa77438b62207466c48620604c8cc34931080936;hpb=058953b54ba1a3fbf95db92a0e60e6c9581bfb6b diff --git a/source/utils.h b/source/utils.h index 961ad49..6a4c55a 100644 --- a/source/utils.h +++ b/source/utils.h @@ -1,44 +1,62 @@ -/* -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_ -#include -#include -#include -#include +#ifndef MSP_FS_UTILS_H_ +#define MSP_FS_UTILS_H_ + #include "path.h" namespace Msp { -namespace Path { +namespace FS { + +/// Extracts the last component of the path. +std::string basename(const Path &); + +/// Removes the last component from the path. +Path dirname(const Path &); + +/** +Returns the base part of a filename. This includes everything up to the last +dot, but not the dot itself. +*/ +std::string basepart(const std::string &); + +/** +Returns the extension part of a filename. This includes the last dot and +everything after it. +*/ +std::string extpart(const std::string &); + +/** +Fixes the case of the given path to match files / directories on the +filesystem. +*/ +Path fix_case(const Path &path); + +/// Reads the contents of a symbolic link +Path readlink(const Path &path); -struct Filename -{ - std::string base; - std::string ext; -}; +/// Resolves all symlinks from a path. Will always return an absolute path. +Path realpath(const Path &path); -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 &); +/// Removes a file +void unlink(const Path &path); -inline int stat(const Path &fn, struct stat &st) -{ return ::stat(fn.str().c_str(), &st); } +/// Renames a file. Existing file, if any, is overwritten. +void rename(const Path &from, const Path &to); -inline Path getcwd() -{ char buf[1024]; return ::getcwd(buf, sizeof(buf)); } +/// Makes a path relative to some base path. That is, base/result==path. +Path relative(const Path &path, const Path &base); -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]==':'); } +/** Determines how many levels a path is below another. Returns -1 if path is +not a descendant of parent. */ +int descendant_depth(const Path &path, const Path &parent); -} // namespace Path +} // namespace FS } // namespace Msp #endif