From 20d28e80a5c861a9d5f449ea911ab75b4f37ad0d Mon Sep 17 00:00:00 2001 From: Jef Date: Tue, 24 Sep 2024 14:54:57 +0200 Subject: Initial community commit --- Src/replicant/nx/win/nxpath.c | 113 ++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 113 insertions(+) create mode 100644 Src/replicant/nx/win/nxpath.c (limited to 'Src/replicant/nx/win/nxpath.c') diff --git a/Src/replicant/nx/win/nxpath.c b/Src/replicant/nx/win/nxpath.c new file mode 100644 index 00000000..1841640b --- /dev/null +++ b/Src/replicant/nx/win/nxpath.c @@ -0,0 +1,113 @@ +#include "nxpath.h" +#include +#include "foundation/error.h" + +static const wchar_t *FindExtension(nx_uri_t filename) +{ + size_t position; + if (!filename || !filename->string || !filename->len) + return 0; + + position=filename->len; + while (position--) + { + wchar_t c = filename->string[position]; + if (c == '.') + return &filename->string[position+1]; + if (c == '/' || c == '\\') + return 0; + } + return 0; +} + +static const wchar_t *FindFilename(nx_uri_t filename) +{ + size_t position; + if (!filename || !filename->string || !filename->len) + return 0; + + position=filename->len; + while (position--) + { + wchar_t c = filename->string[position]; + if (c == '/' || c == '\\') + return &filename->string[position+1]; + } + return 0; +} + +size_t NXPathMatchExtensionList(nx_uri_t filename, nx_string_t *extension_list, size_t num_extensions) +{ + const wchar_t *ext = FindExtension(filename); + if (ext && *ext) + { + size_t i; + for (i=0;i= 0x0600 + if (CompareStringOrdinal(ext, -1, extension_list[i]->string, -1, TRUE) == CSTR_EQUAL) + return i; +#else + if (CompareString(LOCALE_INVARIANT, NORM_IGNORECASE, ext, -1, extension_list[i]->string, -1) == CSTR_EQUAL) + return i; +#endif + } + } + return num_extensions; +} + +int NXPathMatchExtension(nx_uri_t filename, nx_string_t extension) +{ + const wchar_t *ext = FindExtension(filename); + if (ext && *ext) + { +#if WINVER >= 0x0600 + if (CompareStringOrdinal(ext, -1, extension->string, -1, TRUE) == CSTR_EQUAL) + return NErr_Success; +#else + if (CompareString(LOCALE_INVARIANT, NORM_IGNORECASE, ext, -1, extension->string, -1) == CSTR_EQUAL) + return NErr_Success; +#endif + } + return NErr_False; +} + +int NXPathProtocol(nx_uri_t filename, const char *protocol) +{ + if (PathIsURL(filename->string)) + { + wchar_t protocol_from_filename[100]; + DWORD protocol_length=100; + if (UrlGetPart(filename->string, protocol_from_filename, &protocol_length, URL_PART_SCHEME, 0) == S_OK) + { + DWORD i; + for (i=0;istring)) + return NErr_True; + else + return NErr_False; +} + +int NXPathIsRelative(nx_uri_t filename) +{ + if (filename->len >= 3 && filename->string[1] == L':' && (filename->string[2] == L'\\' || filename->string[2] == L'/')) + return NErr_False; + + if (filename->len >= 1 && (filename->string[2] == L'\\' || filename->string[2] == L'/')) + return NErr_False; + + return NErr_True; +} + -- cgit