Files
FileSync/fileutil.c

327 lines
6.2 KiB
C

#include <stdio.h>
#include <dirent.h>
#include <string.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <unistd.h>
#include <utime.h>
#include <time.h>
#ifdef WIN32
#define _WIN32_WINNT 0x0501
#include <signal.h>
#include <windows.h>
#include <fcntl.h>
#include <io.h>
#else
#include <unistd.h>
#endif
#include "fileutil.h"
#ifdef WIN32
long long FileTime_to_POSIX(FILETIME fileTime) {
LARGE_INTEGER date, adjust;
// takes the last modified date
date.HighPart = fileTime.dwHighDateTime;
date.LowPart = fileTime.dwLowDateTime;
// 100-nanoseconds = milliseconds * 10000
adjust.QuadPart = 11644473600000ll * 10000;
// removes the diff between 1970 and 1601
date.QuadPart -= adjust.QuadPart;
// converts back from 100-nanoseconds to seconds
return date.QuadPart / 10000000ll;
}
FILETIME POSIX_to_FileTime(FileTime fileTime) {
LARGE_INTEGER date, adjust;
FILETIME fileTimeOut;
// converts to 100-nanoseconds from seconds
date.QuadPart = fileTime * 10000000ll;
// 100-nanoseconds = milliseconds * 10000
adjust.QuadPart = 11644473600000ll * 10000ll;
// removes the diff between 1970 and 1601
date.QuadPart += adjust.QuadPart;
// asigns to filetime
fileTimeOut.dwHighDateTime = date.HighPart;
fileTimeOut.dwLowDateTime = date.LowPart;
return fileTimeOut;
}
FileTime FileTime_Get(char *fileName) {
HANDLE hFile;
FILETIME ftCreate, ftAccess, ftWrite;
hFile = CreateFile(fileName, GENERIC_READ, FILE_SHARE_READ, NULL,
OPEN_EXISTING, FILE_FLAG_BACKUP_SEMANTICS, NULL );
GetFileTime(hFile, &ftCreate, &ftAccess, &ftWrite);
CloseHandle(hFile);
return (FileTime_to_POSIX(ftWrite));
}
void FileTime_Set(char *fileName, FileTime fileTime) {
HANDLE hFile;
FILETIME ftWrite;
hFile = CreateFile(fileName, GENERIC_WRITE, FILE_SHARE_WRITE, NULL,
OPEN_EXISTING, FILE_FLAG_BACKUP_SEMANTICS, NULL );
ftWrite = POSIX_to_FileTime(fileTime);
SetFileTime(hFile, NULL, NULL, &ftWrite);
CloseHandle(hFile);
}
#else
FileTime FileTime_Get(char *filename) {
struct stat fs;
lstat(filename, &fs);
return (fs.st_mtime);
}
void FileTime_Set(char *filename, FileTime t) {
struct utimbuf utb;
utb.actime = t;
utb.modtime = t;
utime(filename, &utb);
}
#endif
void FileTime_Print(FileTime fileTime) {
struct tm *tms;
tms = localtime((time_t *) &fileTime);
printf("%04d-%02d-%02d %02d:%02d:%02d", tms->tm_year + 1900,
tms->tm_mon + 1, tms->tm_mday, tms->tm_hour, tms->tm_min,
tms->tm_sec);
}
void File_GetName(char *path, char *name) {
int i, j;
i = strlen(path) - 1;
while (i >= 0) {
if (path[i] == '/' || path[i] == '\\') {
i++;
break;
} else {
i--;
}
}
if (i < 0)
i++;
j = 0;
while (path[i]) {
name[j] = path[i];
i++;
j++;
}
name[j] = 0;
}
#ifdef WIN32
int File_ExistsPath(char *path) {
unsigned rc;
rc = GetFileAttributes(path);
if (rc == INVALID_FILE_ATTRIBUTES ) {
return (0);
}
return (1);
}
int File_IsDirectory(char *dir) {
unsigned rc;
rc = GetFileAttributes(dir);
if (rc == INVALID_FILE_ATTRIBUTES ) {
return (0);
}
if (rc & FILE_ATTRIBUTE_DIRECTORY) {
return (1);
}
return (0);
}
int File_IsFile(char *fichero) {
unsigned rc;
rc = GetFileAttributes(fichero);
if (rc == INVALID_FILE_ATTRIBUTES ) {
return (0);
}
if (rc & FILE_ATTRIBUTE_DIRECTORY) {
return (0);
}
return (1);
}
#else
int File_ExistsPath(char *path) {
struct stat info;
if (lstat(path, &info) == -1) {
return (0);
}
return (1);
}
int File_IsDirectory(char *dir) {
struct stat info;
if (lstat(dir, &info) == -1) {
return (0);
}
if (S_ISDIR(info.st_mode)) {
return (1);
}
return (0);
}
int File_IsFile(char *fichero) {
struct stat info;
if (lstat(fichero, &info) == -1) {
return (0);
}
if (S_ISDIR(info.st_mode)) {
return (0);
}
return (1);
}
#endif
long long File_GetSize(char *file) {
FILE *f;
long long tamanho;
f = fopen(file, "rb");
if (!f)
return (-1);
fseek(f, 0, SEEK_END);
tamanho = ftell(f);
fclose(f);
return (tamanho);
}
#ifdef WIN32
int File_MakeDirectory(char *path) {
return (_mkdir(path));
}
#else
int File_MakeDirectory(char *path) {
return (mkdir(path, 0777));
}
#endif
#ifdef WIN32
void File_IterateDir(char *path,
int (*func)(char *path, char *name, void *data), void *data) {
int handle;
struct _finddata_t fileinfo;
char f_path[MaxPath];
int fin = 0;
int findnext_rc;
char path_aux[MaxPath];
char *ptr;
snprintf(path_aux, MaxPath, "%s/*", path);
handle = _findfirst(path_aux, &fileinfo);
if (handle == -1)
return;
// Recorrer el directorio
do {
if (strcmp(fileinfo.name, ".") && strcmp(fileinfo.name, "..")) {
// A partir de aqui hay un fichero
// (o directorio)
snprintf(f_path, 512, "%s/%s", path, fileinfo.name);
fin = func(f_path, fileinfo.name, data);
}
findnext_rc = _findnext(handle, &fileinfo);
} while (findnext_rc != -1 && !fin);
_findclose(handle);
}
#else
void File_IterateDir(char *path,
int (*func)(char *path, char *name, void *data), void *data) {
DIR *directorio;
struct dirent *entidad_dir;
char f_path[MaxPath];
int fin = 0;
char *ptr;
directorio = opendir(path);
if (directorio == NULL )
return;
// Recorrer el directorio
do {
entidad_dir = readdir(directorio);
if (entidad_dir != NULL ) {
if (strcmp(entidad_dir->d_name, ".")
&& strcmp(entidad_dir->d_name, "..")) {
// A partir de aqui hay un fichero
// (o directorio)
snprintf(f_path, MaxPath, "%s/%s", path, entidad_dir->d_name);
fin = func(f_path, entidad_dir->d_name, data);
}
}
}while (entidad_dir != NULL && !fin);
closedir(directorio);
}
#endif
void File_Delete(char *path) {
unlink(path);
}
void File_DeleteDirectory(char *path) {
rmdir(path);
}
#define MaxBuffer 16384
int File_Copy(const char *pathOrig, const char *pathDest) {
FILE *fOrig, *fDest;
char buffer[MaxBuffer];
int readLen = 0;
int writeLen = 0;
int ok = 0;
if ((fOrig = fopen(pathOrig, "rb")) == NULL ) {
return 0;
}
if ((fDest = fopen(pathDest, "wb")) == NULL ) {
return 0;
}
do {
readLen = fread(&buffer, 1, MaxBuffer, fOrig);
if (readLen > 0) {
writeLen = fwrite(&buffer, 1, readLen, fDest);
if (writeLen != readLen) {
// Error
fclose(fOrig);
fclose(fDest);
return 0;
}
}
} while (readLen == MaxBuffer);
if (feof(fOrig)) {
ok = 1;
}
fclose(fOrig);
fclose(fDest);
return ok;
}