A JavaScript port of the JagTag text parsing language, originally written in Java by @jagrosh.
This readme only covers technical information about JagTag-JS, for more comprehensive documentation about JagTag itself please see the Spectra wiki and the original JagTag repo
JagTag is, in the author's own words, a simple yet powerful and customisable interpreted text parsing language. In practice, JagTag notation is used to customise user input with tags which use the format {name:arg1|arg2}.
First of all, the implementation of JagTag has been ported to JavaScript. The key thing to note here is that the actual code has not been ported due to language limitations. Instead, this system is essentially JagTag notation implemented in JavaScript with a slightly different methodology.
Due to language-level limitations, some of the methods are also not fully compatible. This project has been developed with maximum compatibility in mind, but some minor changes have been made. More details can be found in the documentation.
It's worth noting that the Discord-related tag functions have been developed to suit Eris and have not been tested with other libraries. For now it's recommended to use Eris in conjunction with the Discord-related tags, if you wish to use those.
JagTag-JS is available on NPM and you can install it with npm i @thesharks/jagtag-js
. Make sure you have Node.js >= 8 installed.
Basic syntax:
import JagTagParser from '@thesharks/jagtag-js'
JagTagParser('string to parse', argsObject)
For more information about the args object, see the API reference.
At its most basic level, JagTag-JS can be used to perform simple string-related operations without any complications.
import JagTagParser from '@thesharks/jagtag-js'
JagTagParser('change {upper:this} to uppercase')
// Returns 'change THIS to uppercase'
More advanced operations may require you to pass arguments to the parser in order to function correctly. Please check the documentation for information on what parser-level arguments need to be passed for which method.
import JagTagParser from '@thesharks/jagtag-js'
JagTagParser('{argslen} arguments were passed to this tag', { tagArgs: [ 'item1', 'item2', 'item3' ] })
// Returns '3 arguments were passed to this tag'
Since Javascript will attempt to interpret strings such as '\d'
as character escapes, it's recommended to call the parser using String.raw
.
import JagTagParser from '@thesharks/jagtag-js'
JagTagParser('{replaceregex:\d|with:#|in:I have 5 cats and 23 shirts}')
// Returns: "I have 5 cats an# 23 shirts"
// Probably not what you wanted!
JagTagParser(String.raw`{replaceregex:\d|with:#|in:I have 5 cats and 23 shirts}`)
// Returns: "I have # cats and ## shirts"
See CONTRIBUTING.md.