summaryrefslogtreecommitdiffstats
path: root/Source/kwsys/SystemTools.hxx.in
diff options
context:
space:
mode:
authorSebastien Barre <sebastien.barre@kitware.com>2005-03-10 17:50:17 (GMT)
committerSebastien Barre <sebastien.barre@kitware.com>2005-03-10 17:50:17 (GMT)
commita79868206eb59e19fd0ebca72ba435cdbb8c6a89 (patch)
tree355c3e56d3a611ff43383183cdf2e40c0a04b421 /Source/kwsys/SystemTools.hxx.in
parent0e3f4214b9ec5b213f19cde434cbafaf225696d3 (diff)
downloadCMake-a79868206eb59e19fd0ebca72ba435cdbb8c6a89.zip
CMake-a79868206eb59e19fd0ebca72ba435cdbb8c6a89.tar.gz
CMake-a79868206eb59e19fd0ebca72ba435cdbb8c6a89.tar.bz2
ENH: move function from vtkKWDirectoryUtilities and vtkString to SystemTools
Diffstat (limited to 'Source/kwsys/SystemTools.hxx.in')
-rw-r--r--Source/kwsys/SystemTools.hxx.in33
1 files changed, 33 insertions, 0 deletions
diff --git a/Source/kwsys/SystemTools.hxx.in b/Source/kwsys/SystemTools.hxx.in
index a9ebfe7..a546de9 100644
--- a/Source/kwsys/SystemTools.hxx.in
+++ b/Source/kwsys/SystemTools.hxx.in
@@ -120,6 +120,12 @@ public:
static kwsys_stl::string UpperCase(const kwsys_stl::string&);
/**
+ * Return the string cropped to a given length by removing chars in the
+ * center of the string and replacing them with an ellipsis (...)
+ */
+ static kwsys_stl::string Crop(const kwsys_stl::string&, size_t max_len);
+
+ /**
* do a case-independent string comparison
*/
static int Strucmp(const char *s1, const char *s2);
@@ -207,6 +213,29 @@ public:
static bool FileIsDirectory(const char* name);
static kwsys_stl::string GetCurrentWorkingDirectory();
+
+ ///! return true if the file has a given signature (first set of bytes)
+ static bool FileHasSignature(const char* filename, const char *signature, unsigned long offset = 0);
+
+ /**
+ * Try to locate the file 'filename' in the directory 'dir'.
+ * If 'filename' is a fully qualified filename, the basename of the file is
+ * used to check for its existence in 'dir'.
+ * If 'dir' is not a directory, GetFilenamePath() is called on 'dir' to
+ * get its directory first (thus, you can pass a filename as 'dir', as
+ * a convenience).
+ * 'filename_found' is assigned the fully qualified name/path of the file
+ * if it is found (not touched otherwise).
+ * If 'try_filename_dirs' is true, try to find the file using the
+ * components of its path, i.e. if we are looking for c:/foo/bar/bill.txt,
+ * first look for bill.txt in 'dir', then in 'dir'/bar, then in 'dir'/foo/bar
+ * etc.
+ * Return true if the file was found, false otherwise.
+ */
+ static bool LocateFileInDir(const char *filename,
+ const char *dir,
+ kwsys_stl::string& filename_found,
+ int try_filename_dirs = 0);
/**
* Given the path to a program executable, get the directory part of
@@ -304,8 +333,12 @@ public:
/** Return whether the path represents a full path (not relative). */
static bool FileIsFullPath(const char*);
+ /** Return file's modified time. */
static long int ModifiedTime(const char* filename);
+ /** Return file's creation time (Win32: works only for NTFS, not FAT). */
+ static long int CreationTime(const char* filename);
+
///! for windows return the short path for the given path, unix just a pass through
static bool GetShortPath(const char* path, kwsys_stl::string& result);