New "copy" action. Minimizes the actions to copy a directory tree.

This commit is contained in:
2013-06-10 21:02:15 +02:00
parent f4f668d82f
commit 50021a2ec7
3 changed files with 242 additions and 52 deletions

View File

@@ -423,7 +423,7 @@ void AccionFileNode_CheckPair(
} }
AccionFileNode *AccionFileNode_Build( AccionFileNode *AccionFileNode_BuildSync(
FileNode *izquierda,FileNode *derecha) FileNode *izquierda,FileNode *derecha)
{ {
AccionFileNode *afnRaiz=AccionFileNode_CrearNormal(izquierda,derecha); AccionFileNode *afnRaiz=AccionFileNode_CrearNormal(izquierda,derecha);
@@ -437,6 +437,111 @@ AccionFileNode *AccionFileNode_Build(
void AccionFileNode_Copy(
FileNode *fnIzq,FileNode *fnDer,AccionFileNode **afnCola)
{
AccionFileNode *afnNew=AccionFileNode_CrearNormal(fnIzq,fnDer);
if(!fnIzq && !fnDer){
AccionFileNode_Destruir(afnNew);
return;
}
if(!fnIzq && fnDer){
if(fnDer->flags&FileFlag_Directorio){
AccionFileNode_CompareChilds(afnNew,afnCola,
AccionFileNode_DeletePair);
}
if(fnDer->estado!=EstadoFichero_Borrado){
afnNew->accion=AccionFileCmp_BorrarDerecha;
}else{
afnNew->accion=AccionFileCmp_Nada;
}
(*afnCola)->sig=afnNew;
(*afnCola)=afnNew;
}
if(fnIzq && !fnDer){
if(fnIzq->estado!=EstadoFichero_Borrado){
if(fnIzq->flags&FileFlag_Directorio){
afnNew->accion=AccionFileCmp_CrearDirDerecha;
(*afnCola)->sig=afnNew;
(*afnCola)=afnNew;
AccionFileNode_CompareChilds(afnNew,afnCola,
AccionFileNode_Copy);
afnNew=AccionFileNode_CrearNormal(fnIzq,fnDer);
if(abs(fnIzq->ft-fnDer->ft)<=1){ // appox. equal
afnNew->accion=AccionFileCmp_Nada;
}else{
afnNew->accion=AccionFileCmp_FechaIzquierdaADerecha;
}
}else{
afnNew->accion=AccionFileCmp_IzquierdaADerecha;
}
}else{
afnNew->accion=AccionFileCmp_Nada;
}
(*afnCola)->sig=afnNew;
(*afnCola)=afnNew;
}
if(fnIzq && fnDer){
if(fnIzq->flags&FileFlag_Directorio ||
fnDer->flags&FileFlag_Directorio)
{
if(fnIzq->estado!=EstadoFichero_Borrado){
AccionFileNode_CompareChilds(afnNew,afnCola,
AccionFileNode_Copy);
if(abs(fnIzq->ft-fnDer->ft)<=1){ // appox. equal
afnNew->accion=AccionFileCmp_Nada;
}else{
afnNew->accion=AccionFileCmp_FechaIzquierdaADerecha;
}
}else{
AccionFileNode_CompareChilds(afnNew,afnCola,
AccionFileNode_DeletePair);
afnNew->accion=AccionFileCmp_BorrarDerecha;
}
}else{
if(fnIzq->estado!=EstadoFichero_Borrado){
if(abs(fnIzq->ft-fnDer->ft)<=1){ // appox. equal
afnNew->accion=AccionFileCmp_Nada;
}else{
afnNew->accion=AccionFileCmp_IzquierdaADerecha;
}
}else{
if(fnDer->estado!=EstadoFichero_Borrado){
afnNew->accion=AccionFileCmp_BorrarDerecha;
}
}
}
(*afnCola)->sig=afnNew;
(*afnCola)=afnNew;
}
}
AccionFileNode *AccionFileNode_BuildCopy(
FileNode *izquierda,FileNode *derecha)
{
AccionFileNode *afnRaiz=AccionFileNode_CrearNormal(izquierda,derecha);
AccionFileNode *afnCola=afnRaiz;
AccionFileNode_CompareChilds(afnRaiz,&afnCola,
AccionFileNode_Copy);
return afnRaiz;
}
void AccionFileNode_Print(AccionFileNode *afn){ void AccionFileNode_Print(AccionFileNode *afn){
char showPath[MaxPath]; char showPath[MaxPath];
while(afn!=NULL){ while(afn!=NULL){

View File

@@ -29,8 +29,8 @@ AccionFileNode *AccionFileNode_Crear();
void AccionFileNode_Destruir(AccionFileNode *afn); void AccionFileNode_Destruir(AccionFileNode *afn);
AccionFileNode *AccionFileNode_CrearNormal(FileNode *fnIzq,FileNode *fnDer); AccionFileNode *AccionFileNode_CrearNormal(FileNode *fnIzq,FileNode *fnDer);
AccionFileNode *AccionFileNode_Build(FileNode *izquierda,FileNode *derecha); AccionFileNode *AccionFileNode_BuildSync(FileNode *izquierda,FileNode *derecha);
AccionFileNode *AccionFileNode_BuildCopy(FileNode *izquierda,FileNode *derecha);
void AccionFileNode_Print(AccionFileNode *afn); void AccionFileNode_Print(AccionFileNode *afn);

179
main.c
View File

@@ -12,16 +12,26 @@ void help(char *exe){
char exeFilename[MaxPath]; char exeFilename[MaxPath];
File_GetName(exe,exeFilename); File_GetName(exe,exeFilename);
printf("Modo de uso:\n"); printf("Modo de uso:\n");
printf("\t%s info [file] {[file] {..}}\n",exeFilename); printf(" %s info [file] {[file] {..}}\n",exeFilename);
printf("\t%s scan [dir] [tree] \n",exeFilename); printf(" %s scan [dir] [tree] \n",exeFilename);
printf("\t%s rescan [dir] [tree] \n",exeFilename); printf(" %s rescan [dir] [tree] \n",exeFilename);
printf("\t%s read [file] [tree]\n",exeFilename); printf(" %s read [file] [tree]\n",exeFilename);
printf("\t%s dir [dir]\n",exeFilename); printf(" %s dir [dir]\n",exeFilename);
printf("\t%s sync [dirIzquierda] [dirDerecha]\n",exeFilename); printf("\n");
printf(" %s sync [dirIzquierda] [dirDerecha]\n",exeFilename);
printf(" %s resync [dirIzquierda] [dirDerecha]\n",exeFilename);
printf(" %s synctest [dirIzquierda] [dirDerecha]\n",exeFilename);
printf(" %s resynctest [dirIzquierda] [dirDerecha]\n",exeFilename);
printf("\n");
printf(" %s copy [dirIzquierda] [dirDerecha]\n",exeFilename);
printf(" %s recopy [dirIzquierda] [dirDerecha]\n",exeFilename);
printf(" %s copytest [dirIzquierda] [dirDerecha]\n",exeFilename);
printf(" %s recopytest [dirIzquierda] [dirDerecha]\n",exeFilename);
} }
int sync(char *pathIzquierda,char *pathDerecha,int dryrun); FileNode *checkDir(char *path,int recheck);
int sync(char *pathIzquierda,char *pathDerecha,int recheck,int dryrun);
int main(int argc,char *argv[]){ int main(int argc,char *argv[]){
@@ -30,6 +40,11 @@ int main(int argc,char *argv[]){
FileTime ft; FileTime ft;
int i; int i;
if(argc<2){
help(argv[0]);
return 0;
}
if(!strcmp(argv[1],"info") && argc>=3){ if(!strcmp(argv[1],"info") && argc>=3){
// Informacion de ficheros // Informacion de ficheros
for(i=2;i<argc;i++){ for(i=2;i<argc;i++){
@@ -75,34 +90,61 @@ int main(int argc,char *argv[]){
char dirNodesFile[MaxPath]; char dirNodesFile[MaxPath];
FileNode *fn; FileNode *fn;
printf("Checking Directory.. %s\n",path); fn=checkDir(path,1);
if(File_ExistePath(path) && File_EsDirectorio(path)){
// Get the FileNode from the dir
snprintf(dirNodesFile,MaxPath,"%s/"FileNode_Filename,path);
fn=FileNode_Load(dirNodesFile);
if(fn){
fn=FileNode_Refresh(fn,path);
}else{
fn=FileNode_Build(path);
}
if(fn){ if(fn){
FileNode_Print(fn); FileNode_Print(fn);
FileNode_Save(fn,dirNodesFile);
}
} }
}else }else
if(!strcmp(argv[1],"sync") && argc==4){ if(!strcmp(argv[1],"sync") && argc==4){
// Sincronizar dos directorios // Sincronizar dos directorios
char *pathIzquierda=argv[2]; char *pathIzquierda=argv[2];
char *pathDerecha=argv[3]; char *pathDerecha=argv[3];
sync(pathIzquierda,pathDerecha,0); sync(pathIzquierda,pathDerecha,1,0);
}else
if(!strcmp(argv[1],"resync") && argc==4){
// Sincronizar dos directorios
char *pathIzquierda=argv[2];
char *pathDerecha=argv[3];
sync(pathIzquierda,pathDerecha,1,0);
}else }else
if(!strcmp(argv[1],"synctest") && argc==4){ if(!strcmp(argv[1],"synctest") && argc==4){
// Sincronizar dos directorios // Sincronizar dos directorios
char *pathIzquierda=argv[2]; char *pathIzquierda=argv[2];
char *pathDerecha=argv[3]; char *pathDerecha=argv[3];
sync(pathIzquierda,pathDerecha,1); sync(pathIzquierda,pathDerecha,1,1);
}else
if(!strcmp(argv[1],"resynctest") && argc==4){
// Sincronizar dos directorios
char *pathIzquierda=argv[2];
char *pathDerecha=argv[3];
sync(pathIzquierda,pathDerecha,0,1);
}else
if(!strcmp(argv[1],"copy") && argc==4){
// Sincronizar dos directorios
char *pathIzquierda=argv[2];
char *pathDerecha=argv[3];
copy(pathIzquierda,pathDerecha,1,0);
}else
if(!strcmp(argv[1],"recopy") && argc==4){
// Sincronizar dos directorios
char *pathIzquierda=argv[2];
char *pathDerecha=argv[3];
copy(pathIzquierda,pathDerecha,1,0);
}else
if(!strcmp(argv[1],"copytest") && argc==4){
// Sincronizar dos directorios
char *pathIzquierda=argv[2];
char *pathDerecha=argv[3];
copy(pathIzquierda,pathDerecha,1,1);
}else
if(!strcmp(argv[1],"recopytest") && argc==4){
// Sincronizar dos directorios
char *pathIzquierda=argv[2];
char *pathDerecha=argv[3];
copy(pathIzquierda,pathDerecha,0,1);
}else{ }else{
help(argv[0]); help(argv[0]);
@@ -112,11 +154,38 @@ int main(int argc,char *argv[]){
} }
int sync(char *pathIzquierda,char *pathDerecha,int dryrun){
FileNode *checkDir(char *path,int recheck){
char dirNodesFile[MaxPath];
FileNode *fn;
// Comprobar directorio
snprintf(dirNodesFile,MaxPath,"%s/"FileNode_Filename,path);
if(recheck){
printf("Checking Directory.. %s\n",path);
fn=FileNode_Load(dirNodesFile);
if(fn){
fn=FileNode_Refresh(fn,path);
}else{
fn=FileNode_Build(path);
}
FileNode_Save(fn,dirNodesFile);
}else{
printf("Loading Directory.. %s\n",path);
fn=FileNode_Load(dirNodesFile);
if(!fn){
printf("Error, no nodesFile.fs\n");
return NULL;
}
}
return fn;
}
int sync(char *pathIzquierda,char *pathDerecha,int recheck,int dryrun){
char dirNodesFileIzq[MaxPath]; char dirNodesFileIzq[MaxPath];
char dirNodesFileDer[MaxPath]; char dirNodesFileDer[MaxPath];
FileNode *fnIzquierda,*fnDerecha; FileNode *fnIzquierda,*fnDerecha;
// Comprobar y cargar directorios
if(!File_ExistePath(pathIzquierda) || !File_EsDirectorio(pathIzquierda)){ if(!File_ExistePath(pathIzquierda) || !File_EsDirectorio(pathIzquierda)){
printf("Error, directory does not exist: %s\n",pathIzquierda); printf("Error, directory does not exist: %s\n",pathIzquierda);
return 0; return 0;
@@ -125,35 +194,16 @@ int sync(char *pathIzquierda,char *pathDerecha,int dryrun){
printf("Error, directory does not exist: %s\n",pathDerecha); printf("Error, directory does not exist: %s\n",pathDerecha);
return 0; return 0;
} }
fnIzquierda=checkDir(pathIzquierda,recheck);
if(!fnIzquierda){return 0;}
fnDerecha=checkDir(pathDerecha,recheck);
if(!fnDerecha){return 0;}
// Comprobar directorio izquierdo
printf("Checking Directory.. %s\n",pathIzquierda);
snprintf(dirNodesFileIzq,MaxPath,"%s/"FileNode_Filename,
pathIzquierda);
fnIzquierda=FileNode_Load(dirNodesFileIzq);
if(fnIzquierda){
fnIzquierda=FileNode_Refresh(fnIzquierda,pathIzquierda);
}else{
fnIzquierda=FileNode_Build(pathIzquierda);
}
FileNode_Save(fnIzquierda,dirNodesFileIzq);
// Comprobar directorui derecho
printf("Checking Directory.. %s\n",pathDerecha);
snprintf(dirNodesFileDer,MaxPath,"%s/"FileNode_Filename,
pathDerecha);
fnDerecha=FileNode_Load(dirNodesFileDer);
if(fnDerecha){
fnDerecha=FileNode_Refresh(fnDerecha,pathDerecha);
}else{
fnDerecha=FileNode_Build(pathDerecha);
}
FileNode_Save(fnDerecha,dirNodesFileDer);
// Construir acciones // Construir acciones
printf("Building action list.. \n"); printf("Building action list.. \n");
AccionFileNode *afn=NULL; AccionFileNode *afn=NULL;
afn=AccionFileNode_Build(fnIzquierda,fnDerecha); afn=AccionFileNode_BuildSync(fnIzquierda,fnDerecha);
if(dryrun){ if(dryrun){
// Mostrar lista de acciones // Mostrar lista de acciones
@@ -166,3 +216,38 @@ int sync(char *pathIzquierda,char *pathDerecha,int dryrun){
return(1); return(1);
} }
int copy(char *pathIzquierda,char *pathDerecha,int recheck,int dryrun){
char dirNodesFileIzq[MaxPath];
char dirNodesFileDer[MaxPath];
FileNode *fnIzquierda,*fnDerecha;
// Comprobar y cargar directorios
if(!File_ExistePath(pathIzquierda) || !File_EsDirectorio(pathIzquierda)){
printf("Error, directory does not exist: %s\n",pathIzquierda);
return 0;
}
if(!File_ExistePath(pathDerecha) || !File_EsDirectorio(pathDerecha)){
printf("Error, directory does not exist: %s\n",pathDerecha);
return 0;
}
fnIzquierda=checkDir(pathIzquierda,recheck);
if(!fnIzquierda){return 0;}
fnDerecha=checkDir(pathDerecha,recheck);
if(!fnDerecha){return 0;}
// Construir acciones
printf("Building action list.. \n");
AccionFileNode *afn=NULL;
afn=AccionFileNode_BuildCopy(fnIzquierda,fnDerecha);
if(dryrun){
// Mostrar lista de acciones
AccionFileNode_Print(afn);
}else{
// Ejecutar lista de acciones
AccionFileNode_RunList(afn,pathIzquierda,pathDerecha);
}
return(1);
}