summaryrefslogtreecommitdiffhomepage
path: root/dev/BuildKit
diff options
context:
space:
mode:
Diffstat (limited to 'dev/BuildKit')
-rw-r--r--dev/BuildKit/Defines.h30
-rw-r--r--dev/BuildKit/IManifestBuilder.h31
-rw-r--r--dev/BuildKit/Imports.h19
-rw-r--r--dev/BuildKit/JSONManifestBuilder.h33
-rw-r--r--dev/BuildKit/TOMLManifestBuilder.h33
5 files changed, 146 insertions, 0 deletions
diff --git a/dev/BuildKit/Defines.h b/dev/BuildKit/Defines.h
new file mode 100644
index 0000000..d408058
--- /dev/null
+++ b/dev/BuildKit/Defines.h
@@ -0,0 +1,30 @@
+// ============================================================= //
+// nebuild
+// Copyright (C) 2024-2025, Amlal El Mahrouss, all rights reserved.
+// ============================================================= //
+
+#pragma once
+
+#include <BuildKit/Imports.h>
+
+#define LIKELY(ARG) ((ARG) ? assert(false) : ((void) 0))
+#define UNLIKELY(ARG) LIKELY(!(ARG))
+
+#define LIBNEBUILD_VERSION "v0.0.1-libNeBuild"
+
+#define LIBNEBUILD_VERSION_BCD 0x0001
+
+#define LIBNEBUILD_VERSION_MAJOR 1
+#define LIBNEBUILD_VERSION_MINOR 1
+#define LIBNEBUILD_VERSION_PATCH 0
+
+#define LIBNEBUILD_UNUSED(X) ((void) X)
+
+namespace NeBuild::Logger {
+/// @brief replacement for std::cout for NeBuild logging.
+inline std::ostream& info() noexcept {
+ auto& out = std::cout;
+ out << rang::fg::red << "nebuild: " << rang::style::reset;
+ return out;
+}
+} // namespace NeBuild::Logger
diff --git a/dev/BuildKit/IManifestBuilder.h b/dev/BuildKit/IManifestBuilder.h
new file mode 100644
index 0000000..c1d45d0
--- /dev/null
+++ b/dev/BuildKit/IManifestBuilder.h
@@ -0,0 +1,31 @@
+// ============================================================= //
+// nebuild
+// Copyright (C) 2024-2025, Amlal El Mahrouss, all rights reserved.
+// ============================================================= //
+
+#pragma once
+
+#include <BuildKit/Defines.h>
+
+#define NEBUILD_MANIFEST_BUILDER : public NeBuild::IManifestBuilder
+
+namespace NeBuild {
+/// @brief Builder interface class.
+/// @note This class is meant to be used as an interface.
+class IManifestBuilder {
+ public:
+ IManifestBuilder() = default;
+ virtual ~IManifestBuilder() = default;
+
+ IManifestBuilder& operator=(const IManifestBuilder&) = default;
+ IManifestBuilder(const IManifestBuilder&) = default;
+
+ /// @brief Builds a target using the implemented laguage.
+ /// @param arg_sz filename size
+ /// @param arg_val filename path.
+ /// @retval true succeeded.
+ /// @retval false failed.
+ virtual bool BuildTarget(const std::string& arg, const bool dry_run = false) = 0;
+ virtual const char* BuildSystem() = 0;
+};
+} // namespace NeBuild \ No newline at end of file
diff --git a/dev/BuildKit/Imports.h b/dev/BuildKit/Imports.h
new file mode 100644
index 0000000..c542737
--- /dev/null
+++ b/dev/BuildKit/Imports.h
@@ -0,0 +1,19 @@
+// ============================================================= //
+// nebuild
+// Copyright (C) 2024-2025, Amlal El Mahrouss, all rights reserved.
+// ============================================================= //
+
+#ifndef NEBUILD_INCLUDES_H
+#define NEBUILD_INCLUDES_H
+
+#include <rang/rang.h>
+#include <cassert>
+#include <cstddef>
+#include <cstdio>
+#include <fstream>
+#include <iostream>
+#include <sstream>
+#include <string>
+#include <thread>
+
+#endif // NEBUILD_INCLUDES_H
diff --git a/dev/BuildKit/JSONManifestBuilder.h b/dev/BuildKit/JSONManifestBuilder.h
new file mode 100644
index 0000000..63a67b7
--- /dev/null
+++ b/dev/BuildKit/JSONManifestBuilder.h
@@ -0,0 +1,33 @@
+// ============================================================= //
+// nebuild
+// Copyright (C) 2024-2025, Amlal El Mahrouss, all rights reserved.
+// ============================================================= //
+
+#pragma once
+
+#include <BuildKit/IManifestBuilder.h>
+#include <json/json.h>
+
+/// @file JSONManifestBuilder.h
+/// @brief JSON manifest builder header file.
+
+namespace NeBuild {
+/// @brief JSON builder
+class JSONManifestBuilder final NEBUILD_MANIFEST_BUILDER {
+ public:
+ JSONManifestBuilder() = default;
+ ~JSONManifestBuilder() override = default;
+
+ JSONManifestBuilder& operator=(const JSONManifestBuilder&) = default;
+ JSONManifestBuilder(const JSONManifestBuilder&) = default;
+
+ public:
+ /// @brief Builds a JSON target.
+ /// @param arg_sz filename size
+ /// @param arg_val filename path.
+ /// @retval true build succeeded.
+ /// @retval false failed to build.
+ bool BuildTarget(const std::string& arg_val, const bool dry_run = false) override;
+ const char* BuildSystem() override;
+};
+} // namespace NeBuild \ No newline at end of file
diff --git a/dev/BuildKit/TOMLManifestBuilder.h b/dev/BuildKit/TOMLManifestBuilder.h
new file mode 100644
index 0000000..10a8200
--- /dev/null
+++ b/dev/BuildKit/TOMLManifestBuilder.h
@@ -0,0 +1,33 @@
+// ============================================================= //
+// nebuild
+// Copyright (C) 2024-2025, Amlal El Mahrouss, all rights reserved.
+// ============================================================= //
+
+#pragma once
+
+#include <BuildKit/IManifestBuilder.h>
+#include <toml++/toml.hpp>
+
+/// @file TOMLManifestBuilder.h
+/// @brief TOML manifest builder header file.
+
+namespace NeBuild {
+/// @brief TOML builder
+class TOMLManifestBuilder final NEBUILD_MANIFEST_BUILDER {
+ public:
+ TOMLManifestBuilder() = default;
+ ~TOMLManifestBuilder() override = default;
+
+ TOMLManifestBuilder& operator=(const TOMLManifestBuilder&) = default;
+ TOMLManifestBuilder(const TOMLManifestBuilder&) = default;
+
+ public:
+ /// @brief Builds a TOML target.
+ /// @param arg_sz filename size
+ /// @param arg_val filename path.
+ /// @retval true build succeeded.
+ /// @retval false failed to build.
+ bool BuildTarget(int arg_sz, const char* arg_val, const bool dry_run = false) override;
+ const char* BuildSystem() override;
+};
+} // namespace NeBuild \ No newline at end of file