/* The MIT License (MIT) Copyright (c) 2014 Antonio SJ Musumeci Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ #ifndef __FS_HPP__ #define __FS_HPP__ #include #include #include #include "path.hpp" namespace fs { using std::size_t; using std::string; using std::vector; using std::map; namespace path { string dirname(const string &path); string basename(const string &path); bool is_empty(const string &path); bool exists(vector::const_iterator begin, vector::const_iterator end, const string &fusepath); bool exists(const vector &srcmounts, const string &fusepath); inline string make(const string &base, const string &suffix) { return base + suffix; } inline void append(string &base, const string &suffix) { base += suffix; } } void findallfiles(const vector &srcmounts, const string &fusepath, vector &paths); int clonepath(const string &srcfrom, const string &srcto, const string &relative); int listxattr(const string &path, vector &attrs); int listxattr(const string &path, string &attrs); int listxattr(const string &path, vector &attrs); int getxattr(const string &path, const string &attr, vector &value); int getxattr(const string &path, const string &attr, string &value); int getxattrs(const string &path, map &attrs); int setxattr(const string &path, const string &key, const string &value, const int flags); int setxattr(const int fd, const string &key, const string &value, const int flags); int setxattrs(const string &path, const map &attrs); int copyxattrs(const string &from, const string &to); int copyattr(const string &from, const string &to); void glob(const vector &patterns, vector &strs); }; #endif // __FS_HPP__