aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRechi <Rechi@users.noreply.github.com>2018-03-23 19:00:00 +0100
committerRechi <Rechi@users.noreply.github.com>2018-03-23 19:00:00 +0100
commit14ffbe39d6a3b0cfbf334653d0f03d88f690acbe (patch)
tree1f9948c3393a7e2c875a89ec1ce1542f53f5c052
parentcf7dd38abb6901f536b6a8d937a0a56248e06652 (diff)
[cpluff] add windows changes
-rw-r--r--lib/cpluff/CMakeLists.txt55
-rw-r--r--lib/cpluff/libcpluff/internal.h4
-rw-r--r--lib/cpluff/libcpluff/ploader.c14
-rw-r--r--lib/cpluff/libcpluff/win32/cpluffdef.h4
-rw-r--r--lib/cpluff/libcpluff/win32/dirent.c66
-rw-r--r--lib/cpluff/libcpluff/win32/dirent.h4
-rw-r--r--lib/cpluff/libcpluff/win32/win32_utils.c73
-rw-r--r--lib/cpluff/libcpluff/win32/win32_utils.h30
8 files changed, 212 insertions, 38 deletions
diff --git a/lib/cpluff/CMakeLists.txt b/lib/cpluff/CMakeLists.txt
new file mode 100644
index 0000000000..931c0aee1c
--- /dev/null
+++ b/lib/cpluff/CMakeLists.txt
@@ -0,0 +1,55 @@
+cmake_minimum_required(VERSION 3.0)
+
+project(libcpluff VERSION 0.1.4 LANGUAGES C)
+
+find_package(expat 2.2.0 REQUIRED)
+
+add_library(${PROJECT_NAME}
+ ${CMAKE_CURRENT_SOURCE_DIR}/kazlib/hash.h
+ ${CMAKE_CURRENT_SOURCE_DIR}/kazlib/hash.c
+ ${CMAKE_CURRENT_SOURCE_DIR}/kazlib/list.h
+ ${CMAKE_CURRENT_SOURCE_DIR}/kazlib/list.c
+ ${CMAKE_CURRENT_SOURCE_DIR}/libcpluff/context.c
+ ${CMAKE_CURRENT_SOURCE_DIR}/libcpluff/cpluff.h
+ ${CMAKE_CURRENT_SOURCE_DIR}/libcpluff/cpluff.c
+ ${CMAKE_CURRENT_SOURCE_DIR}/libcpluff/defines.h
+ ${CMAKE_CURRENT_SOURCE_DIR}/libcpluff/internal.h
+ ${CMAKE_CURRENT_SOURCE_DIR}/libcpluff/logging.c
+ ${CMAKE_CURRENT_SOURCE_DIR}/libcpluff/pcontrol.c
+ ${CMAKE_CURRENT_SOURCE_DIR}/libcpluff/pinfo.c
+ ${CMAKE_CURRENT_SOURCE_DIR}/libcpluff/ploader.c
+ ${CMAKE_CURRENT_SOURCE_DIR}/libcpluff/pscan.c
+ ${CMAKE_CURRENT_SOURCE_DIR}/libcpluff/psymbol.c
+ ${CMAKE_CURRENT_SOURCE_DIR}/libcpluff/serial.c
+ ${CMAKE_CURRENT_SOURCE_DIR}/libcpluff/thread.h
+ ${CMAKE_CURRENT_SOURCE_DIR}/libcpluff/util.h
+ ${CMAKE_CURRENT_SOURCE_DIR}/libcpluff/util.c
+)
+
+if(WIN32)
+ target_sources(${PROJECT_NAME} PRIVATE
+ ${CMAKE_CURRENT_SOURCE_DIR}/libcpluff/thread_windows.c
+ ${CMAKE_CURRENT_SOURCE_DIR}/libcpluff/win32/cpluffdef.h
+ ${CMAKE_CURRENT_SOURCE_DIR}/libcpluff/win32/dirent.h
+ ${CMAKE_CURRENT_SOURCE_DIR}/libcpluff/win32/dirent.c
+ ${CMAKE_CURRENT_SOURCE_DIR}/libcpluff/win32/win32_utils.h
+ ${CMAKE_CURRENT_SOURCE_DIR}/libcpluff/win32/win32_utils.c
+ )
+endif()
+
+target_link_libraries(${PROJECT_NAME} PRIVATE ${EXPAT_LIBRARIES})
+
+target_include_directories(${PROJECT_NAME}
+ PRIVATE
+ $<BUILD_INTERFACE:kazlib;libcpluff;libcpluff/win32;${EXPAT_INCLUDE_DIR}>
+ INTERFACE
+ $<INSTALL_INTERFACE:include>
+)
+
+target_compile_definitions(${PROJECT_NAME}
+ PRIVATE
+ XML_STATIC
+ CP_C_API=CP_EXPORT
+ _CRT_SECURE_NO_WARNINGS
+ _CRT_NONSTDC_NO_DEPRECATE
+)
diff --git a/lib/cpluff/libcpluff/internal.h b/lib/cpluff/libcpluff/internal.h
index 161ba6de07..5f5761750b 100644
--- a/lib/cpluff/libcpluff/internal.h
+++ b/lib/cpluff/libcpluff/internal.h
@@ -85,7 +85,11 @@ extern "C" {
#if defined(_WIN32)
#define DLHANDLE void *
+#if defined(WINAPI_FAMILY) && (WINAPI_FAMILY != WINAPI_FAMILY_DESKTOP_APP)
+#define DLOPEN(name) LoadPackagedLibrary(name, 0)
+#else
#define DLOPEN(name) LoadLibraryA(name)
+#endif
#define DLSYM(handle, symbol) GetProcAddress(handle, symbol)
#define DLCLOSE(handle) CloseHandle(handle)
#define DLERROR() "WIN32 - TODO"
diff --git a/lib/cpluff/libcpluff/ploader.c b/lib/cpluff/libcpluff/ploader.c
index 5c01addd43..66249381ab 100644
--- a/lib/cpluff/libcpluff/ploader.c
+++ b/lib/cpluff/libcpluff/ploader.c
@@ -41,6 +41,9 @@
#include "defines.h"
#include "util.h"
#include "internal.h"
+#if defined(_WIN32)
+#include "win32_utils.h"
+#endif
// Use XMLCALL if available
#ifdef XMLCALL
@@ -1159,11 +1162,22 @@ CP_C_API cp_plugin_info_t * cp_load_plugin_descriptor(cp_context_t *context, con
file[path_len] = CP_FNAMESEP_CHAR;
strcpy(file + path_len + 1, CP_PLUGIN_DESCRIPTOR);
+#if defined(_WIN32)
+ wchar_t* fileW = to_utf16(file, 0);
+ fh = _wfopen(fileW, L"rb");
+ free(fileW);
+ if (!fh)
+ {
+ status = CP_ERR_IO;
+ break;
+ }
+#else
// Open the file
if ((fh = fopen(file, "rb")) == NULL) {
status = CP_ERR_IO;
break;
}
+#endif
// Initialize descriptor parsing
status = init_descriptor_parsing(context, &plcontext, &parser, file);
diff --git a/lib/cpluff/libcpluff/win32/cpluffdef.h b/lib/cpluff/libcpluff/win32/cpluffdef.h
index 891e95a0f6..7e3d55f269 100644
--- a/lib/cpluff/libcpluff/win32/cpluffdef.h
+++ b/lib/cpluff/libcpluff/win32/cpluffdef.h
@@ -136,7 +136,11 @@
#if defined(_WIN32)
# define CP_EXPORT __declspec(dllexport)
+#if defined(_WINDLL)
# define CP_IMPORT extern __declspec(dllimport)
+#else
+# define CP_IMPORT
+#endif
# define CP_HIDDEN
#elif defined(__GNUC__) && (__GNUC__ > 3 || (__GNUC__ == 3 && __GNUC_MINOR__ >= 3))
# define CP_EXPORT
diff --git a/lib/cpluff/libcpluff/win32/dirent.c b/lib/cpluff/libcpluff/win32/dirent.c
index 3254b22729..ead41848f9 100644
--- a/lib/cpluff/libcpluff/win32/dirent.c
+++ b/lib/cpluff/libcpluff/win32/dirent.c
@@ -9,6 +9,7 @@
*/
#include "dirent.h"
+#include "win32_utils.h"
#include <errno.h>
#include <io.h> /* _findfirst and _findnext set errno iff they return -1 */
#include <stdlib.h>
@@ -21,10 +22,10 @@ extern "C"
struct DIR
{
- long handle; /* -1 for failed rewind */
- struct _finddata_t info;
+ HANDLE handle; /* -1 for failed rewind */
struct dirent result; /* d_name null iff first time */
- char *name; /* null-terminated char string */
+ wchar_t* name;
+ WIN32_FIND_DATAW info;
};
DIR *opendir(const char *name)
@@ -33,16 +34,29 @@ DIR *opendir(const char *name)
if(name && name[0])
{
- size_t base_length = strlen(name);
- const char *all = /* search pattern must end with suitable wildcard */
- strchr("/\\", name[base_length - 1]) ? "*" : "/*";
-
- if((dir = (DIR *) malloc(sizeof *dir)) != 0 &&
- (dir->name = (char *) malloc(base_length + strlen(all) + 1)) != 0)
+ if ((dir = (DIR *)malloc(sizeof *dir)) != 0)
{
- strcat(strcpy(dir->name, name), all);
-
- if((dir->handle = (long) _findfirst(dir->name, &dir->info)) != -1)
+ dir->handle = INVALID_HANDLE_VALUE;
+ int len = strlen(name);
+ size_t newLength = len + 2; //add an extra for null and another for a * at the end
+ if (!(name[0] == '\\' && name[1] == '\\' && name[2] == '?' && name[3] == '\\'))
+ newLength += 4;
+ if (name[len - 1] != '\\')
+ newLength += 1;
+
+ char* newDir = (char*)malloc(newLength);
+ strcpy_s(newDir, newLength, "\\\\?\\");
+ strcat_s(newDir, newLength, name);
+ if (name[len - 1] != '\\')
+ strcat_s(newDir, newLength, "\\");
+ strcat_s(newDir, newLength, "*");
+ newDir[newLength - 1] = '\0';
+
+ dir->name = to_utf16(newDir, newLength);
+ free(newDir);
+
+ dir->handle = FindFirstFileW(dir->name, &dir->info);
+ if (dir->handle != INVALID_HANDLE_VALUE)
{
dir->result.d_name = 0;
}
@@ -55,6 +69,7 @@ DIR *opendir(const char *name)
}
else /* rollback */
{
+ free(dir->name);
free(dir);
dir = 0;
errno = ENOMEM;
@@ -72,12 +87,9 @@ int closedir(DIR *dir)
{
int result = -1;
- if(dir)
+ if(dir && dir->handle != INVALID_HANDLE_VALUE)
{
- if(dir->handle != -1)
- {
- result = _findclose(dir->handle);
- }
+ FindClose(dir->handle);
free(dir->name);
free(dir);
@@ -95,12 +107,12 @@ struct dirent *readdir(DIR *dir)
{
struct dirent *result = 0;
- if(dir && dir->handle != -1)
+ if(dir && dir->handle != INVALID_HANDLE_VALUE)
{
- if(!dir->result.d_name || _findnext(dir->handle, &dir->info) != -1)
+ if (FindNextFileW(dir->handle, &dir->info))
{
result = &dir->result;
- result->d_name = dir->info.name;
+ result->d_name = to_utf8(dir->info.cFileName, 0);
}
}
else
@@ -111,20 +123,6 @@ struct dirent *readdir(DIR *dir)
return result;
}
-void rewinddir(DIR *dir)
-{
- if(dir && dir->handle != -1)
- {
- _findclose(dir->handle);
- dir->handle = (long) _findfirst(dir->name, &dir->info);
- dir->result.d_name = 0;
- }
- else
- {
- errno = EBADF;
- }
-}
-
// helper for scandir below
static void scandir_free_dir_entries(struct dirent*** namelist, int entries) {
int i;
diff --git a/lib/cpluff/libcpluff/win32/dirent.h b/lib/cpluff/libcpluff/win32/dirent.h
index b41998c6eb..c250bfdb28 100644
--- a/lib/cpluff/libcpluff/win32/dirent.h
+++ b/lib/cpluff/libcpluff/win32/dirent.h
@@ -19,10 +19,6 @@ extern "C"
typedef struct DIR DIR;
-#ifndef WIN32
-static int errno;
-#endif
-
struct dirent
{
char *d_name;
diff --git a/lib/cpluff/libcpluff/win32/win32_utils.c b/lib/cpluff/libcpluff/win32/win32_utils.c
new file mode 100644
index 0000000000..52cf353c13
--- /dev/null
+++ b/lib/cpluff/libcpluff/win32/win32_utils.c
@@ -0,0 +1,73 @@
+/*-------------------------------------------------------------------------
+ * C-Pluff, a plug-in framework for C
+ * Copyright 2016 Team Kodi
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining a
+ * copy of this software and associated documentation files (the "Software"),
+ * to deal in the Software without restriction, including without limitation
+ * the rights to use, copy, modify, merge, publish, distribute, sublicense,
+ * and/or sell copies of the Software, and to permit persons to whom the
+ * Software is furnished to do so, subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be included
+ * in all copies or substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
+ * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
+ * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
+ * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
+ * CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
+ * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
+ * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
+ *-----------------------------------------------------------------------*/
+
+#include <stdlib.h>
+
+#include "win32_utils.h"
+
+wchar_t* to_utf16(const char* str, size_t length)
+{
+ if (length == 0)
+ length = strlen(str);
+ int result = MultiByteToWideChar(CP_UTF8, 0, str, length, NULL, 0);
+ if (result == 0)
+ {
+ return NULL;
+ }
+
+ int newLen = result + 1;
+ wchar_t* dirPath = malloc(newLen * 2);
+ result = MultiByteToWideChar(CP_UTF8, 0, str, length, dirPath, newLen);
+
+ if (result == 0)
+ {
+ free(dirPath);
+ return NULL;
+ }
+
+ dirPath[newLen - 1] = L'\0';
+ return dirPath;
+}
+
+char* to_utf8(const wchar_t* str, size_t length)
+{
+ if (length == 0)
+ length = wcslen(str);
+
+ int result = WideCharToMultiByte(CP_UTF8, 0, str, length, NULL, 0, NULL, NULL);
+ if (result == 0)
+ return NULL;
+
+ int newLen = result + 1;
+ char *newStr = malloc(newLen);
+ result = WideCharToMultiByte(CP_UTF8, 0, str, length, newStr, result, NULL, NULL);
+ if (result == 0)
+ {
+ free(newStr);
+ return NULL;
+ }
+
+ newStr[newLen - 1] = '\0';
+
+ return newStr;
+}
diff --git a/lib/cpluff/libcpluff/win32/win32_utils.h b/lib/cpluff/libcpluff/win32/win32_utils.h
new file mode 100644
index 0000000000..f4074f3745
--- /dev/null
+++ b/lib/cpluff/libcpluff/win32/win32_utils.h
@@ -0,0 +1,30 @@
+/*-------------------------------------------------------------------------
+ * C-Pluff, a plug-in framework for C
+ * Copyright 2016 Team Kodi
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining a
+ * copy of this software and associated documentation files (the "Software"),
+ * to deal in the Software without restriction, including without limitation
+ * the rights to use, copy, modify, merge, publish, distribute, sublicense,
+ * and/or sell copies of the Software, and to permit persons to whom the
+ * Software is furnished to do so, subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be included
+ * in all copies or substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
+ * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
+ * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
+ * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
+ * CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
+ * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
+ * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
+ *-----------------------------------------------------------------------*/
+
+#if !defined(WIN32_LEAN_AND_MEAN)
+ #define WIN32_LEAN_AND_MEAN
+#endif
+#include <windows.h>
+
+wchar_t* to_utf16(const char* str, size_t length);
+char* to_utf8(const wchar_t* str, size_t length);