Code cleanup

This commit is contained in:
2015-11-23 01:41:11 +01:00
parent ed88d7624f
commit f96eb1bdb8
6 changed files with 148 additions and 105 deletions

View File

@@ -149,19 +149,20 @@ void AccionFileNode_CompareChilds(
} }
void ActionFileNode_Statistics(ActionFileNode actionFileNode, int ActionFileNode_Statistics(ActionFileNode actionFileNode,
ActionQueueStatistics *statistics) ActionQueueStatistics *statistics)
{ {
statistics->readLeft = 0; statistics->readLeft = 0;
statistics->writeLeft = 0; statistics->writeLeft = 0;
statistics->readRight = 0; statistics->readRight = 0;
statistics->writeRight = 0; statistics->writeRight = 0;
statistics->deleteLeft = 0;
statistics->deleteRight = 0;
statistics->fullCopyCount = 0; statistics->fullCopyCount = 0;
statistics->dateCopyCount = 0; statistics->dateCopyCount = 0;
statistics->directoryCount = 0; statistics->directoryCount = 0;
statistics->deleteCount = 0; statistics->deleteCount = 0;
statistics->deleteLeft = 0;
statistics->deleteRight = 0;
while (actionFileNode != NULL) { while (actionFileNode != NULL) {
@@ -202,6 +203,12 @@ void ActionFileNode_Statistics(ActionFileNode actionFileNode,
actionFileNode = actionFileNode->next; actionFileNode = actionFileNode->next;
} }
return (
statistics->fullCopyCount +
statistics->dateCopyCount +
statistics->directoryCount +
statistics->deleteCount
);
} }
void ActionFileNode_Print(ActionFileNode actionFileNode) { void ActionFileNode_Print(ActionFileNode actionFileNode) {
@@ -219,34 +226,34 @@ void ActionFileNode_Print(ActionFileNode actionFileNode) {
//printff("%s == %s\n",pathIzq,pathDer); //printff("%s == %s\n",pathIzq,pathDer);
break; break;
case ActionFileCmp_LeftToRight: case ActionFileCmp_LeftToRight:
printff(" => %s\n", showPath); Print(" => %s\n", showPath);
break; break;
case ActionFileCmp_RightToLeft: case ActionFileCmp_RightToLeft:
printff(" <= %s\n", showPath); Print(" <= %s\n", showPath);
break; break;
case ActionFileCmp_DeleteLeft: case ActionFileCmp_DeleteLeft:
printff(" *- %s\n", showPath); Print(" *- %s\n", showPath);
break; break;
case ActionFileCmp_DeleteRight: case ActionFileCmp_DeleteRight:
printff(" -* %s\n", showPath); Print(" -* %s\n", showPath);
break; break;
case ActionFileCmp_DateLeftToRight: case ActionFileCmp_DateLeftToRight:
printff(" -> %s\n", showPath); Print(" -> %s\n", showPath);
break; break;
case ActionFileCmp_DateRightToLeft: case ActionFileCmp_DateRightToLeft:
printff(" <- %s\n", showPath); Print(" <- %s\n", showPath);
break; break;
case ActionFileCmp_MakeRightDirectory: case ActionFileCmp_MakeRightDirectory:
printff(" -D %s\n", showPath); Print(" -D %s\n", showPath);
break; break;
case ActionFileCmp_MakeLeftDirectory: case ActionFileCmp_MakeLeftDirectory:
printff(" D- %s\n", showPath); Print(" D- %s\n", showPath);
break; break;
} }
actionFileNode = actionFileNode->next; actionFileNode = actionFileNode->next;
} }
printff("End\n"); Print("End\n");
} }
void AccionFileNodeAux_CopyDate(char *pathOrig, char *pathDest) { void AccionFileNodeAux_CopyDate(char *pathOrig, char *pathDest) {
@@ -302,42 +309,42 @@ int ActionFileNode_RunList(ActionFileNode actionFileNode, char *pathLeft,
//printff("%s == %s\n",pathIzq,pathDer); //printff("%s == %s\n",pathIzq,pathDer);
break; break;
case ActionFileCmp_LeftToRight: case ActionFileCmp_LeftToRight:
printff(" => %s\n", showPath); Print(" => %s\n", showPath);
AccionFileNodeAux_Copy(fullPathLeft, fullPathRight); numActions++; AccionFileNodeAux_Copy(fullPathLeft, fullPathRight); numActions++;
break; break;
case ActionFileCmp_RightToLeft: case ActionFileCmp_RightToLeft:
printff(" <= %s\n", showPath); Print(" <= %s\n", showPath);
AccionFileNodeAux_Copy(fullPathRight, fullPathLeft); numActions++; AccionFileNodeAux_Copy(fullPathRight, fullPathLeft); numActions++;
break; break;
case ActionFileCmp_DeleteLeft: case ActionFileCmp_DeleteLeft:
printff(" *- %s\n", showPath); Print(" *- %s\n", showPath);
AccionFileNodeAux_Delete(fullPathRight, fullPathLeft); numActions++; AccionFileNodeAux_Delete(fullPathRight, fullPathLeft); numActions++;
break; break;
case ActionFileCmp_DeleteRight: case ActionFileCmp_DeleteRight:
printff(" -* %s\n", showPath); Print(" -* %s\n", showPath);
AccionFileNodeAux_Delete(fullPathLeft, fullPathRight); numActions++; AccionFileNodeAux_Delete(fullPathLeft, fullPathRight); numActions++;
break; break;
case ActionFileCmp_DateLeftToRight: case ActionFileCmp_DateLeftToRight:
printff(" -> %s\n", showPath); Print(" -> %s\n", showPath);
AccionFileNodeAux_CopyDate(fullPathLeft, fullPathRight); numActions++; AccionFileNodeAux_CopyDate(fullPathLeft, fullPathRight); numActions++;
break; break;
case ActionFileCmp_DateRightToLeft: case ActionFileCmp_DateRightToLeft:
printff(" <- %s\n", showPath); Print(" <- %s\n", showPath);
AccionFileNodeAux_CopyDate(fullPathRight, fullPathLeft); numActions++; AccionFileNodeAux_CopyDate(fullPathRight, fullPathLeft); numActions++;
break; break;
case ActionFileCmp_MakeRightDirectory: case ActionFileCmp_MakeRightDirectory:
printff(" -D %s\n", showPath); Print(" -D %s\n", showPath);
AccionFileNodeAux_MakeDir(fullPathLeft, fullPathRight); numActions++; AccionFileNodeAux_MakeDir(fullPathLeft, fullPathRight); numActions++;
break; break;
case ActionFileCmp_MakeLeftDirectory: case ActionFileCmp_MakeLeftDirectory:
printff(" D- %s\n", showPath); Print(" D- %s\n", showPath);
AccionFileNodeAux_MakeDir(fullPathRight, fullPathLeft); numActions++; AccionFileNodeAux_MakeDir(fullPathRight, fullPathLeft); numActions++;
break; break;
} }
actionFileNode = actionFileNode->next; actionFileNode = actionFileNode->next;
} }
printff("End\n"); Print("End\n");
return numActions; return numActions;
} }

View File

@@ -359,33 +359,33 @@ FileNode FileNode_Load(char *filePath) {
} }
void FileNode_PrintNode(FileNode fileNode) { void FileNode_PrintNode(FileNode fileNode) {
printff(FileNode_GetPath(fileNode, NULL)); Print(FileNode_GetPath(fileNode, NULL));
if (fileNode->flags & FileFlag_Normal) { if (fileNode->flags & FileFlag_Normal) {
printff(" File"); Print(" File");
} }
else { else {
printff(" Dir"); Print(" Dir");
} }
printff(" %d", fileNode->status); Print(" %d", fileNode->status);
if (fileNode->status == FileStatus_New) { if (fileNode->status == FileStatus_New) {
printff(" New"); Print(" New");
} }
if (fileNode->status == FileStatus_Modified) { if (fileNode->status == FileStatus_Modified) {
printff(" Modified"); Print(" Modified");
} }
if (fileNode->status == FileStatus_Deleted) { if (fileNode->status == FileStatus_Deleted) {
printff(" Deleted!!!"); Print(" Deleted!!!");
} }
printff("\n"); Print("\n");
if (fileNode->flags&FileFlag_HasSize) { if (fileNode->flags&FileFlag_HasSize) {
printff("\\-Size : %lld\n", fileNode->size); Print("\\-Size : %lld\n", fileNode->size);
} }
if (fileNode->flags&FileFlag_HasTime) { if (fileNode->flags&FileFlag_HasTime) {
printff("\\-Date : "); FileTime_Print(fileNode->fileTime); printff("\n"); Print("\\-Date : "); FileTime_Print(fileNode->fileTime); Print("\n");
} }
if (fileNode->flags&FileFlag_HasCRC) { if (fileNode->flags&FileFlag_HasCRC) {
printff("\\-CRC : [%08X]\n", fileNode->crc); Print("\\-CRC : [%08X]\n", fileNode->crc);
} }
} }
@@ -407,7 +407,7 @@ void FileNode_Print(FileNode fileNode) {
while (fileNodeAux->next == NULL) { while (fileNodeAux->next == NULL) {
fileNodeAux = fileNodeAux->parent; fileNodeAux = fileNodeAux->parent;
if (fileNodeAux == fileNode || fileNodeAux == NULL) { if (fileNodeAux == fileNode || fileNodeAux == NULL) {
printff("End\n"); Print("End\n");
end = 1; end = 1;
break; break;
} }

View File

@@ -57,6 +57,10 @@ FILETIME POSIX_to_FileTime(FileTime fileTime) {
return fileTimeOut; return fileTimeOut;
} }
/////////////////////////////
// FileTime_Get
//
// Gets the current time in POSIX.
FileTime FileTime_Get(char *fileName) { FileTime FileTime_Get(char *fileName) {
HANDLE hFile; HANDLE hFile;
FILETIME ftCreate, ftAccess, ftWrite; FILETIME ftCreate, ftAccess, ftWrite;
@@ -67,6 +71,10 @@ FileTime FileTime_Get(char *fileName) {
return (FileTime_to_POSIX(ftWrite)); return (FileTime_to_POSIX(ftWrite));
} }
/////////////////////////////
// FileTime_Set
//
// Sets the current time in POSIX.
void FileTime_Set(char *fileName, FileTime fileTime) { void FileTime_Set(char *fileName, FileTime fileTime) {
HANDLE hFile; HANDLE hFile;
FILETIME ftWrite; FILETIME ftWrite;
@@ -79,12 +87,20 @@ void FileTime_Set(char *fileName, FileTime fileTime) {
#else #else
/////////////////////////////
// FileTime_Get
//
// Gets the current time in POSIX.
FileTime FileTime_Get(char *fileName) { FileTime FileTime_Get(char *fileName) {
struct stat fs; struct stat fs;
lstat(fileName, &fs); lstat(fileName, &fs);
return (fs.st_mtime); return (fs.st_mtime);
} }
/////////////////////////////
// FileTime_Set
//
// Sets the current time in POSIX.
void FileTime_Set(char *fileName, FileTime t) { void FileTime_Set(char *fileName, FileTime t) {
struct utimbuf utb; struct utimbuf utb;
@@ -95,6 +111,19 @@ void FileTime_Set(char *fileName, FileTime t) {
#endif #endif
/////////////////////////////
// FileTime_Print
//
// Prints the filetime
void FileTime_Print(FileTime fileTime) {
struct tm *tms;
tms = localtime((time_t *)&fileTime);
Print("%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);
}
#ifdef WIN32 #ifdef WIN32
long long File_GetSize(char *fileName) { long long File_GetSize(char *fileName) {
@@ -137,17 +166,6 @@ void File_GetSizeAndTime(char *fileName, long long *size, FileTime *time) {
} }
#endif #endif
void FileTime_Print(FileTime fileTime) {
struct tm *tms;
tms = localtime((time_t *)&fileTime);
printff("%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) { void File_GetName(char *path, char *name) {
int i, j; int i, j;

View File

@@ -14,23 +14,23 @@
void Help(char *exe) { void Help(char *exe) {
char exeFilename[MaxPath]; char exeFilename[MaxPath];
File_GetName(exe, exeFilename); File_GetName(exe, exeFilename);
printff("Usage:\n"); Print("Usage:\n");
printff(" %s info [file] {[file] {..}}\n", exeFilename); Print(" %s info [file] {[file] {..}}\n", exeFilename);
printff(" %s scan [dir] [tree] \n", exeFilename); Print(" %s scan [dir] [tree] \n", exeFilename);
printff(" %s rescan [dir] [tree] \n", exeFilename); Print(" %s rescan [dir] [tree] \n", exeFilename);
printff(" %s read [file] [tree]\n", exeFilename); Print(" %s read [file] [tree]\n", exeFilename);
printff(" %s dir [dir]\n", exeFilename); Print(" %s dir [dir]\n", exeFilename);
printff(" %s check [dir]\n", exeFilename); Print(" %s check [dir]\n", exeFilename);
printff("\n"); Print("\n");
printff(" %s sync [dirA] [dirB]\n", exeFilename); Print(" %s sync [dirA] [dirB]\n", exeFilename);
printff(" %s resync [dirA] [dirB]\n", exeFilename); Print(" %s resync [dirA] [dirB]\n", exeFilename);
printff(" %s synctest [dirA] [dirB]\n", exeFilename); Print(" %s synctest [dirA] [dirB]\n", exeFilename);
printff(" %s resynctest [dirA] [dirB]\n", exeFilename); Print(" %s resynctest [dirA] [dirB]\n", exeFilename);
printff("\n"); Print("\n");
printff(" %s copy [dirA] [dirB]\n", exeFilename); Print(" %s copy [dirA] [dirB]\n", exeFilename);
printff(" %s recopy [dirA] [dirB]\n", exeFilename); Print(" %s recopy [dirA] [dirB]\n", exeFilename);
printff(" %s copytest [dirA] [dirB]\n", exeFilename); Print(" %s copytest [dirA] [dirB]\n", exeFilename);
printff(" %s recopytest [dirA] [dirB]\n", exeFilename); Print(" %s recopytest [dirA] [dirB]\n", exeFilename);
} }
FileNode CheckDir(char *path, int recheck); FileNode CheckDir(char *path, int recheck);
@@ -43,7 +43,7 @@ int main(int argc, char *argv[]) {
return 0; return 0;
} }
printff("\n================================ FileSync ===================================\n"); Print("\n================================ FileSync ===================================\n");
if (!strcmp(argv[1], "info") && argc >= 3) { if (!strcmp(argv[1], "info") && argc >= 3) {
// Informacion de ficheros // Informacion de ficheros
int i; int i;
@@ -59,31 +59,31 @@ int main(int argc, char *argv[]) {
// Scan directory information tree and save // Scan directory information tree and save
long long tScan = Time_GetTime(); long long tScan = Time_GetTime();
FileNode fileNode; FileNode fileNode;
printff("Building FileNode..\n"); Print("Building FileNode..\n");
fileNode = FileNode_Build(argv[2]); fileNode = FileNode_Build(argv[2]);
tScan = Time_GetTime() - tScan; tScan = Time_GetTime() - tScan;
printff("\ttScan :"); PrintElapsedTime(tScan); printff("\n"); Print("\ttScan :"); PrintElapsedTime(tScan); Print("\n");
FileNode_Save(fileNode, argv[3]); FileNode_Save(fileNode, argv[3]);
} }
else if (!strcmp(argv[1], "rescan") && argc == 4) { else if (!strcmp(argv[1], "rescan") && argc == 4) {
// Scan directory information and save tree // Scan directory information and save tree
FileNode fileNode; FileNode fileNode;
printff("Loading FileNode..\n"); Print("Loading FileNode..\n");
fileNode = FileNode_Load(argv[3]); fileNode = FileNode_Load(argv[3]);
if (fileNode) { if (fileNode) {
printff("Rebuilding FileNode..\n"); Print("Rebuilding FileNode..\n");
long long tScan = Time_GetTime(); long long tScan = Time_GetTime();
fileNode = FileNode_Refresh(fileNode, argv[2]); fileNode = FileNode_Refresh(fileNode, argv[2]);
tScan = Time_GetTime() - tScan; tScan = Time_GetTime() - tScan;
printff("\ttScan :"); PrintElapsedTime(tScan); printff("\n"); Print("\ttScan :"); PrintElapsedTime(tScan); Print("\n");
FileNode_Save(fileNode, argv[3]); FileNode_Save(fileNode, argv[3]);
} }
else { else {
printff("Building FileNode..\n"); Print("Building FileNode..\n");
long long tScan = Time_GetTime(); long long tScan = Time_GetTime();
fileNode = FileNode_Build(argv[2]); fileNode = FileNode_Build(argv[2]);
tScan = Time_GetTime() - tScan; tScan = Time_GetTime() - tScan;
printff("\ttScan :"); PrintElapsedTime(tScan); printff("\n"); Print("\ttScan :"); PrintElapsedTime(tScan); Print("\n");
FileNode_Save(fileNode, argv[3]); FileNode_Save(fileNode, argv[3]);
} }
} }
@@ -154,7 +154,7 @@ FileNode CheckDir(char *path, int recheck) {
// Check directory // Check directory
snprintf(dirNodesFile, MaxPath, "%s/"FileNode_Filename, path); snprintf(dirNodesFile, MaxPath, "%s/"FileNode_Filename, path);
if (recheck) { if (recheck) {
printff("Checking Directory.. %s\n", path); Print("Checking Directory.. %s\n", path);
long long tScan = Time_GetTime(); long long tScan = Time_GetTime();
fileNode = FileNode_Load(dirNodesFile); fileNode = FileNode_Load(dirNodesFile);
if (fileNode) { if (fileNode) {
@@ -164,14 +164,14 @@ FileNode CheckDir(char *path, int recheck) {
fileNode = FileNode_Build(path); fileNode = FileNode_Build(path);
} }
tScan = Time_GetTime() - tScan; tScan = Time_GetTime() - tScan;
printff("\ttScan :"); PrintElapsedTime(tScan); printff("\n"); Print("\ttScan :"); PrintElapsedTime(tScan); Print("\n");
FileNode_Save(fileNode, dirNodesFile); FileNode_Save(fileNode, dirNodesFile);
} }
else { else {
printff("Loading Directory.. %s\n", path); Print("Loading Directory.. %s\n", path);
fileNode = FileNode_Load(dirNodesFile); fileNode = FileNode_Load(dirNodesFile);
if (!fileNode) { if (!fileNode) {
printff("Error, no nodesFile.fs\n"); Print("Error, no nodesFile.fs\n");
return NULL; return NULL;
} }
} }
@@ -180,27 +180,30 @@ FileNode CheckDir(char *path, int recheck) {
void PrintStatistics(ActionFileNode actionFileNode) { void PrintStatistics(ActionFileNode actionFileNode) {
ActionQueueStatistics statistics; ActionQueueStatistics statistics;
ActionFileNode_Statistics(actionFileNode, &statistics); if (ActionFileNode_Statistics(actionFileNode, &statistics) == 0) {
printff("Statistics\n"); Print("Noting to do.\n");
return;
}
Print("Statistics\n");
printff(" % 8s % 8s % 8s\n", Print(" % 8s % 8s % 8s\n",
"Read", "Write", "Delete"); "Read", "Write", "Delete");
printff("Left :"); Print("Left :");
PrintDataSize(statistics.readLeft); PrintDataSize(statistics.readLeft);
PrintDataSize(statistics.writeLeft); PrintDataSize(statistics.writeLeft);
PrintDataSize(statistics.deleteLeft); PrintDataSize(statistics.deleteLeft);
printff("\n"); Print("\n");
printff("Right:"); Print("Right:");
PrintDataSize(statistics.readRight); PrintDataSize(statistics.readRight);
PrintDataSize(statistics.writeRight); PrintDataSize(statistics.writeRight);
PrintDataSize(statistics.deleteRight); PrintDataSize(statistics.deleteRight);
printff("\n"); Print("\n");
printff("\n"); Print("\n");
printff("Copy count : % 10d\n", statistics.fullCopyCount); Print("Copy count : % 10d\n", statistics.fullCopyCount);
printff("Date copy count: % 10d\n", statistics.dateCopyCount); Print("Date copy count: % 10d\n", statistics.dateCopyCount);
printff("Directory count: % 10d\n", statistics.directoryCount); Print("Directory count: % 10d\n", statistics.directoryCount);
printff("Delete count : % 10d\n", statistics.deleteCount); Print("Delete count : % 10d\n", statistics.deleteCount);
} }
int Sync(char *pathLeft, char *pathRight, int recheck, int dryRun) { int Sync(char *pathLeft, char *pathRight, int recheck, int dryRun) {
@@ -209,11 +212,11 @@ int Sync(char *pathLeft, char *pathRight, int recheck, int dryRun) {
// Check and load directories // Check and load directories
if (!File_ExistsPath(pathLeft) || !File_IsDirectory(pathLeft)) { if (!File_ExistsPath(pathLeft) || !File_IsDirectory(pathLeft)) {
printff("Error, directory does not exist: %s\n", pathLeft); Print("Error, directory does not exist: %s\n", pathLeft);
return 0; return 0;
} }
if (!File_ExistsPath(pathRight) || !File_IsDirectory(pathRight)) { if (!File_ExistsPath(pathRight) || !File_IsDirectory(pathRight)) {
printff("Error, directory does not exist: %s\n", pathRight); Print("Error, directory does not exist: %s\n", pathRight);
return 0; return 0;
} }
fileNodeLeft = CheckDir(pathLeft, recheck); fileNodeLeft = CheckDir(pathLeft, recheck);
@@ -227,11 +230,11 @@ int Sync(char *pathLeft, char *pathRight, int recheck, int dryRun) {
// Build actions // Build actions
long long tBuild = Time_GetTime(); long long tBuild = Time_GetTime();
printff("Building action list.. \n"); Print("Building action list.. \n");
ActionFileNode actionFileNode = NULL; ActionFileNode actionFileNode = NULL;
actionFileNode = ActionFileNode_BuildSync(fileNodeLeft, fileNodeRight); actionFileNode = ActionFileNode_BuildSync(fileNodeLeft, fileNodeRight);
tBuild = Time_GetTime() - tBuild; tBuild = Time_GetTime() - tBuild;
printff("\ttBuild:"); PrintElapsedTime(tBuild); printff("\n"); Print("\ttBuild:"); PrintElapsedTime(tBuild); Print("\n");
if (dryRun) { if (dryRun) {
// Show action list // Show action list
@@ -255,11 +258,11 @@ int Copy(char *pathLeft, char *pathRight, int reCheck, int dryRun) {
// Check and load directories // Check and load directories
if (!File_ExistsPath(pathLeft) || !File_IsDirectory(pathLeft)) { if (!File_ExistsPath(pathLeft) || !File_IsDirectory(pathLeft)) {
printff("Error, directory does not exist: %s\n", pathLeft); Print("Error, directory does not exist: %s\n", pathLeft);
return 0; return 0;
} }
if (!File_ExistsPath(pathRight) || !File_IsDirectory(pathRight)) { if (!File_ExistsPath(pathRight) || !File_IsDirectory(pathRight)) {
printff("Error, directory does not exist: %s\n", pathRight); Print("Error, directory does not exist: %s\n", pathRight);
return 0; return 0;
} }
fileNodeLeft = CheckDir(pathLeft, reCheck); fileNodeLeft = CheckDir(pathLeft, reCheck);
@@ -273,11 +276,11 @@ int Copy(char *pathLeft, char *pathRight, int reCheck, int dryRun) {
// Build actions // Build actions
long long tBuild = Time_GetTime(); long long tBuild = Time_GetTime();
printff("Building action list.. \n"); Print("Building action list.. \n");
ActionFileNode actionFileNode = NULL; ActionFileNode actionFileNode = NULL;
actionFileNode = ActionFileNode_BuildCopy(fileNodeLeft, fileNodeRight); actionFileNode = ActionFileNode_BuildCopy(fileNodeLeft, fileNodeRight);
tBuild = Time_GetTime() - tBuild; tBuild = Time_GetTime() - tBuild;
printff("\ttBuild:"); PrintElapsedTime(tBuild); printff("\n"); Print("\ttBuild:"); PrintElapsedTime(tBuild); Print("\n");
if (dryRun) { if (dryRun) {
// Show action list // Show action list

View File

@@ -5,6 +5,10 @@
#include "util.h" #include "util.h"
/////////////////////////////
// String_Copy
//
// Copies a string.
char *String_Copy(char *str) { char *String_Copy(char *str) {
char *strnew; char *strnew;
int len; int len;
@@ -16,7 +20,6 @@ char *String_Copy(char *str) {
return (strnew); return (strnew);
} }
#if WIN32 #if WIN32
#include <windows.h> #include <windows.h>
// WIN32 // WIN32
@@ -95,21 +98,21 @@ long long Time_GetCurrentTime() {
// Prints the elapsed time (input in microseconds (us)) // Prints the elapsed time (input in microseconds (us))
int PrintElapsedTime(long long time) { int PrintElapsedTime(long long time) {
if (time < 1000) { if (time < 1000) {
return printff("%8lld us", time); return Print("%8lld us", time);
} }
double msTime = (double)time / 1000; double msTime = (double)time / 1000;
if (msTime < 1000) { if (msTime < 1000) {
return printff("% 8.3f ms", msTime); return Print("% 8.3f ms", msTime);
} }
double seconds = msTime / 1000; double seconds = msTime / 1000;
if (seconds < 60) { if (seconds < 60) {
return printff("% 8.3f s", seconds); return Print("% 8.3f s", seconds);
} }
int minutes = (int)seconds / 60; int minutes = (int)seconds / 60;
seconds = seconds - (minutes * 60); seconds = seconds - (minutes * 60);
int hours = minutes / 60; int hours = minutes / 60;
minutes = minutes % 60; minutes = minutes % 60;
return printff("%02d:%02d:%06.3f", hours, minutes, seconds); return Print("%02d:%02d:%06.3f", hours, minutes, seconds);
} }
///////////////////////////// /////////////////////////////
@@ -118,25 +121,29 @@ int PrintElapsedTime(long long time) {
// Prints the data size (input in bytes) // Prints the data size (input in bytes)
int PrintDataSize(long long size) { int PrintDataSize(long long size) {
if (size < 1024) { if (size < 1024) {
return printff("%8lld B ", size); return Print("%8lld B ", size);
} }
double kibSize = (double)size / 1024; double kibSize = (double)size / 1024;
if (kibSize < 1024) { if (kibSize < 1024) {
return printff("% 8.3f KiB", kibSize); return Print("% 8.3f KiB", kibSize);
} }
double mibSize = kibSize / 1024; double mibSize = kibSize / 1024;
if (mibSize < 1024) { if (mibSize < 1024) {
return printff("% 8.3f MiB", mibSize); return Print("% 8.3f MiB", mibSize);
} }
double gibSize = mibSize / 1024; double gibSize = mibSize / 1024;
if (gibSize < 1024) { if (gibSize < 1024) {
return printff("% 8.3f GiB", gibSize); return Print("% 8.3f GiB", gibSize);
} }
double tibSize = gibSize / 1024; double tibSize = gibSize / 1024;
return printff("% 8.3f TiB", tibSize); return Print("% 8.3f TiB", tibSize);
} }
int printff(char *fmt, ...) { /////////////////////////////
// Print
//
// Prints the formated text screen
int Print(char *fmt, ...) {
va_list ap; va_list ap;
int n; int n;

View File

@@ -4,6 +4,10 @@
#include <stdlib.h> #include <stdlib.h>
#include <stdarg.h> #include <stdarg.h>
/////////////////////////////
// String_Copy
//
// Copies a string.
char *String_Copy(char *str); char *String_Copy(char *str);
///////////////////////////// /////////////////////////////
@@ -37,6 +41,10 @@ int PrintElapsedTime(long long time);
// Prints the data size (input in bytes) // Prints the data size (input in bytes)
int PrintDataSize(long long size); int PrintDataSize(long long size);
int printff(char *fmt, ...); /////////////////////////////
// Print
//
// Prints the formated text screen
int Print(char *fmt, ...);
#endif #endif