Rantjs
Procedurally generate text with JavaScript
Install / Use
/learn @robbestad/RantjsREADME
Rantjs
Rantjs is a procedural text generator. The goal is to augment human creativity with the boundless potential of randomness. Inspired by Rant.
<img src="http://res.cloudinary.com/sven-anders-robbestad/image/upload/c_scale,w_350/v1418975366/rantjs_0.8.4.png">The project is available via npm (do npm install rantjs).
Demo and more information
Interactive demo available here
Click here for a writeup on my blog
Usage
var rant = require("rantjs");
var sentence=rant('<firstname male> likes to <verb-transitive> <noun.plural> with <pron poss male> pet <noun-animal> on <timenoun dayofweek plural>.');
console.log(sentence); // 'Sean likes to chop parrots with his pet cat on Saturdays.'
For implementation details, please visit the npmjs page
Install
git clone https://github.com/svenanders/rantjs && cd rantjs
npm i
gulp serve
Then open http://localhost:8000
Development Plan
Easy way to choose alternative dictionaries
Indefinite article (a/an) automation
Overwriting (targets)
~~Capitalisation~~
~~Looping (repeaters)~~
Conditionals
Contributions
Contributions are welcome. Feel free to submit an issue/pull request. The following areas are of particular interest:
Documentation (wiki/code)
Fixing bugs
Optimization
Functions in the development plan
New language features
Testing. Currently, this is the result of the coverage report:
Statements : 96.44% ( 461/478 )
Branches : 67.65% ( 46/68 )
Functions : 100% ( 18/18 )
Lines : 97.24% ( 458/471 )
Ideally, it should be 100% on everything
New in version 1.0.0
Added option for custom dictionaries. Note that this replaces the built-in dictionary.
var yourCustomDic = {}
...
rant('your text', yourCustomDic);
A sample dictionary file can be found in the ./src folder. Also take a look at the built-in english dicionary in the same folder for reference.
New in version 0.9.x
0.9.7 - Added nonsense verbs from Rantionary
0.9.5 - Added verbs for success and defeat
0.9.4 - Added Death (<verb death>)
0.9.3 - Added climb (<verb climb up|down>)
New in version 0.9.1
Rewrote Rantjs for CommonJS.
Removed several gulp tasks (concat, minify)
Refactored the tests
Renamed the app internally
New usage syntax (not compatible with 0.8.x)
You can now call Rantjs directly from require:
var sentence=require("rantjs")("<firstname male> likes to <verb-transitive>
<noun.plural> with <pron poss male> pet <noun-animal> on <timenoun dayofweek plural>.");
Added randomization:
require("rantjs")("A random string: [rep:8][sep:\N]{\C}");
//A random string: XUACJGOGN
New in version 0.8.6
Added support for [rep:x]
Usage:
[case:title][sep:\n][rep:3]{I like <noun animal plural> but not <noun animal plural>}
// I Like Ogres but not Turtles
// I Like Bulls but not Horses
// I Like Poodles but not Owls
Note: [sep:\n] dictates newlines. Alternatively, you can specify \s for space.
New in version 0.8.5
Added support for [case]-tag.
Usage:
[case:upper]<firstname male>
Variants:
[case:none|default|word|upper|lower|case|sentence]
Related Skills
node-connect
342.5kDiagnose OpenClaw node connection and pairing failures for Android, iOS, and macOS companion apps
frontend-design
85.3kCreate distinctive, production-grade frontend interfaces with high design quality. Use this skill when the user asks to build web components, pages, or applications. Generates creative, polished code that avoids generic AI aesthetics.
openai-whisper-api
342.5kTranscribe audio via OpenAI Audio Transcriptions API (Whisper).
qqbot-media
342.5kQQBot 富媒体收发能力。使用 <qqmedia> 标签,系统根据文件扩展名自动识别类型(图片/语音/视频/文件)。
