mirror of
https://github.com/kerberos-io/openalpr-base.git
synced 2025-10-07 02:32:45 +08:00
198 lines
4.4 KiB
C++
198 lines
4.4 KiB
C++
#include "filesystem.h"
|
|
|
|
namespace alpr
|
|
{
|
|
|
|
bool startsWith(std::string const &fullString, std::string const &prefix)
|
|
{
|
|
if(fullString.substr(0, prefix.size()).compare(prefix) == 0) {
|
|
return true;
|
|
}
|
|
|
|
return false;
|
|
}
|
|
|
|
bool hasEnding (std::string const &fullString, std::string const &ending)
|
|
{
|
|
if (fullString.length() >= ending.length())
|
|
{
|
|
return (0 == fullString.compare (fullString.length() - ending.length(), ending.length(), ending));
|
|
}
|
|
else
|
|
{
|
|
return false;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
long getFileSize(std::string filename)
|
|
{
|
|
struct stat stat_buf;
|
|
int rc = stat(filename.c_str(), &stat_buf);
|
|
//return rc == 0 ? stat_buf.st_size : -1;
|
|
|
|
// 512 bytes is the standard block size
|
|
if (rc == 0)
|
|
return 512 * stat_buf.st_blocks;
|
|
|
|
return -1;
|
|
}
|
|
|
|
long getFileCreationTime(std::string filename)
|
|
{
|
|
struct stat stat_buf;
|
|
int rc = stat(filename.c_str(), &stat_buf);
|
|
|
|
if (rc != 0)
|
|
return 0;
|
|
|
|
double milliseconds = (stat_buf.st_ctim.tv_sec * 1000) + (((double) stat_buf.st_ctim.tv_nsec) / 1000000.0);
|
|
|
|
return (long) milliseconds;
|
|
}
|
|
|
|
|
|
|
|
bool hasEndingInsensitive(const std::string& fullString, const std::string& ending)
|
|
{
|
|
if (fullString.length() < ending.length())
|
|
return false;
|
|
|
|
int startidx = fullString.length() - ending.length();
|
|
|
|
for (unsigned int i = startidx; i < fullString.length(); ++i)
|
|
if (tolower(fullString[i]) != tolower(ending[i - startidx]))
|
|
return false;
|
|
return true;
|
|
}
|
|
|
|
bool DirectoryExists( const char* pzPath )
|
|
{
|
|
if ( pzPath == NULL) return false;
|
|
|
|
DIR *pDir;
|
|
bool bExists = false;
|
|
|
|
pDir = opendir (pzPath);
|
|
|
|
if (pDir != NULL)
|
|
{
|
|
bExists = true;
|
|
(void) closedir (pDir);
|
|
}
|
|
|
|
return bExists;
|
|
}
|
|
|
|
bool fileExists( const char* pzPath )
|
|
{
|
|
if (pzPath == NULL) return false;
|
|
|
|
bool fExists = false;
|
|
std::ifstream f(pzPath);
|
|
fExists = f.is_open();
|
|
f.close();
|
|
return fExists;
|
|
}
|
|
|
|
std::vector<std::string> getFilesInDir(const char* dirPath)
|
|
{
|
|
DIR *dir;
|
|
|
|
std::vector<std::string> files;
|
|
|
|
struct dirent *ent;
|
|
if ((dir = opendir (dirPath)) != NULL)
|
|
{
|
|
/* print all the files and directories within directory */
|
|
while ((ent = readdir (dir)) != NULL)
|
|
{
|
|
if (strcmp(ent->d_name, ".") != 0 && strcmp(ent->d_name, "..") != 0)
|
|
files.push_back(ent->d_name);
|
|
}
|
|
closedir (dir);
|
|
}
|
|
else
|
|
{
|
|
/* could not open directory */
|
|
perror ("");
|
|
return files;
|
|
}
|
|
|
|
return files;
|
|
}
|
|
|
|
bool stringCompare( const std::string &left, const std::string &right )
|
|
{
|
|
for( std::string::const_iterator lit = left.begin(), rit = right.begin(); lit != left.end() && rit != right.end(); ++lit, ++rit )
|
|
if( tolower( *lit ) < tolower( *rit ) )
|
|
return true;
|
|
else if( tolower( *lit ) > tolower( *rit ) )
|
|
return false;
|
|
if( left.size() < right.size() )
|
|
return true;
|
|
return false;
|
|
}
|
|
|
|
std::string filenameWithoutExtension(std::string filename)
|
|
{
|
|
int lastindex = filename.find_last_of(".");
|
|
return filename.substr(0, lastindex);
|
|
}
|
|
|
|
|
|
static int makeDir(const char *path, mode_t mode)
|
|
{
|
|
struct stat st;
|
|
int status = 0;
|
|
|
|
if (stat(path, &st) != 0)
|
|
{
|
|
/* Directory does not exist. EEXIST for race condition */
|
|
if (mkdir(path, mode) != 0 && errno != EEXIST)
|
|
status = -1;
|
|
}
|
|
else if (!S_ISDIR(st.st_mode))
|
|
{
|
|
errno = ENOTDIR;
|
|
status = -1;
|
|
}
|
|
|
|
return(status);
|
|
}
|
|
|
|
/**
|
|
** makePath - ensure all directories in path exist
|
|
** Algorithm takes the pessimistic view and works top-down to ensure
|
|
** each directory in path exists, rather than optimistically creating
|
|
** the last element and working backwards.
|
|
*/
|
|
bool makePath(const char* path, mode_t mode)
|
|
{
|
|
|
|
char *pp;
|
|
char *sp;
|
|
int status;
|
|
char *copypath = strdup(path);
|
|
|
|
status = 0;
|
|
pp = copypath;
|
|
while (status == 0 && (sp = strchr(pp, '/')) != 0)
|
|
{
|
|
if (sp != pp)
|
|
{
|
|
/* Neither root nor double slash in path */
|
|
*sp = '\0';
|
|
status = makeDir(copypath, mode);
|
|
*sp = '/';
|
|
}
|
|
pp = sp + 1;
|
|
}
|
|
if (status == 0)
|
|
status = makeDir(path, mode);
|
|
free(copypath);
|
|
return (status);
|
|
|
|
}
|
|
} |