|  | 4 days ago | |
|---|---|---|
| .. | ||
| VS2022 | 2 months ago | |
| LICENSE | 2 months ago | |
| Makefile | 3 weeks ago | |
| README.md | 1 month ago | |
| examples_report.md | 6 days ago | |
| examples_report_issues.md | 6 days ago | |
| rexm.c | 4 days ago | |
| rexm.ico | 2 months ago | |
| rexm.rc | 2 months ago | |
| rexm.rc.data | 2 months ago | |
rexm - raylib examples managerrexm is a raylib support tool to help to manage the raylib examples collection.
raylib has a big collection of examples to learn how to use the library. It started with just a few examples and it has grown to +160 in the last 12 years, with many of those examples contributed by the community (~50%).
Managing those examples has become a considerable amount of work. Some years ago an examples template was created to standarize examples format and contents, it simplified the review process but implementing a new example is not enough; adding/modifying an new example from the collection implies a series of actions:
.c code file, following provided examples template guidelines.
resource directory, make sure they are based in a permissive licenseMakefile: multi-platform build configurationMakefile.Web: specific Web building configurationREADME.md table, in corerct categoryraylib.com open-source repositoryraylib.com webpage to include example running on real-timeAll the following files need to be require to be review every time an examples is added or modified:
  - Add: raylib/examples/<category>/<category>_example_name.c
  - Add: raylib/examples/<category>/<category>_example_name.png
  - Add: raylib/examples/<category>/resources/..
  - Edit: raylib/examples/Makefile
  - Edit: raylib/examples/Makefile.Web
  - Add: raylib/projects/VS2022/examples/<category>_example_name.vcxproj
  - Edit: raylib/projects/VS2022/raylib.sln
  - Edit: raylib/examples/README.md
  - Edit: raylib.com/common/examples.js
  - Generate: raylib.com/examples/<category>/<category>_example_name.html
  - Generate: raylib.com/examples/<category>/<category>_example_name.data
  - Generate: raylib.com/examples/<category>/<category>_example_name.wasm
  - Generate: raylib.com/examples/<category>/<category>_example_name.js
This process has been done manually for many years and required a lot of time, it was also very prone to errors, like missing some edits or adding typos.
Finally I decided to automatize the process and create a pipeline to add, rename, remove, validate and build examples automatically edited. Additionally I decided to a validation process to verify the integrity of all the required files and even fix some of the potential issues.
rexm supported commandsThe following commands are supported by rexm to manage examples:
  help                          : Provides command-line usage information
  create <new_example_name>     : Creates an empty example, from internal template
  add <example_name>            : Add existing example, category extracted from name
                                  Supported categories: core, shapes, textures, text, models
  rename <old_examples_name> <new_example_name> : Rename an existing example
  remove <example_name>         : Remove an existing example
  build <example_name>          : Build example for Desktop and Web platforms
  validate                      : Validate examples collection, generates report
  update                        : Validate and update examples collection, generates report
rexm examples validation and updateTwo commands have been added to rexm to validate all the examples, checking if the examples follow all requirements and all the files needed are available, that way the examples review has been automated, generating complete tables on examples status.
As we were able to detect possible examples errors and inconsistencies, an additional command was implemented to update all examples with inconsistencies.
rexm technology usedUsually this kind of pipelines are implemented with high-level scripting languages like Python due to all the functionality already provided, specially useful for files/paths management or text files editing but those languages also require the interpreter available to run. I decided to follow a less common route, implementing the tool directly in C, the language I use for raylib and all my tools.
C standard library does not provide a lot of the high-level functionality required for files and text management but here is where raylib came to the rescue. raylib already contained some functions to work with the file system and to manage text, so I decided to implement the required additional ones to use raylib on pipelines building.
The main benefit of using C and raylib is that the pipeline can be created in C and it can be build int an independent multi-platform dependency-free executable tool; it also open the door for a possible expansion into a UI interface, if required in the future.
As mentioned, implementing the pipeline in C with raylib required some additional support functions to be added, to simplify some tasks and align with functionality provided by high-level languages; but it was not dramatic and the truth is that the development process just flowed smoothly.
Some of the support functions implemented:
// File management functions
int FileRename(const char *fileName, const char *fileRename); // Rename file (if exists)
int FileRemove(const char *fileName); // Remove file (if exists)
int FileCopy(const char *srcPath, const char *dstPath); // Copy file from one path to another, dstPath created if it doesn't exist
int FileMove(const char *srcPath, const char *dstPath); // Move file from one directory to another, dstPath created if it doesn't exist
int FileTextReplace(const char *fileName, const char *search, const char *replacement); // Replace text in an existing file
iint FileTextFindIndex(const char *fileName, const char *search); // Find text in existing file
// Text management functions
char **LoadTextLines(const char *text, int *count);  // Load text lines from text block, separate by '\n'
void UnloadTextLines(char **text); // Unload text lines
const char *TextRemoveSpaces(const char *text); // Remove text spaces, concat words
char *GetTextBetween(const char *text, const char *begin, const char *end); // Get text between two strings
char *TextReplace(const char *text, const char *search, const char *replacement); // Replace text string
char *TextReplaceBetween(const char *text, const char *begin, const char *end, const char *replacement); // Replace text between two specific strings
These functions have been added to raylib main library.
rexm is an open source project, licensed under an unmodified zlib/libpng license
Copyright (c) 2025 Ramon Santamaria (@raysan5)