Over the last several years I’ve folded in the codemeta.json file as a data source for building and releasing software for Caltech Library. Initially I used a tool I wrote called “codemeta2cff”. It did one thing which was create a CITATION.cff from the codemeta.json file. Over time I wound up reusing the CodeMeta to generate version files for Go, Python, JavaScript and TypeScript projects. I wound up generating the “about.md” file from CodeMeta content too. The evolution was organic and resulted in a series of scripts, Makefile rules and Pandoc templates. CodeMeta Tools is a consolidation of that evolution into a single simple tool. It also integrated other data like Git repository hash and compile dates. You can now use a single tool to generate your CITATION.cff, about.md and version files with a single tool. This streamlines the setup of projects as well as maintain these various files from a single source of truth held in the codemeta.json file.
So why is this significant? The metadata held in our CodeMeta JSON file is very helpful when integrating into software repositories like CaltechDATA. While my initial focus in adopting CodeMeta was documentation for my projects I think it can play a common role across projects regardless of implementation language. On the command line this means you can easily have a consistent “version” response indicating not just the semver and program name but also the Git hash and compile date. This is important for support reasons. As we evolve programs that are deployed on individual computers users often don’t update their software. Knowing that they are running a different version than the currently supported one can cut down the time needed to diagnosis issues. Similarly if we introduce a regression in a new version we can check to see if the fix got applied because the Git hash in the version string will change on each commit. For server software having consistent version info serves a similar role.
The following files are common in my projects and other’s projects at Caltech Library.
Having a CM Tool that can generate these means the build processes can be simplified and can more easily translate across the POSIX and Windows divide.
The common files that can use the information in the CodeMeta file are likely to grow over time. The implementation of CM Tools should make it easy to add additional transformations as needed.
Right now my build processes require Pandoc. Pandoc isn’t something that most developers think about as part of their build tool chain outside of building websites. With an easy to install command line tool the Pandoc dependency can be removed.
CM Tools is implemented as a TypeScript program compiled using
Deno. The cmt
is a “static
binary”[^1] that can be “installed” with a simple copy command.
TypeScript was chosen because it is a superset of JavaScript which is
one of the most common programming languages in the early 21st century.
This is the type of tool that will benefit from community contributions.
Deno provide easy cross platform compilation for our supported operating
systems – macOS, Windows and Linux. Deno and TypeScript together provide
many of the advantages of our Go based utilities with the advantage of a
large part of the Library, Archives and Museum developer communities
that could potentially contribute.
The architecture of CM Tools is a series of small TypeScript files
cmt
command and holds the
version info for CM Tools