computron

Computron is a Node.js library to apply XSLT stylesheets to XML documents.

Usage no npm install needed!

<script type="module">
  import computron from 'https://cdn.skypack.dev/computron';
</script>

README

Build and test status npm version

Computron

Computron is a Node.js library to apply XSLT stylesheets to XML documents. It's a C++ addon for Node.js that uses libxml2 and libxslt.

Disclaimer

This library is only intended to be used on Linux.

Requirements

You must have libxml2 and libxslt1 installed on your system.

sudo apt install libxml2-dev libxslt1-dev

You should already have a C++ compiler installed on your system, if it's not the case install g++.

sudo apt install g++

Computron uses node-gyp as a build system so you need to install it to be able to compile Computron

npm install -g node-gyp

Usage

Basic example:

const Computron = require('computron');
const computron = new Computron();

computron.loadStylesheet('/path/to/stylesheet', (_err) => {
  if (_err) throw _err;

  // null is passed as second argument because the stylesheet doesn't take any parameters
  computron.apply('/path/to/xml', null, (err, result) => {
    if (err) throw err;

    console.log(result);
  });
});

Using a stylesheet that takes parameters:

const Computron = require('computron');
const computron = new Computron();

computron.loadStylesheet('/path/to/stylesheet-with-params', (_err) => {
  if (_err) throw _err;

  computron.apply('/path/to/xml', { param1Name: 'param1Value', param2Name: 'param2Value' }, (err, result) => {
    if (err) throw err;

    console.log(result);
  });
});

Development

To build and run the tests in release mode run:

npm test

You can debug the C++ code with in VSCode, to do so run:

npm run build:config

This will build the VSCode debugger configuration, you can then simply press F5 or go to the "Run and Debug" tab and click on "Debug".