This repository represents the Lynar Studios - Standard Library (ls-std).

Patrick-Christopher Mattulat 1a34d11eb7 Make dll goal strategy more library specific %!s(int64=2) %!d(string=hai) anos
config ce721a93b4 Add SerializableFactory class %!s(int64=3) %!d(string=hai) anos
doc 2bbf2247e8 Add key value file definition %!s(int64=4) %!d(string=hai) anos
include 1a34d11eb7 Make dll goal strategy more library specific %!s(int64=2) %!d(string=hai) anos
source 4c483bdaee Replace nlohmann json type with library core type %!s(int64=2) %!d(string=hai) anos
test 4ee4923ed7 Adjust JSON test to use library core type %!s(int64=2) %!d(string=hai) anos
.gitignore 2ee11bc5fb Extended .gitignore file %!s(int64=4) %!d(string=hai) anos
CMakeLists.txt b71e397ac7 Add CLI Tool for Base64 functionality %!s(int64=2) %!d(string=hai) anos
LICENSE.MIT bbf7536450 Rename LICENSE.txt file %!s(int64=4) %!d(string=hai) anos
README.md 92332a62f0 Add changelog for feature to README.md file %!s(int64=2) %!d(string=hai) anos

README.md

Lynar Studios - Standard Library 2022.2.0

This is a cross-platform standard library written in C++ offering functionalities you would usually miss in C++'s standard template library (STL), especially if you would search for cross-platform implementations.
This library has been tested on Windows, Linux and MacOS systems. Following a modularized approach the following submodules are defined in scope of this library, which are independent:

Boxing

This library module provides boxing classes for primitive data types (e.g. string, int, long, float...) to provide additional functionalities.

Core

The core module is a base module providing a base Class, exceptions, data types and interfaces. Usually the other submodules are dependent on this module.

Encoding

To encode a byte field (e.g. a binary file) for transfer the Base64 encoding / decoding functionality is being provided by this submodule as a first feature.

Event

This submodule comes with an Event class, as well as with handlers and managers to provide an intuitive event handling for your application.

IO

To handle file operations - or to receive information of a file - this library submodule provides an own File class implementation, which can also be passed to library implemented input or output stream classes.
Additionally XML and KV parsing functionalities are provided by this submodule.

Logic

Functionalities provided by this submodule support your project with some nice logical features. The first one being provided by it is a state machine.

Time

A Date class comes with this submodule, which you can use to represent a date and do operations on it.


Changelog

Features

  • this library is now being compiled with C++ 17 standard
  • this library can now build shared libraries by using MSVC
  • Clang support has been added to this library
  • added Base64 CLI Tool, which enables a user to use Base64 encoding and decoding functionalities via CLI
  • JSON type alias has been added to avoid direct nlohmann library usage

Improvements

  • none

Fixes

  • none

Documentation

You can find a detailed documentation on Lynar Studios Website: lynarstudios.com


License

This software is licensed and uses MIT-license. You can find a LICENSE.MIT file inside the project's root directory.


Building

To build this library you'd need a recent version of cmake and your OS specific compiler collection, like gcc or MinGW installed.
Inside project's root directory create the following folder:

cmake_build_release

Open your OS specific command line interface (CLI) and navigate to this new folder and run the following command to configure the project and generate a native build system:

cmake ../

Inside cmake_build_release folder you will now find cmake generated files. To compile the library now, just run:

cmake --build . --config Release

Please note: Currently only a small set of compilers is officially supported. If you'd like to compile with an unsupported compiler, you have to set LS_STD_BUILD_WITH_SUPPORTED_COMPILER - option in CMakeLists.txt file to OFF - then reset and reload the cmake project.

Find below a table of compiler/OS combinations which have been tested during library version development:

Supported Compiler OS Compiler Version
GCC Linux Mint 20.3 12.1.0
Clang Linux Mint 20.3 12.0.0-3ubuntu1~20.04.5
MinGW-w64 / GCC Windows 10 11.2.0
MSVC Windows 10 19.32.31332.0

Add Library To Your CMake Project

If you would like to add this library to your CMake project (CMakeLists.txt file), make sure that you would add the libraries' include directory:

include_directories(${CMAKE_CURRENT_LIST_DIR}/path/to/this/library/include)

Then link the libraries' binary file inside your CMakeLists.txt file:

target_link_libraries(... libls_std_core libls_std_boxing ...)

Testing

This project contains unit tests to provide test coverage.
To run those tests you have to build this project with option LS_STD_BUILD_WITH_TESTS set to ON - then reset and reload the CMake project.