mirror of
https://git.lyx.org/repos/lyx.git
synced 2024-09-22 07:57:22 +00:00
63d19999eb
git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@21890 a592a061-630c-0410-9148-cb99ea01b6c8
72 lines
2.0 KiB
C++
72 lines
2.0 KiB
C++
// -*- C++ -*-
|
|
/**
|
|
* \file lyxlib.h
|
|
* This file is part of LyX, the document processor.
|
|
* Licence details can be found in the file COPYING.
|
|
*
|
|
* A selection of useful system functions made
|
|
* handy for C++ usage.
|
|
*
|
|
* \author Lars Gullik Bjønnes
|
|
*
|
|
* Full author contact details are available in file CREDITS.
|
|
*/
|
|
|
|
#ifndef LYX_LIB_H
|
|
#define LYX_LIB_H
|
|
|
|
#include "support/FileName.h"
|
|
|
|
#include <string>
|
|
|
|
|
|
namespace lyx {
|
|
namespace support {
|
|
|
|
/// get the current working directory
|
|
FileName const getcwd();
|
|
/// Change file permissions
|
|
bool chmod(FileName const & file, unsigned long int mode);
|
|
/**
|
|
* rename a file, returns false if it fails.
|
|
* It can handle renames across partitions.
|
|
*/
|
|
bool rename(FileName const & from, FileName const & to);
|
|
/// copy a file, returns false it it fails
|
|
bool copy(FileName const & from, FileName const & to,
|
|
unsigned long int mode = (unsigned long int)-1);
|
|
/// FIXME: some point to this hmm ?
|
|
int kill(int pid, int sig);
|
|
/// FIXME: same here
|
|
void abort();
|
|
/// create the given directory with the given mode
|
|
/// \ret return 0 if the directory is successfully created
|
|
int mkdir(FileName const & pathname, unsigned long int mode);
|
|
/// create the given directory with the given mode, create all
|
|
/// intermediate directories if necessary
|
|
/// \ret return 0 if the directory is successfully created
|
|
int makedir(char * pathname, unsigned long int mode=0755);
|
|
/// (securely) create a temporary file in the given dir with the given mask
|
|
/// \p mask must be in filesystem encoding
|
|
FileName const tempName(FileName const & dir = FileName(),
|
|
std::string const & mask = std::string());
|
|
|
|
|
|
/**
|
|
* Returns true if var is approximately equal to number with allowed error
|
|
* of 'error'.
|
|
*
|
|
* Usage: if (float_equal(var, number, 0.0001)) { }
|
|
*
|
|
* This will check if 'var' is approx. equal to 'number' with error of 1/1000
|
|
*/
|
|
inline bool float_equal(double var, double number, double error)
|
|
{
|
|
return (number - error <= var && var <= number + error);
|
|
}
|
|
|
|
} // namespace support
|
|
} // namespace lyx
|
|
|
|
#endif /* LYX_LIB_H */
|