@thesharks/jagtag-js
v2.0.0
Published
A JavaScript port of https://github.com/jagrosh/JagTag.
Downloads
25
Readme
JagTag-JS
A JavaScript port of the JagTag text parsing language, originally written in Java by @jagrosh.
What is JagTag?
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}.
How does this differ?
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.
Installation and usage
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:
const JagTagParser = require('@thesharks/jagtag-js')
JagTagParser('string to parse', argsObject)
For more information about the args object, see the API reference.
Simple example
At its most basic level, JagTag-JS can be used to perform simple string-related operations without any complications.
const JagTagParser = require('@thesharks/jagtag-js')
JagTagParser('change {upper:this} to uppercase')
// Returns 'change THIS to uppercase'
Advanced example
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.
const JagTagParser = require('@thesharks/jagtag-js')
JagTagParser('{argslen} arguments were passed to this tag', { tagArgs: [ 'item1', 'item2', 'item3' ] })
// Returns '3 arguments were passed to this tag'
String interpolation
Since Javascript will attempt to interpret strings such as '\d'
as character escapes, it's recommended to call the parser using String.raw
.
const JagTagParser = require('@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"
Contributing
See CONTRIBUTING.md.