Files
Uniglot/README.md
DarkFeather 3538b44a20 New hooks: find-data-files to ensure that data files are not added
make-sure-hooks-synced to ensure that hooks are committed consistently
to checker.

Updates to README.md to document standard directories

Adding Resources as standard files for all repos to consume.
2025-10-09 09:59:46 -05:00

3.8 KiB

This repo holds all our standard functions that all our services should use. We include a folder for each language -- files are broken down by their inclusion method. Please follow our development best practices when contributing.

Some other functions served by this repo are included below.

Etymology

Uniglot is derived from the idea of a universal language to be used by all projects. Uni means one, and glot is defined as '"speaking, writing, or written in a language" of the kind or number specified by the initial element'. So, Uniglot is thereby the single language used by all AniNIX projects. This refers both to the library files contained here and the universal hooks used in AniNIX development.

Relevant Files and Software

Example Packaging

This repo does have some example packaging for use in downstream projects. The Makefile and PKGBUILD are standards the AniNIX should maintain throughout their projects.

Executables

The following executables are available:

  • uniglot-clone ensures that when repos are cloned, they are attached to the standard Uniglot hooks.
  • home-git is support for User Support Repositories.

Hooks

The Hooks folder includes a standard pre-commit and pre-receive that will be enforced across repos. These pre-commit and pre-receive will enforce the contents of Hooks/scripts.d. This allows us to enforce standards of quality across the ecosystem.

Notably, each repo that subscribes to this enforcement can also commit their own standards in addition to global standards. Python tests should go in a folder called tests/ and scripts in a folder called precommit-hooks/. These will be run in addition to the global hooks.

Consumed Directories

When used with uniglot-clone, there are several directories at which AniNIX/Uniglot's hooks will look.

  • the rss/ directory will be used by Hooks/scripts.d/generate-rss-snippet on a webserver to publish snippets. See /AniNIX/Kapisi/src/branch/main/roles/Foundation/files/custom/public/assets/js/aninix.js#L2 for options to consume these snippets in a webpage. This allows each repo to publish new updates in one place and webpages to show it in addition to https://singularity.aninix.net and other readers.
  • The tests/ directory will be used by Hooks/scripts.d/pytest to run Python unit tests on a repo. Any code should be wrapped with automated regressions.
  • The precommit-hooks directory will be used by Hooks/scripts.d/local-hooks. This allows individual repos to use our general hooks and then add on specific tests on top, such as lint checkers or consistency checkers.

Standard Libraries

Each language for which we have libraries should have its own folder. Breakdown within each of these may be broken up by line count or topic, at the author's discretion. Once an include standard has been set, though, it should be preserved. For example, if functions in the Bash header are to be broken out into subordinate files, then the Bash header should include these files that contain functions formally in itself.

Available Clients

The clients for this package are the compilers for the various languages represented.

  • bash for Bash
  • mono for C#
  • gcc for C
  • javac for Java

The hooks can be consumed by git when uniglot-clone is run on a repo.

Equivalents or Competition

The equivalents for this are the -headers or -libs packages for other projects. There is not really competition, as these are things specific for our development environment.