EFIAPI\r
PathCleanUpDirectories(\r
IN CHAR16 *Path\r
- )\r
+)\r
{\r
CHAR16 *TempString;\r
- UINTN TempSize;\r
\r
- if (Path==NULL) {\r
- return(NULL);\r
+ if (Path == NULL) {\r
+ return NULL;\r
}\r
+\r
//\r
- // Fix up the '/' vs '\'\r
+ // Replace the '/' with '\'\r
//\r
- for (TempString = Path ; TempString != NULL && *TempString != CHAR_NULL ; TempString++) {\r
+ for (TempString = Path; *TempString != CHAR_NULL; TempString++) {\r
if (*TempString == L'/') {\r
*TempString = L'\\';\r
}\r
}\r
+\r
//\r
- // Fix up the ..\r
+ // Remove all the "\.". E.g.: fs0:\abc\.\def\.\r
//\r
- while ((TempString = StrStr(Path, L"\\..\\")) != NULL) {\r
- *TempString = CHAR_NULL;\r
- TempString += 4;\r
- PathRemoveLastItem(Path);\r
- TempSize = StrSize(TempString);\r
- CopyMem(Path+StrLen(Path), TempString, TempSize);\r
+ while ((TempString = StrStr (Path, L"\\.\\")) != NULL) {\r
+ CopyMem (TempString, TempString + 2, StrSize (TempString + 2));\r
}\r
- if ((TempString = StrStr(Path, L"\\..")) != NULL && *(TempString + 3) == CHAR_NULL) {\r
- *TempString = CHAR_NULL;\r
- if (!PathRemoveLastItem(Path)) {\r
- *TempString = L'\\';\r
- }\r
+ if (StrCmp (Path + StrLen (Path) - 2, L"\\.") == 0) {\r
+ Path[StrLen (Path) - 1] = CHAR_NULL;\r
}\r
+\r
//\r
- // Fix up the .\r
+ // Remove all the "\..". E.g.: fs0:\abc\..\def\..\r
//\r
- while ((TempString = StrStr(Path, L"\\.\\")) != NULL) {\r
- *TempString = CHAR_NULL;\r
- TempString += 2;\r
- TempSize = StrSize(TempString);\r
- CopyMem(Path+StrLen(Path), TempString, TempSize);\r
- }\r
- if ((TempString = StrStr(Path, L"\\.")) != NULL && *(TempString + 2) == CHAR_NULL) {\r
+ while (((TempString = StrStr(Path, L"\\..")) != NULL) &&\r
+ ((*(TempString + 3) == L'\\') || (*(TempString + 3) == CHAR_NULL))\r
+ ) {\r
*(TempString + 1) = CHAR_NULL;\r
+ PathRemoveLastItem(Path);\r
+ CopyMem (Path + StrLen (Path), TempString + 3, StrSize (TempString + 3));\r
}\r
\r
- while ((TempString = StrStr(Path, L"\\\\")) != NULL) {\r
- *TempString = CHAR_NULL;\r
- TempString += 1;\r
- TempSize = StrSize(TempString);\r
- CopyMem(Path+StrLen(Path), TempString, TempSize);\r
- }\r
- if ((TempString = StrStr(Path, L"\\\\")) != NULL && *(TempString + 1) == CHAR_NULL) {\r
- *(TempString) = CHAR_NULL;\r
+ //\r
+ // Replace the "\\" with "\"\r
+ //\r
+ while ((TempString = StrStr (Path, L"\\\\")) != NULL) {\r
+ CopyMem (TempString, TempString + 1, StrSize (TempString + 1));\r
}\r
\r
- return (Path);\r
+ return Path;\r
}\r
\r