comparison src/utils.c @ 11:e6a594f16403

*: huge refactor the config file has changed drastically, moving to an ini file from that custom format; i *would* have used the win32 functions for those, but they were barely functional, so I decided on using ini.h which is lightweight enough. additionally, I've added Deezer support so album art will be displayed! unfortunately though winhttp is a pain in the ass so if I send a request with any form of unicode chars in it it just returns a "bad request" error. I've tried debugging this but I could never really come up with anything: my hypothesis is that deezer expects their characters in percent-encoded UTF-8, but winhttp is sending them in some other encoding. the config dialog was moved out of config.c (overdue) and many more options are given in the config as well. main.c has been renamed to plugin.c to better differentiate it from... everything else.
author Paper <paper@paper.us.eu.org>
date Thu, 14 Mar 2024 20:25:37 -0400
parents 42ac054c0231
children
comparison
equal deleted inserted replaced
10:42ac054c0231 11:e6a594f16403
4 * Useful utilities for general use. 4 * Useful utilities for general use.
5 **/ 5 **/
6 #include "utils.h" 6 #include "utils.h"
7 7
8 #include <sysinfoapi.h> 8 #include <sysinfoapi.h>
9 #include <windef.h>
10 #include <winbase.h>
11 #include <winuser.h>
12 #include <stringapiset.h>
9 #include <stdint.h> 13 #include <stdint.h>
10 14
15 /* self explanatory. */
11 uint64_t get_system_time_in_milliseconds(void) { 16 uint64_t get_system_time_in_milliseconds(void) {
12 FILETIME ft; 17 FILETIME ft;
13 GetSystemTimeAsFileTime(&ft); 18 GetSystemTimeAsFileTime(&ft);
14 uint64_t ul = (uint64_t) ft.dwHighDateTime << 32 | ft.dwLowDateTime; 19 uint64_t ul = (uint64_t) ft.dwHighDateTime << 32 | ft.dwLowDateTime;
15 return ((ul - 116444736000000000ULL)/10000000); 20 return ((ul - 116444736000000000ULL) * (1.0/10000000));
16 } 21 }
17 22
18 uint32_t crc32b(unsigned char* restrict message) { 23 /*
19 int32_t i, j; 24 * appends the contents of a UTF-8 string with the content of a wide string
20 uint32_t byte, crc, mask; 25 *
26 * [in] LPCWSTR wstr, the wstring to append
27 * [out] LPSTR str, the utf-8 string to append to
28 * [in] size_t offset, an offset in bytes of `str` to append at
29 * [in] size_t size, the total size of `str` in bytes
30 *
31 * if the function fails, it returns 0.
32 * if the string is empty (i.e. str[0] == '\0'), this function returns 0.
33 * if the wide string is too large to be appended within `size`, it returns 0.
34 * on success, it returns the amount of characters written ***NOT INCLUDING THE
35 * NUL BYTE***.
36 */
37 size_t append_wstr_to_utf8(LPCWSTR wstr, LPSTR str, size_t offset, size_t size) {
38 if (!wstr || !str)
39 return 0;
21 40
22 crc = 0xFFFFFFFF; 41 const int wstr_len = WideCharToMultiByte(CP_UTF8, WC_ERR_INVALID_CHARS, wstr, -1, NULL, 0, NULL, NULL);
23 for (i = 0; message[i] != 0; i++) { 42 if (wstr_len < 0 || offset + wstr_len >= size)
24 byte = message[i]; // Get next byte. 43 return 0;
25 crc = crc ^ byte; 44
26 for (j = 7; j >= 0; j--) { // Do eight times. 45 const int actual_len = WideCharToMultiByte(CP_UTF8, WC_ERR_INVALID_CHARS, wstr, -1, str + offset, wstr_len, NULL, NULL);
27 mask = -(crc & 1); 46 if (actual_len < 1)
28 crc = (crc >> 1) ^ (0xEDB88320 & mask); 47 return 0;
29 } 48
30 } 49 return actual_len - 1; // remove nul byte from offset
31 return ~crc;
32 } 50 }