summaryrefslogtreecommitdiffhomepage
path: root/SDK/Libraries/CoreSystem/Headers
diff options
context:
space:
mode:
Diffstat (limited to 'SDK/Libraries/CoreSystem/Headers')
-rw-r--r--SDK/Libraries/CoreSystem/Headers/Alert.h25
-rw-r--r--SDK/Libraries/CoreSystem/Headers/Defines.h235
-rw-r--r--SDK/Libraries/CoreSystem/Headers/File.h57
-rw-r--r--SDK/Libraries/CoreSystem/Headers/Heap.h39
-rw-r--r--SDK/Libraries/CoreSystem/Headers/Hint.h20
-rw-r--r--SDK/Libraries/CoreSystem/Headers/Intl.h29
-rw-r--r--SDK/Libraries/CoreSystem/Headers/Math.h27
-rw-r--r--SDK/Libraries/CoreSystem/Headers/Rsrc.h12
-rw-r--r--SDK/Libraries/CoreSystem/Headers/Thread.h47
-rw-r--r--SDK/Libraries/CoreSystem/Headers/Transport.h48
10 files changed, 539 insertions, 0 deletions
diff --git a/SDK/Libraries/CoreSystem/Headers/Alert.h b/SDK/Libraries/CoreSystem/Headers/Alert.h
new file mode 100644
index 00000000..7decd4ca
--- /dev/null
+++ b/SDK/Libraries/CoreSystem/Headers/Alert.h
@@ -0,0 +1,25 @@
+/* -------------------------------------------
+
+ Copyright SoftwareLabs
+
+------------------------------------------- */
+
+/*************************************************************
+ *
+ * File: Alert.h
+ * Purpose: New OS alert dialog.
+ * Date: 3/26/24
+ *
+ * Copyright SoftwareLabs, all rights reserved.
+ *
+ *************************************************************/
+
+#pragma once
+
+#include <Headers/Defines.h>
+
+/// @brief Shows an alert box, as provided by the OS.
+/// @param fmt The alert formating.
+/// @param
+/// @return
+CS_EXTERN_C VoidType UiAlert(const CharacterTypeUTF8* fmt, ...);
diff --git a/SDK/Libraries/CoreSystem/Headers/Defines.h b/SDK/Libraries/CoreSystem/Headers/Defines.h
new file mode 100644
index 00000000..713d6df8
--- /dev/null
+++ b/SDK/Libraries/CoreSystem/Headers/Defines.h
@@ -0,0 +1,235 @@
+/* -------------------------------------------
+
+ Copyright SoftwareLabs
+
+------------------------------------------- */
+
+#pragma once
+
+#ifdef CS_MUST_PASS
+#undef CS_MUST_PASS
+#endif
+
+#ifdef _DEBUG
+#define CS_MUST_PASS(e) \
+ { \
+ if (!e) \
+ { \
+ UiAlert("Assertion failed.\nExpression :%s\nFile: %s\nLine: %i", #e, __FILE__, __LINE__) RtAssertTriggerInterrupt() \
+ } \
+ }
+#else
+#define CS_MUST_PASS(e) CS_UNREFERENCED_PARAMETER(e)
+#endif
+
+#ifdef __cplusplus
+
+#define CS_EXTERN_C extern "C"
+
+#else
+
+#define CS_EXTERN_C extern
+
+#endif
+
+#include <Headers/Alert.h>
+
+struct ApplicationInterface;
+struct GUID;
+
+CS_EXTERN_C void RtAssertTriggerInterrupt(void);
+
+#define CS_STDCALL __attribute__((stdcall))
+#define CS_CDECL __attribute__((cdecl))
+#define CS_MSCALL __attribute__((ms_abi))
+
+#define PACKED __attribute__((packed))
+
+#define CS_PASCAL CS_STDCALL
+
+#include <Headers/Hint.h>
+
+typedef __UINT8_TYPE__ ByteType;
+typedef __UINT16_TYPE__ WordType;
+typedef __UINT32_TYPE__ DWordType;
+typedef __UINT64_TYPE__ QWordType;
+typedef __SIZE_TYPE__ SizeType;
+
+typedef char CharacterTypeUTF8;
+typedef CharacterTypeUTF8* PtrCharacterType;
+
+typedef void* PtrVoidType;
+typedef void VoidType;
+
+#ifdef __SINGLE_PRECISION__
+typedef float FloatType;
+typedef float PositionType;
+#else
+typedef double FloatType;
+typedef double PositionType;
+#endif
+
+typedef __UINTPTR_TYPE__ UIntPtrType;
+typedef __INTPTR_TYPE__ IntPtrType;
+typedef __UINT64_TYPE__ UInt64Type;
+typedef __INT64_TYPE__ Int64Type;
+typedef __UINT32_TYPE__ UInt32Type;
+typedef __INT32_TYPE__ Int32Type;
+
+typedef CharacterTypeUTF8 BooleanType;
+
+#define Yes 1
+#define No 0
+
+#define CS_PTR *
+
+#define CS_UNREFERENCED_PARAMETER(e) ((VoidType)(e))
+
+#ifdef __x86_64__
+
+#define CS_FAR __far
+#define CS_NEAR __near
+
+#define _M_AMD64 2
+#else
+
+#define CS_FAR
+#define CS_NEAR
+
+#endif
+
+#ifdef __aarch64__
+#define _M_AARCH64 3
+#endif
+
+#ifdef __powerpc64__
+#define _M_PPC64 4
+#endif
+
+#ifdef __64x0__
+#define _M_64000 5
+#endif
+
+#ifdef __riscv__
+#define _M_RISCV 6
+#endif
+
+#define CS_STATIC static
+#define CS_INLINE inline
+#define CS_CONST const
+
+#ifdef __cplusplus
+#define CS_CONSTEXPR constexpr
+#else
+#define CS_CONSTEXPR
+#endif // __cplusplus
+
+enum RtProcessCall
+{
+ kCallAllocPtr = 1,
+ kCallFreePtr,
+ kCallSizePtr,
+ kCallCheckPtr,
+ kCallAllocStack,
+ /// @brief Open a specific handle
+ /// (can be used as sel to call methods related to it.)
+ kCallOpenFile,
+ kCallCloseFile,
+ kCallOpenDir,
+ kCallCloseDir,
+ kCallOpenDevice,
+ kCallCloseDevice,
+ kCallCreateWindow,
+ kCallCloseWindow,
+ kCallCreateMenu,
+ kCallCloseMenu,
+ kCallRandomNumberGenerator,
+ kCallGetArgsCount,
+ kCallGetArgsPtr,
+ kCallFileExists,
+ kCallDirectoryExists,
+ kCallSymlinkExists,
+ kCallDeviceExists,
+ kCallDriveExists,
+ /// @brief Number of process calls.
+ kCallsCount,
+};
+
+/**
+ * @brief GUID type, something you can also find in CFKit.
+ * @author Amlal El Mahrouss
+ */
+typedef struct GUID
+{
+ DWordType Data1;
+ WordType Data2;
+ WordType Data3;
+ ByteType Data4[8];
+} GUIDType, *PtrGUIDType;
+
+/// \brief Application Interface.
+/// \author Amlal El Mahrouss
+typedef struct ApplicationInterface
+{
+ VoidType (*Release)(struct ApplicationInterface* Self, DWordType ExitCode);
+ IntPtrType (*Invoke)(struct ApplicationInterface* Self, DWordType Sel, ...);
+ VoidType (*Query)(struct ApplicationInterface* Self, PtrVoidType* Dst, SizeType SzDst, struct GUID* GuidOf);
+} ApplicationInterface, *ApplicationInterfaceRef;
+
+#ifdef __cplusplus
+
+#define CS_COPY_DELETE(KLASS) \
+ KLASS& operator=(const KLASS&) = delete; \
+ KLASS(const KLASS&) = delete;
+
+#define CS_COPY_DEFAULT(KLASS) \
+ KLASS& operator=(const KLASS&) = default; \
+ KLASS(const KLASS&) = default;
+
+#define CS_MOVE_DELETE(KLASS) \
+ KLASS& operator=(KLASS&&) = delete; \
+ KLASS(KLASS&&) = delete;
+
+#define CS_MOVE_DEFAULT(KLASS) \
+ KLASS& operator=(KLASS&&) = default; \
+ KLASS(KLASS&&) = default;
+
+#define app_cast reinterpret_cast<ApplicationInterfaceRef>
+
+template <SizeType N>
+using StrType = CharacterTypeUTF8[N];
+
+#else
+
+#define app_cast (ApplicationInterfaceRef)
+
+#endif // ifdef C++
+
+/// @brief Get app singleton.
+/// @param
+/// @return
+CS_EXTERN_C ApplicationInterfaceRef RtGetAppPointer(VoidType);
+
+/// @brief Get argument count
+/// @param
+/// @return
+CS_EXTERN_C SizeType RtGetAppArgumentsCount(VoidType);
+
+/// @brief Get argument pointer.
+/// @param
+/// @return
+CS_EXTERN_C CharacterTypeUTF8** RtGetAppArgumentsPtr(VoidType);
+
+CS_EXTERN_C ApplicationInterfaceRef kSharedApplication;
+
+typedef CharacterTypeUTF8 StrType255[255];
+
+#define True 1
+#define False 0
+#define Bool BooleanType
+
+#define NullPtr ((PtrVoidType)0)
+
+#ifndef kInvalidRef
+#define kInvalidRef 0
+#endif
diff --git a/SDK/Libraries/CoreSystem/Headers/File.h b/SDK/Libraries/CoreSystem/Headers/File.h
new file mode 100644
index 00000000..cfd9ee30
--- /dev/null
+++ b/SDK/Libraries/CoreSystem/Headers/File.h
@@ -0,0 +1,57 @@
+/* -------------------------------------------
+
+ Copyright SoftwareLabs
+
+------------------------------------------- */
+
+#pragma once
+
+#include <Headers/Defines.h>
+
+#define kMaxForkNameLength (256U) /* long fork names. */
+
+struct _Fork;
+
+/// @brief Filesystem wrapper.
+
+typedef QWordType FSRef;
+
+/// @brief Opens a new file.
+/// @param path where to find it.
+/// @param rest the restrict (rw, rwe, r+, w+, r, w)
+/// @return FSRef the file.
+CS_EXTERN_C FSRef CSOpenFile(const CharacterTypeUTF8* path, const CharacterTypeUTF8* r);
+
+/// @brief Closes the file and flushes it to the said file.
+/// @param refCS the filesystem reference.
+/// @return
+CS_EXTERN_C VoidType CSCloseFile(FSRef refCS);
+
+/// @brief A fork information header.
+typedef struct _Fork
+{
+ Int32Type forkFlags;
+ Int32Type forkKind;
+ CharacterTypeUTF8 forkName[kMaxForkNameLength];
+ SizeType forkSize;
+ CharacterTypeUTF8 forkData[];
+} ForkType, ForkTypePtr;
+
+typedef ForkType* FSForkRef;
+
+/// @brief Gets the fork inside a file.
+/// @param refCS the filesystem ref
+/// @param forkName the fork's name
+/// @return the fork data.
+CS_EXTERN_C FSForkRef CSGetFork(FSRef refCS, const CharacterTypeUTF8* forkName);
+
+/// @brief Check if the filesystem path is valid.
+/// @return if not return false, or true.
+CS_EXTERN_C BooleanType CSIsValidPath(const CharacterTypeUTF8* path);
+
+/// @brief Flush file
+/// @param refCS the file reference.
+/// @return
+CS_EXTERN_C VoidType CSFlushFile(FSRef refCS);
+
+/// END OF FILE
diff --git a/SDK/Libraries/CoreSystem/Headers/Heap.h b/SDK/Libraries/CoreSystem/Headers/Heap.h
new file mode 100644
index 00000000..b2ad6e74
--- /dev/null
+++ b/SDK/Libraries/CoreSystem/Headers/Heap.h
@@ -0,0 +1,39 @@
+/* -------------------------------------------
+
+ Copyright SoftwareLabs
+
+------------------------------------------- */
+
+#pragma once
+
+#include <Headers/Defines.h>
+
+#define cAllocationKindCount (2U)
+
+enum CsAllocationKind
+{
+ kStandardAllocation = 0xC,
+ kArrayAllocation = 0xD,
+};
+
+/// @brief Allocates a new pointer from process pool.
+/// @param sz the size
+/// @param flags the allocation flags.
+/// @return
+CS_EXTERN_C PtrVoidType CSAllocateHeap(QWordType sz,
+ DWordType flags);
+
+/// @brief Check if the pointer exists.
+/// @param ptr the pointer to free.
+/// @return
+CS_EXTERN_C BooleanType CSIsHeapValid(PtrVoidType ptr);
+
+/// @brief Gets the size of the process' pointer.
+/// @param ptr the pointer to free.
+/// @return
+CS_EXTERN_C QWordType CSGetHeapSize(PtrVoidType ptr);
+
+/// @brief Frees the process pointer.
+/// @param ptr the pointer to free.
+/// @return
+CS_EXTERN_C VoidType CSFreeHeap(PtrVoidType ptr);
diff --git a/SDK/Libraries/CoreSystem/Headers/Hint.h b/SDK/Libraries/CoreSystem/Headers/Hint.h
new file mode 100644
index 00000000..ee14711d
--- /dev/null
+++ b/SDK/Libraries/CoreSystem/Headers/Hint.h
@@ -0,0 +1,20 @@
+/* -------------------------------------------
+
+ Copyright SoftwareLabs
+
+------------------------------------------- */
+
+#pragma once
+
+#pragma compiler(hint_manifest)
+
+#define _Input
+#define _Output
+
+#define _Optional
+
+#define _StrictCheckInput
+#define _StrictCheckOutput
+
+#define _InOut
+#define _StrictInOut
diff --git a/SDK/Libraries/CoreSystem/Headers/Intl.h b/SDK/Libraries/CoreSystem/Headers/Intl.h
new file mode 100644
index 00000000..b868adca
--- /dev/null
+++ b/SDK/Libraries/CoreSystem/Headers/Intl.h
@@ -0,0 +1,29 @@
+/* -------------------------------------------
+
+ Copyright SoftwareLabs
+
+------------------------------------------- */
+
+#pragma once
+
+/// @brief Intlization primitives.
+
+#include <Headers/Defines.h>
+
+typedef UInt64Type IntlRef;
+
+/// @brief Get app locale.
+/// @param name locale name.
+/// @return
+IntlRef IntlGetLocale(const char* name);
+
+/// @brief Set app locale.
+/// @param intl the locale
+/// @return
+BooleanType IntlSetLocale(const IntlRef intl);
+
+/// @brief locale helpers.
+
+/// @brief translate a string from a locale.
+const CharacterTypeUTF8* Intl(const CharacterTypeUTF8* input,
+ const IntlRef locale);
diff --git a/SDK/Libraries/CoreSystem/Headers/Math.h b/SDK/Libraries/CoreSystem/Headers/Math.h
new file mode 100644
index 00000000..0079803e
--- /dev/null
+++ b/SDK/Libraries/CoreSystem/Headers/Math.h
@@ -0,0 +1,27 @@
+/* -------------------------------------------
+
+ Copyright SoftwareLabs
+
+------------------------------------------- */
+
+#pragma once
+
+#include <Headers/Defines.h>
+
+///////////////////////////////////////////////////////////////////////
+/// Random number generators functions ///
+///////////////////////////////////////////////////////////////////////
+
+/// @brief Number generator helper.
+/// @return Random generated number.
+CS_EXTERN_C SizeType MathRand(VoidType);
+
+///////////////////////////////////////////////////////////////////////
+/// Mathematical functions ///
+///////////////////////////////////////////////////////////////////////
+
+CS_EXTERN_C FloatType Sqrt(FloatType number);
+
+CS_EXTERN_C FloatType Cosine(FloatType number);
+CS_EXTERN_C FloatType Sine(FloatType number);
+CS_EXTERN_C FloatType Tangent(FloatType number); \ No newline at end of file
diff --git a/SDK/Libraries/CoreSystem/Headers/Rsrc.h b/SDK/Libraries/CoreSystem/Headers/Rsrc.h
new file mode 100644
index 00000000..7fe52910
--- /dev/null
+++ b/SDK/Libraries/CoreSystem/Headers/Rsrc.h
@@ -0,0 +1,12 @@
+/* -------------------------------------------
+
+ Copyright SoftwareLabs
+
+------------------------------------------- */
+
+#pragma once
+
+#include <Headers/Defines.h>
+
+/// @file Rsrc.h
+/// @brief RXML forks. \ No newline at end of file
diff --git a/SDK/Libraries/CoreSystem/Headers/Thread.h b/SDK/Libraries/CoreSystem/Headers/Thread.h
new file mode 100644
index 00000000..15b40df3
--- /dev/null
+++ b/SDK/Libraries/CoreSystem/Headers/Thread.h
@@ -0,0 +1,47 @@
+/* -------------------------------------------
+
+ Copyright SoftwareLabs
+
+------------------------------------------- */
+
+//
+// Created by Amlal on 3/18/24
+//
+
+#ifndef __THREAD__
+#define __THREAD__
+
+#include <Headers/Defines.h>
+
+#define kThreadErrorExit (-33)
+
+/// @brief Thread reference.
+typedef QWordType ThreadRef;
+
+/// @brief Main application thread.
+CS_EXTERN_C ThreadRef kMainThread;
+
+typedef VoidType (*ThreadEntrypointKind)(VoidType);
+
+/// @brief Creates a new thread, and runs the code.
+/// @param threadName the thread's name.
+/// @param threadStart where to start.
+/// @return
+CS_EXTERN_C ThreadRef CSThreadCreate(const CharacterTypeUTF8* threadName, ThreadEntrypointKind threadStart);
+
+/// @brief Dispoes the thread, and exits with code kThreadErrorExit
+/// @param ref the thread reference.
+/// @return nothing.
+CS_EXTERN_C VoidType CSThreadRelease(ThreadRef ref);
+
+/// @brief Waits for the thread to complete.
+/// @param ref the thread reference.
+/// @return nothing.
+CS_EXTERN_C VoidType CSThreadJoin(ThreadRef ref);
+
+/// @brief Yields the current thread.
+/// @param ref the thead reference.
+/// @return
+CS_EXTERN_C VoidType CSThreadYield(ThreadRef ref);
+
+#endif // __THREAD__
diff --git a/SDK/Libraries/CoreSystem/Headers/Transport.h b/SDK/Libraries/CoreSystem/Headers/Transport.h
new file mode 100644
index 00000000..3f6db3f1
--- /dev/null
+++ b/SDK/Libraries/CoreSystem/Headers/Transport.h
@@ -0,0 +1,48 @@
+/* -------------------------------------------
+
+ Copyright SoftwareLabs
+
+------------------------------------------- */
+
+//
+// Created by Amlal on 5/12/24
+//
+
+#ifndef __TRANSPORT__
+#define __TRANSPORT__
+
+/// @file: Transport.h
+/// @brief Open Transport Layer, an alternative to berkeley sockets.
+
+#include <Headers/Defines.h>
+
+typedef QWordType TrStreamType;
+
+/// @brief Opens a new socket
+/// @param afType address family
+/// @param sockType type of socket
+/// @param sockProto socket protocol.
+/// @return The STREAMS socket.
+/// @note return is const.
+CS_EXTERN_C CS_CONST TrStreamType CSOpenSocket(UInt32Type afType, UInt32Type sockType, UInt32Type sockProto);
+
+/// @brief Close a STREAMS socket.
+/// @param streams The streams socket.
+/// @return
+CS_EXTERN_C VoidType CSCloseSocket(CS_CONST TrStreamType streams);
+
+/// @brief Get OpenTransport version.
+/// @param void
+/// @return
+CS_EXTERN_C CS_CONST Int32Type CSGetVersion(VoidType);
+
+enum
+{
+ TrSocketProtoTCP, /// TCP socket
+ TrSocketProtoUDP, /// UDP socket
+ TrSocketProtoUN, /// IPC socket
+ TrSocketProtoRaw, /// Raw socket
+ TrSocketProtoCount,
+};
+
+#endif // __TRANSPORT__ \ No newline at end of file