Revision: 14972
          http://sourceforge.net/p/edk2/code/14972
Author:   jcarsey
Date:     2013-12-12 18:42:18 +0000 (Thu, 12 Dec 2013)
Log Message:
-----------
ShellPkg: refactor out leading and trailing space trimming

Contributed-under: TianoCore Contribution Agreement 1.0
Signed-off-by: Jaben Carsey <[email protected]>
Reviewed-by: Erik Bjorge <[email protected]>

Modified Paths:
--------------
    trunk/edk2/ShellPkg/Application/Shell/Shell.c

Modified: trunk/edk2/ShellPkg/Application/Shell/Shell.c
===================================================================
--- trunk/edk2/ShellPkg/Application/Shell/Shell.c       2013-12-12 17:55:37 UTC 
(rev 14971)
+++ trunk/edk2/ShellPkg/Application/Shell/Shell.c       2013-12-12 18:42:18 UTC 
(rev 14972)
@@ -71,6 +71,36 @@
 STATIC CONST CHAR16 mStartupScript[]        = L"startup.nsh";
 
 /**
+  Cleans off leading and trailing spaces and tabs
+
+  @param[in] String pointer to the string to trim them off
+**/
+EFI_STATUS
+EFIAPI
+TrimSpaces(
+  IN CHAR16 **String
+  )
+{
+  ASSERT(String != NULL);
+  ASSERT(*String!= NULL);
+  //
+  // Remove any spaces and tabs at the beginning of the (*String).
+  //
+  while (((*String)[0] == L' ') || ((*String)[0] == L'\t')) {
+    CopyMem((*String), (*String)+1, StrSize((*String)) - sizeof((*String)[0]));
+  }
+
+  //
+  // Remove any spaces at the end of the (*String).
+  //
+  while ((*String)[StrLen((*String))-1] == L' ') {
+    (*String)[StrLen((*String))-1] = CHAR_NULL;
+  }
+
+  return (EFI_SUCCESS);
+}
+
+/**
   Find a command line contains a split operation
 
   @param[in] CmdLine      The command line to parse.
@@ -1460,12 +1490,7 @@
     return (EFI_OUT_OF_RESOURCES);
   }
 
-  //
-  // Remove any spaces and tabs at the beginning of the string.
-  //
-  while ((CleanOriginal[0] == L' ') || (CleanOriginal[0] == L'\t')) {
-    CopyMem(CleanOriginal, CleanOriginal+1, StrSize(CleanOriginal) - 
sizeof(CleanOriginal[0]));
-  }
+  TrimSpaces(&CleanOriginal);
 
   //
   // Handle case that passed in command line is just 1 or more " " characters.
@@ -1478,13 +1503,6 @@
     return (EFI_SUCCESS);
   }
 
-  //
-  // Remove any spaces at the end of the string.
-  //
-  while (CleanOriginal[StrLen(CleanOriginal)-1] == L' ') {
-    CleanOriginal[StrLen(CleanOriginal)-1] = CHAR_NULL;
-  }
-
   CommandName = NULL;
   if (StrStr(CleanOriginal, L" ") == NULL){
     StrnCatGrow(&CommandName, NULL, CleanOriginal, 0);
@@ -1530,12 +1548,7 @@
     return (EFI_OUT_OF_RESOURCES);
   }
 
-  while (PostVariableCmdLine[StrLen(PostVariableCmdLine)-1] == L' ') {
-    PostVariableCmdLine[StrLen(PostVariableCmdLine)-1] = CHAR_NULL;
-  }
-  while (PostVariableCmdLine[0] == L' ') {
-    CopyMem(PostVariableCmdLine, PostVariableCmdLine+1, 
StrSize(PostVariableCmdLine) - sizeof(PostVariableCmdLine[0]));
-  }
+  TrimSpaces(&PostVariableCmdLine);
 
   //
   // We dont do normal processing with a split command line (output from one 
command input to another)
@@ -1583,13 +1596,8 @@
         ShellPrintHiiEx(-1, -1, NULL, STRING_TOKEN (STR_SHELL_INVALID_REDIR), 
ShellInfoObject.HiiHandle);
       }
     } else {
-      while (PostVariableCmdLine[StrLen(PostVariableCmdLine)-1] == L' ') {
-        PostVariableCmdLine[StrLen(PostVariableCmdLine)-1] = CHAR_NULL;
-      }
-      while (PostVariableCmdLine[0] == L' ') {
-        CopyMem(PostVariableCmdLine, PostVariableCmdLine+1, 
StrSize(PostVariableCmdLine) - sizeof(PostVariableCmdLine[0]));
-      }
-
+      TrimSpaces(&PostVariableCmdLine);
+    
       //
       // get the argc and argv updated for internal commands
       //

This was sent by the SourceForge.net collaborative development platform, the 
world's largest Open Source development site.


------------------------------------------------------------------------------
Rapidly troubleshoot problems before they affect your business. Most IT 
organizations don't have a clear picture of how application performance 
affects their revenue. With AppDynamics, you get 100% visibility into your 
Java,.NET, & PHP application. Start your 15-day FREE TRIAL of AppDynamics Pro!
http://pubads.g.doubleclick.net/gampad/clk?id=84349831&iu=/4140/ostg.clktrk
_______________________________________________
edk2-commits mailing list
[email protected]
https://lists.sourceforge.net/lists/listinfo/edk2-commits

Reply via email to