summary refs log tree commit diff
path: root/src/Utils.h
diff options
context:
space:
mode:
authorWlodekM <[email protected]>2024-06-16 10:35:45 +0300
committerWlodekM <[email protected]>2024-06-16 10:35:45 +0300
commitabef6da56913f1c55528103e60a50451a39628b1 (patch)
treeb3c8092471ecbb73e568cd0d336efa0e7871ee8d /src/Utils.h
initial commit
Diffstat (limited to 'src/Utils.h')
-rw-r--r--src/Utils.h77
1 files changed, 77 insertions, 0 deletions
diff --git a/src/Utils.h b/src/Utils.h
new file mode 100644
index 0000000..1042c5e
--- /dev/null
+++ b/src/Utils.h
@@ -0,0 +1,77 @@
+#ifndef CC_UTILS_H
+#define CC_UTILS_H
+#include "Core.h"
+/* 
+Provides various utility functions
+Copyright 2014-2023 ClassiCube | Licensed under BSD-3
+*/
+
+struct Bitmap;
+struct StringsBuffer;
+/* Represents a particular instance in time in some timezone. Not necessarily UTC time. */
+/* NOTE: TimeMS and DateTime_CurrentUTC() should almost always be used instead. */
+/* This struct should only be used when actually needed. (e.g. log message time) */
+struct DateTime {
+	int year;   /* Year,   ranges from 0 to 65535 */
+	int month;  /* Month,  ranges from 1 to 12 */
+	int day;    /* Day,    ranges from 1 to 31 */
+	int hour;   /* Hour,   ranges from 0 to 23 */
+	int minute; /* Minute, ranges from 0 to 59 */
+	int second; /* Second, ranges from 0 to 59 */
+	int __milli;/* Was milliseconds, unused now */
+};
+
+#define MILLIS_PER_SEC 1000
+#define SECS_PER_MIN 60
+#define SECS_PER_HOUR (60 * 60)
+#define SECS_PER_DAY (60 * 60 * 24)
+
+CC_NOINLINE int Utils_ParseEnum(const cc_string* text, int defValue, const char* const* names, int namesCount);
+/* Returns whether value starts with http:// or https:// */
+cc_bool Utils_IsUrlPrefix(const cc_string* value);
+
+/* Creates the directory if it doesn't exist. (logs failure using Logger_SysWarn2) */
+cc_bool Utils_EnsureDirectory(const char* dirName);
+/* Gets the filename portion of a path. (e.g. "dir/file.txt" -> "file.txt") */
+void Utils_UNSAFE_GetFilename(STRING_REF cc_string* path);
+/* Gets rid of first directory in a path. (e.g. "dx/gl/aa.txt" -> "gl/aa.txt" */
+void Utils_UNSAFE_TrimFirstDirectory(STRING_REF cc_string* path);
+int Utils_AccumulateWheelDelta(float* accumulator, float delta);
+#define Utils_AdjViewDist(value) ((int)(1.4142135f * (value)))
+
+cc_uint8 Utils_CalcSkinType(const struct Bitmap* bmp);
+cc_uint32 Utils_CRC32(const cc_uint8* data, cc_uint32 length);
+/* CRC32 lookup table, for faster CRC32 calculations. */
+/* NOTE: This cannot be just indexed by byte value - see Utils_CRC32 implementation. */
+extern const cc_uint32 Utils_Crc32Table[256];
+CC_NOINLINE void Utils_Resize(void** buffer, int* capacity, cc_uint32 elemSize, int defCapacity, int expandElems);
+void Utils_SwapEndian16(cc_int16* values, int numValues);
+
+/* Converts blocks of 3 bytes into 4 ASCII characters. (pads if needed) */
+/* Returns the number of ASCII characters written. */
+/* NOTE: You MUST ensure that dst is appropriately sized. */
+int Convert_ToBase64(const void* data, int len, char* dst);
+/* Converts blocks of 4 ASCII characters into 3 bytes. */
+/* Returns the number of bytes written. */
+/* NOTE: You MUST ensure that dst is appropriately sized. */
+int Convert_FromBase64(const char* src, int len, cc_uint8* dst);
+
+typedef cc_bool (*EntryList_Filter)(const cc_string* entry);
+/* Loads the entries from disc. */
+/* NOTE: If separator is \0, does NOT check for duplicate keys when loading. */
+/* filter can be used to optionally skip loading some entries from the file. */
+CC_NOINLINE cc_result EntryList_Load(struct StringsBuffer* list, const char* file, char separator, EntryList_Filter filter);
+/* Shortcut for EntryList_Load with separator of \0 and filter of NULL */
+/* NOTE: Does NOT check for duplicate keys */
+CC_NOINLINE cc_result EntryList_UNSAFE_Load(struct StringsBuffer* list, const char* file);
+/* Saves the entries in the given list to disc. */
+CC_NOINLINE void EntryList_Save(struct StringsBuffer* list, const char* file);
+/* Removes the entry whose key caselessly equals the given key. */
+CC_NOINLINE cc_bool EntryList_Remove(struct StringsBuffer* list, const cc_string* key, char separator);
+/* Replaces the entry whose key caselessly equals the given key, or adds a new entry. */
+CC_NOINLINE void EntryList_Set(struct StringsBuffer* list, const cc_string* key, const cc_string* value, char separator);
+/* Returns the value of the entry whose key caselessly equals the given key. */
+CC_NOINLINE STRING_REF cc_string EntryList_UNSAFE_Get(struct StringsBuffer* list, const cc_string* key, char separator);
+/* Finds the index of the entry whose key caselessly equals the given key. */
+CC_NOINLINE int EntryList_Find(struct StringsBuffer* list, const cc_string* key, char separator);
+#endif