From 93bb30c682bdc984b9acced58e9a1268eefade15 Mon Sep 17 00:00:00 2001 From: Nikias Bassen Date: Fri, 11 Jun 2021 01:37:27 +0200 Subject: Add helper for handling colored terminal output --- src/glue.c | 72 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 72 insertions(+) create mode 100644 src/glue.c (limited to 'src/glue.c') diff --git a/src/glue.c b/src/glue.c new file mode 100644 index 0000000..e65ef56 --- /dev/null +++ b/src/glue.c @@ -0,0 +1,72 @@ +/* + * glue.c + * + * Copyright (c) 2021 Nikias Bassen, All Rights Reserved. + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 2.1 of the License, or (at your option) any later version. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA + */ + +#ifdef HAVE_CONFIG_H +#include +#endif + +#ifdef WIN32 +#include +#endif + +#include "common.h" +#include "libimobiledevice-glue/thread.h" + +extern void term_colors_init(); + +static void internal_glue_init(void) +{ + term_colors_init(); +} + +static void internal_glue_deinit(void) +{ + +} + +static thread_once_t init_once = THREAD_ONCE_INIT; +static thread_once_t deinit_once = THREAD_ONCE_INIT; + +#ifdef WIN32 +BOOL WINAPI DllMain(HINSTANCE hModule, DWORD dwReason, LPVOID lpReserved) +{ + switch (dwReason) { + case DLL_PROCESS_ATTACH: + thread_once(&init_once, internal_glue_init); + break; + case DLL_PROCESS_DETACH: + thread_once(&deinit_once, internal_glue_deinit); + break; + default: + break; + } + return 1; +} +#else +static void __attribute__((constructor)) limd_glue_initialize(void) +{ + thread_once(&init_once, internal_glue_init); +} + +static void __attribute__((destructor)) limd_glue_deinitialize(void) +{ + thread_once(&deinit_once, internal_glue_deinit); +} +#endif -- cgit v1.1-32-gdbae