/usr/include/vmime/utility/file.hpp is in libvmime-dev 0.9.2-5build2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 | //
// VMime library (http://www.vmime.org)
// Copyright (C) 2002-2013 Vincent Richard <vincent@vmime.org>
//
// This program is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License as
// published by the Free Software Foundation; either version 3 of
// the License, or (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
// General Public License for more details.
//
// You should have received a copy of the GNU General Public License along
// with this program; if not, write to the Free Software Foundation, Inc.,
// 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
//
// Linking this library statically or dynamically with other modules is making
// a combined work based on this library. Thus, the terms and conditions of
// the GNU General Public License cover the whole combination.
//
#ifndef VMIME_UTILITY_FILE_HPP_INCLUDED
#define VMIME_UTILITY_FILE_HPP_INCLUDED
#include "vmime/config.hpp"
#include "vmime/utility/path.hpp"
#include "vmime/utility/stream.hpp"
#if VMIME_HAVE_FILESYSTEM_FEATURES
namespace vmime {
namespace utility {
class file;
/** File list iterator (see file::getFiles).
*/
class VMIME_EXPORT fileIterator : public object
{
public:
virtual ~fileIterator() { }
/** Check whether the cursor has reach the end of the list.
*
* @return true if you can call nextElement(), or false
* if no more file is available
*/
virtual bool hasMoreElements() const = 0;
/** Return the next file in the list.
*
* @return next file or NULL
*/
virtual shared_ptr <file> nextElement() = 0;
};
/** Write to a file.
*/
class VMIME_EXPORT fileWriter : public object
{
public:
virtual ~fileWriter() { }
virtual shared_ptr <utility::outputStream> getOutputStream() = 0;
};
/** Read from a file.
*/
class VMIME_EXPORT fileReader : public object
{
public:
virtual ~fileReader() { }
virtual shared_ptr <utility::inputStream> getInputStream() = 0;
};
/** Abstract representation of a file or directory.
*/
class VMIME_EXPORT file : public object
{
public:
typedef utility::path path;
typedef unsigned long length_type;
virtual ~file() { }
/** Create the file pointed by this file object.
*
* @throw exceptions::filesystem_exception if an error occurs
*/
virtual void createFile() = 0;
/** Create the directory pointed by this file object.
*
* @param createAll if set to true, recursively create all
* parent directories if they do not exist
* @throw exceptions::filesystem_exception if an error occurs
*/
virtual void createDirectory(const bool createAll = false) = 0;
/** Test whether this is a file.
*
* @return true if this is a file, false otherwise
*/
virtual bool isFile() const = 0;
/** Test whether this is a directory.
*
* @return true if this is a directory, false otherwise
*/
virtual bool isDirectory() const = 0;
/** Test whether this file is readible.
*
* @return true if we can read this file, false otherwise
*/
virtual bool canRead() const = 0;
/** Test whether this file is writeable.
*
* @return true if we can write to this file, false otherwise
*/
virtual bool canWrite() const = 0;
/** Return the length of this file.
*
* @return file size (in bytes)
*/
virtual length_type getLength() = 0;
/** Return the full path of this file/directory.
*
* @return full path of the file
*/
virtual const path& getFullPath() const = 0;
/** Test whether this file/directory exists.
*
* @return true if the file exists, false otherwise
*/
virtual bool exists() const = 0;
/** Return the parent directory of this file/directory.
*
* @return parent directory (or NULL if root)
*/
virtual shared_ptr <file> getParent() const = 0;
/** Rename the file/directory.
*
* @param newName full path of the new file
* @throw exceptions::filesystem_exception if an error occurs
*/
virtual void rename(const path& newName) = 0;
/** Deletes this file/directory.
* If this is a directory, it must be empty.
*
* @throw exceptions::filesystem_exception if an error occurs
*/
virtual void remove() = 0;
/** Return an object capable of writing to this file.
*
* @return file writer object
*/
virtual shared_ptr <fileWriter> getFileWriter() = 0;
/** Return an object capable of reading from this file.
*
* @return file reader object
*/
virtual shared_ptr <fileReader> getFileReader() = 0;
/** Enumerate files contained in this directory.
*
* @return file iterator to enumerate files
* @throw exceptions::not_a_directory if this is not a directory,
* exceptions::filesystem_exception if another error occurs
*/
virtual shared_ptr <fileIterator> getFiles() const = 0;
protected:
file() { }
private:
file(const file&) : object() { }
};
/** Constructs 'file' objects.
*/
class VMIME_EXPORT fileSystemFactory : public object
{
public:
virtual ~fileSystemFactory() { }
/** Create a new file object from the specified path.
*
* @param path full path (absolute) of the file
* @return new file object for the path
*/
virtual shared_ptr <file> create(const file::path& path) const = 0;
/** Parse a path contained in a string.
*
* @param str string containing a path in a system-dependent representation
* @return path object (abstract representation)
*/
virtual const file::path stringToPath(const string& str) const = 0;
/** Return the system-dependent string representation for the specified path.
*
* @param path abstract representation of the path
* @return string representation of the path
*/
virtual const string pathToString(const file::path& path) const = 0;
/** Test whether the specified path component is syntactically
* valid (ie: does not contain any 'special' character).
*
* @param comp path component to test
* @return true if the component is valid, false otherwise
*/
virtual bool isValidPathComponent(const file::path::component& comp) const = 0;
/** Test whether the specified path is syntactically valid
* (ie: components do not contain any 'special' character).
*
* @param path path to test
* @return true if the path is valid, false otherwise
*/
virtual bool isValidPath(const file::path& path) const = 0;
};
} // utility
} // vmime
#endif // VMIME_HAVE_FILESYSTEM_FEATURES
#endif // VMIME_UTILITY_FILE_HPP_INCLUDED
|