/usr/include/ui-utilcpp/File.hpp is in libui-utilcpp-dev 1.8.3-2.
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 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 | /**
 * @file
 * @brief File, descriptors and sockets.
 */
#ifndef UI_UTIL_FILE_HPP
#define UI_UTIL_FILE_HPP
#ifdef WIN32
#include <fcntl.h>
#endif
// STDC++
#include <string>
#include <iostream>
#include <vector>
#include <ctime>
// C++ libraries
#include <ui-utilcpp/Exception.hpp>
#include <ui-utilcpp/Sys.hpp>
namespace UI {
namespace Util {
/** @brief Like getenv(3), but returns empty string when env is missing. */
std::string getenv(std::string const & name);
/** @brief Guess a config file (/etc/id.conf or ~/.id.conf). */
std::string guessConfFile(std::string const & id, std::string const & suffix=".conf");
/** @brief Write and keep pid file during lifetime. */
class PIDFile
{
public:
	/** @brief Guess a pid file (/var/run/id.pid or ~/.id.pid). */
	static std::string guess(std::string const & id);
	PIDFile(std::string const & path,
#ifdef WIN32
	        pid_t const & pid=Sys::getpid(),
#else
	        pid_t const & pid=Sys::getpgid(0),
#endif
	        bool const & keepExisting=true,
	        mode_t const & perms=S_IRUSR | S_IWUSR
#ifndef WIN32
					| S_IRGRP | S_IROTH
#endif
					);
	~PIDFile();
private:
	std::string const path_;
};
/** @brief Guarantuee to run "remove(2)" on path in destructor. */
class AutoRemoveFile
{
public:
	AutoRemoveFile(std::string const & path);
	~AutoRemoveFile();
	std::string const & operator()() const;
private:
	std::string const path_;
};
/** @brief Simple exception-save FILE abstraction. */
class CFileStream
{
public:
	/** @brief Constructor. */
	CFileStream(std::string const & fileName, std::string const & mode);
	~CFileStream();
	/** @brief Get C file stream. */
	FILE * get() const;
private:
	FILE * const file_;
};
/** @brief File copy from file names. */
void fileCopy(std::string const & src, std::string const & dest);
/** @brief Check if a file exists using stat(2).
 *
 * @param fName File name to check.
 * @return true, if file exists, else false.
 */
bool fileExists(std::string const & fName);
/** @brief Get the modification time for a file
 *
 * @param path File to check.
 * @return time of last modification.
 */
time_t fileModificationTime(std::string const & path);
/** @brief File Descriptor Holder Class.
 *
 * @see read(2), write(2)
 *
 * This should encapsulate system calls on file descriptors, and
 * automate descriptor closing.
 */
class FileDescriptor
{
public:
	/** @brief Helper to close file descriptors from destructors. */
	static void fdClose(int const & fd, std::string const & id, bool const & doClose=true);
	/** @brief Error codes for exceptions. */
	enum ErrorCode
	{
		OpenErr_ = 1,
		ReadErr_,
		WriteErr_,
		LockErr_,
		UnlockErr_,
		BindErr_,
		ConnectErr_,
		UnblockErr_,
		ListenErr_,
		ShutdownErr_
	};
	/** @brief Exceptions for this class. */
	typedef CodeException<ErrorCode> Exception;
	/** @brief Constructor from file descriptor
	 *
	 * @param fd Already opened file descriptor
	 * @param closeFd Whether to call close(2) in destructor
	 *
	 * This constructor takes an already opened file descriptor.  The
	 * destructor will not call close on this descriptor.
	 *
	 */
	FileDescriptor(int fd=-1, bool closeFd=false);
	/** @brief Destructor.
	 *
	 * This will close the file descriptor via close(2), unless it was
	 * constructed by an already opened descriptor.
	 *
	 * It will never delete the file, even if it got created by the
	 * constructor.
	 *
	 */
	virtual ~FileDescriptor();
	/** @brief C++ like virtual read method.
	 *
	 * This default implementation uses read(2).
	 */
	virtual std::streamsize read(void * const buf, std::streamsize count);
	/** @brief C++ like virtual erite method.
	 *
	 * This default implementation uses write(2).
	 */
	virtual std::streamsize write(void const * const buf, std::streamsize count);
	/** @brief Get file descriptor. */
	int getFd() const;
protected:
	/** @brief The file descriptor that is managed. */
	int fd_;
	/** @brief To be called in a constructor. */
	void init(int fd, bool closeFd=false);
private:
	bool closeFd_;
};
/** @brief File representation.
 *
 * @see FileDescriptor, fcntl(2), open(2), close(2)
 */
class File: public FileDescriptor
{
public:
	/** @brief Constructor.
	 *
	 * @param name Path to the file to open
	 * @param flags As in open(2)
	 * @param mode As in open(2)
	 * @param closeFd Whether to call close(2) in destructor
	 * @see open(2)
	 *
	 * This constructor takes a file name, will try to open the file
	 * using open(2). Arguments to open(2) can be given optionally,
	 * and have reasonable defaults.
	 *
	 * OPEN_ERR will be thrown if the file could not be created via
	 * open(2).
	 */
	File(std::string const & name,
	     int flags=O_CREAT | O_WRONLY,
	     mode_t mode=S_IRUSR | S_IWUSR,
	     bool closeFd=true);
	/** @brief Constructor from file descriptor.
	 *
	 * @param fd Already opened file descriptor
	 * @param closeFd Whether to call close(2) in destructor
	 *
	 * This constructor takes an already opened file descriptor.
	 */
	File(int fd, bool closeFd=false);
	/** @brief Get file name. This will always deliver en empty string if constructed from fd. */
	std::string const & getName() const;
private:
	std::string const name_;
};
/**
 * @example FileLock.cpp
 * Example program for advisory POSIX and BSD file locking.
 * Should be installed as ui-utilcpp-filelock along with the library.
 */
/** @brief Mutex For Posix Advisory File Locking
 *
 * @see MutexLock
 * @see fcntl(2), open(2)
 * @attention This does not work from the same process id, as any close() to any open file
 *  descriptor of a process removes all POSIX locks from that (process/fd)-pair.
 */
#ifndef WIN32
class PosixFileMutex: public File
{
public:
	/** @brief Constructor from file name.
	 *
	 * @param lockFile Name of lock file
	 * @see FileDescriptor
	 */
	PosixFileMutex(std::string const & lockFile);
	/** @brief Constructor from file descriptor.
	 *
	 * @param fd Opened file descriptor
	 * @see FileDescriptor
	 */
	PosixFileMutex(int fd);
	/** @name Standard mutex methods.
	 * @{ */
	bool tryEnterMutex() throw();
	void enterMutex();
	void leaveMutex();
	/** @} */
private:
	bool setPosixLock(int type, bool wait);
};
/** @brief Mutex For BSD Advisory File Locking.
 *
 * @see MutexLock
 * @see flock(2), open(2)
 * @attention BSD locking does not work over NFS.
 *
 */
class BSDFileMutex: public File
{
public:
	/** @brief Constructor from file name.
	 *
	 * @param lockFile Name of lock file
	 * @see FileDescriptor
	 */
	BSDFileMutex(std::string const & lockFile);
	/** @brief Constructor from file descriptor.
	 *
	 * @param fd Opened file descriptor
	 * @see FileDescriptor
	 */
	BSDFileMutex(int fd);
	/** @name Standard mutex methods.
	 * @{ */
	bool tryEnterMutex() throw();
	void enterMutex();
	void leaveMutex();
	/** @} */
};
#endif
/** @brief File system information abstraction.
 *
 * @note All methods always return (amounts of) 1024 byte
 * blocks. Calculation is done via float for simplicity -- minor
 * rounding errors may occur.
 */
class FsInfo
{
private:
	uint64_t calc(long double const & value) const;
public:
	FsInfo(std::string const & dev, std::string const & file);
	uint64_t getTotal() const;
	uint64_t getAvail() const;
	uint64_t getFree()  const;
	uint64_t getUsed()  const;
private:
	long double bSize_;
	long double bTotal_;
	long double bAvail_;
	long double bFree_;
};
}}
#endif
 |