#include #include "fsactions.h" #include "../common/common.h" #include "../../libs/fatfs/ff.h" #include "../../gfx/gfx.h" #include "../gfx/gfxutils.h" #include "../utils/utils.h" #include "../../mem/heap.h" #include "../../hid/hid.h" #include "../../utils/btn.h" #include "fsutils.h" int fsact_copy(const char *locin, const char *locout, u8 options){ FIL in, out; FILINFO in_info; u64 sizeRemaining, toCopy; u8 *buff, toPrint = options & COPY_MODE_PRINT, toCancel = options & COPY_MODE_CANCEL; u32 x, y, i = 11; int res; gfx_con_getpos(&x, &y); if (!strcmp(locin, locout)){ gfx_errDisplay("copy", ERR_SAME_LOC, 1); return 1; } if ((res = f_open(&in, locin, FA_READ | FA_OPEN_EXISTING))){ gfx_errDisplay("copy", res, 2); return 1; } if ((res = f_stat(locin, &in_info))){ gfx_errDisplay("copy", res, 3); return 1; } if ((res = f_open(&out, locout, FA_CREATE_ALWAYS | FA_WRITE))){ gfx_errDisplay("copy", res, 4); return 1; } if (toPrint){ SWAPCOLOR(COLOR_GREEN); gfx_printf("[ ]"); x += 16; gfx_con_setpos(x, y); } buff = malloc (BUFSIZE); sizeRemaining = f_size(&in); const u64 totalsize = sizeRemaining; while (sizeRemaining > 0){ toCopy = MIN(sizeRemaining, BUFSIZE); if ((res = f_read(&in, buff, toCopy, NULL))){ gfx_errDisplay("copy", res, 5); break; } if ((res = f_write(&out, buff, toCopy, NULL))){ gfx_errDisplay("copy", res, 6); break; } sizeRemaining -= toCopy; if (toPrint && (i > 16 || !sizeRemaining)){ gfx_printf("%3d%%", (u32)(((totalsize - sizeRemaining) * 100) / totalsize)); gfx_con_setpos(x, y); } if (toCancel && i > 16){ if (btn_read() & (BTN_VOL_DOWN | BTN_VOL_UP)){ f_unlink(locout); break; } } if (options){ if (i++ > 16) i = 0; } } if (toPrint){ RESETCOLOR; gfx_con_setpos(x - 16, y); } f_close(&in); f_close(&out); free(buff); f_chmod(locout, in_info.fattrib, 0x3A); f_stat(locin, &in_info); //somehow stops fatfs from being weird return res; } int fsact_del_recursive(char *path){ DIR dir; FILINFO fno; int res; u32 x, y; char *localpath = NULL; gfx_con_getpos(&x, &y); utils_copystring(path, &localpath); if ((res = f_opendir(&dir, localpath))){ gfx_errDisplay("del_recursive", res, 1); return 1; } while (!f_readdir(&dir, &fno) && fno.fname[0]){ if (fno.fattrib & AM_DIR){ fsact_del_recursive(fsutil_getnextloc(localpath, fno.fname)); } else { SWAPCOLOR(COLOR_RED); gfx_printf("\r"); gfx_printandclear(fno.fname, 37, 720); if ((res = f_unlink(fsutil_getnextloc(localpath, fno.fname)))){ gfx_errDisplay("del_recursive", res, 2); return 1; } } } f_closedir(&dir); if ((res = f_unlink(localpath))){ gfx_errDisplay("del_recursive", res, 3); return 1; } free(localpath); return 0; } int fsact_copy_recursive(char *path, char *dstpath){ DIR dir; FILINFO fno; int res; u32 x, y; char *startpath = NULL, *destpath = NULL, *destfoldername = NULL, *temp = NULL; gfx_con_getpos(&x, &y); utils_copystring(path, &startpath); utils_copystring(strrchr(path, '/') + 1, &destfoldername); utils_copystring(fsutil_getnextloc(dstpath, destfoldername), &destpath); if ((res = f_opendir(&dir, startpath))){ gfx_errDisplay("copy_recursive", res, 1); return 1; } f_mkdir(destpath); while (!f_readdir(&dir, &fno) && fno.fname[0]){ if (fno.fattrib & AM_DIR){ fsact_copy_recursive(fsutil_getnextloc(startpath, fno.fname), destpath); } else { SWAPCOLOR(COLOR_GREEN); gfx_printf("\r"); gfx_printandclear(fno.fname, 37, 720); utils_copystring(fsutil_getnextloc(startpath, fno.fname), &temp); if ((res = fsact_copy(temp, fsutil_getnextloc(destpath, fno.fname), COPY_MODE_PRINT))){ gfx_errDisplay("copy_recursive", res, 2); return 1; } free(temp); } } f_closedir(&dir); if ((res = (f_stat(startpath, &fno)))){ gfx_errDisplay("copy_recursive", res, 3); return 1; } if ((res = f_chmod(destpath, fno.fattrib, 0x3A))){ gfx_errDisplay("copy_recursive", res, 4); return 1; } free(startpath); free(destpath); free(destfoldername); return 0; }