aboutsummaryrefslogtreecommitdiffstats
path: root/Library/UefiShellUfmCommandLib
diff options
context:
space:
mode:
Diffstat (limited to 'Library/UefiShellUfmCommandLib')
-rw-r--r--Library/UefiShellUfmCommandLib/UefiShellUfmCommandLib.c2
-rw-r--r--Library/UefiShellUfmCommandLib/actions.c47
-rw-r--r--Library/UefiShellUfmCommandLib/actions.h1
3 files changed, 49 insertions, 1 deletions
diff --git a/Library/UefiShellUfmCommandLib/UefiShellUfmCommandLib.c b/Library/UefiShellUfmCommandLib/UefiShellUfmCommandLib.c
index 09298d8..1920b13 100644
--- a/Library/UefiShellUfmCommandLib/UefiShellUfmCommandLib.c
+++ b/Library/UefiShellUfmCommandLib/UefiShellUfmCommandLib.c
@@ -24,7 +24,7 @@ STATIC CONST struct shortcut shortcuts[] = {
{ACTION_CMD, {SCAN_F2, 0x0}, edit, L"2", L"Edit"},
{ACTION_CMD, {SCAN_F3, 0x0}, hexedit, L"3", L"Hex"},
{ACTION_CMD, {SCAN_F4, 0x0}, do_nothing, L"4", L"Copy"},
- {ACTION_CMD, {SCAN_F5, 0x0}, do_nothing, L"5", L"RenMov"},
+ {ACTION_CMD, {SCAN_F5, 0x0}, mv, L"5", L"RenMov"},
{ACTION_CMD, {SCAN_F6, 0x0}, mkdir, L"6", L"Mkdir"},
{ACTION_CMD, {SCAN_F7, 0x0}, rm, L"7", L"Rm"},
{ACTION_CMD, {SCAN_F8, 0x0}, do_nothing, L"8", L""},
diff --git a/Library/UefiShellUfmCommandLib/actions.c b/Library/UefiShellUfmCommandLib/actions.c
index aca0e7b..596e7c4 100644
--- a/Library/UefiShellUfmCommandLib/actions.c
+++ b/Library/UefiShellUfmCommandLib/actions.c
@@ -24,6 +24,8 @@
#define UPANEL ((PANEL == LEFT_PANEL) ? RIGHT_PANEL : LEFT_PANEL)
#define FILECOUNT_LENGTH 20
+STATIC CONST CHAR16 mv_title[] = L" Move ";
+STATIC CONST CHAR16 mv_label[] = L"Move %u files/directories to:";
STATIC CONST CHAR16 rm_title[] = L" Delete ";
STATIC CONST CHAR16 rm_label[] = L"Delete %u files/directories?";
STATIC CONST CHAR16 mkdir_title[] = L" Create a new directory ";
@@ -128,6 +130,51 @@ BOOLEAN hexedit(VOID)
return TRUE;
}
+BOOLEAN mv(VOID)
+{
+ struct dbox_ctx *dbox;
+ UINTN i, size, line = PANEL->curline;
+ CHAR16 *label;
+ EFI_SHELL_FILE_INFO *file;
+ EFI_STATUS status;
+ BOOLEAN status_op;
+
+ if(!PANEL->cwd)
+ return FALSE;
+
+ if(PANEL->marked < 1)
+ return FALSE;
+
+ size = (StrLen(mv_label) + FILECOUNT_LENGTH + 1) * sizeof(CHAR16);
+ label = AllocatePool(size);
+ if(!label)
+ return FALSE;
+
+ UnicodeSPrint(label, size, mv_label, PANEL->marked);
+ dbox = dbox_alloc(fm_ctx.scr, mv_title, label, TRUE, UPANEL->cwd);
+
+ dbox_refresh(dbox);
+ status_op = dbox_handle(dbox);
+ if(status_op) {
+ for(i = 1; i <= PANEL->dirs->len; i++) {
+ if(PANEL->dirs->marked[i-1] == FALSE)
+ continue;
+
+ file = dirl_getn(PANEL->dirs, i);
+ status = copy_file(file->FullName, UPANEL->cwd); // NOT UPANEL->cwd!!!
+ if(!EFI_ERROR(status))
+ delete_file(file);
+ }
+ panel_cd_to(PANEL, PANEL->cwd);
+ panel_move_cursor(PANEL, (line > PANEL->dirs->len) ? PANEL->dirs->len : line);
+ }
+
+ redraw();
+ FreePool(label);
+ dbox_release(dbox);
+ return TRUE;
+}
+
BOOLEAN mkdir(VOID)
{
struct dbox_ctx *dbox;
diff --git a/Library/UefiShellUfmCommandLib/actions.h b/Library/UefiShellUfmCommandLib/actions.h
index 0bb301e..1080678 100644
--- a/Library/UefiShellUfmCommandLib/actions.h
+++ b/Library/UefiShellUfmCommandLib/actions.h
@@ -24,6 +24,7 @@ BOOLEAN execute(VOID);
BOOLEAN mark(VOID);
BOOLEAN edit(VOID);
BOOLEAN hexedit(VOID);
+BOOLEAN mv(VOID);
BOOLEAN mkdir(VOID);
BOOLEAN rm(VOID);
BOOLEAN show_filesystems(VOID);