npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

mush-format

v0.3.17

Published

A javascript library that minifies pretty formatted mushcode.

Downloads

11

Readme

MUSH Formatter

header

a javaScript library designed to take mushcode from something readable to something you can quote directly into your game.

Install

with npm, save as a dependancy

npm i mush-format --save

Simple Usage

Mush Format is, at it's core a middleware system, very close to express JS.

const Formatter = require(mush-format)
const formatter = new Formatter();

const results = await formatter.format("path/to/code.mu")
console.log(results.text)

Extending The Formatter

Mush Format is at it's heart a middleware system close to ExpressJS. To install a middleware

app.use("step", middleware)

Writing middleware is very similar to writing it for express, including the usge of a next() function to call the next middleware system in line. It's a function that takes two arguments data and next.

app.use("step", (data, next) => {

  // ... code to run

})

Steps

There are 5 steps when formatting code.

  • Pre - These middleware functions are performed before formatting begins.
  • Open - Open all of the connected documents and stitch them together.
  • Render - This step is used to read any #meta tags and execute appropriate actions.
  • Compress - Remove all formatting and unevaluated meta tags, and minify the code so it can be quoted.
  • Finish - Any changes that need to be made post formatting. Headers and footers are set in this step.

Data

The data object carries information between connected middleware, and steps. Here are a few highlights of important args:

data = {
  // The original string that kicked
  // off the Command
  input: "",

  // The current file/URL that mush formatter
  // is working with.
  curFile: "",

  // The base URL or directory.
  base: "",

  // this is the stitched together
  // document from any included ode.
  raw: "",

  // The final, game ready code.
  text: "",

  // Stores header title/value
  // key-pairs.
  headers: [],

  // Same thing, only with footer tags
  footers: [],

  // Any messages from the process
  // of working with the file, text,
  // archive or directory.
  log: []
}

next(error, data)

Use the next function to route any errors, and pass data onto the next middleware function. If you forget to include next the software will hang.

module.exports = (data, next) => {

  // .... Accomplish some stuff ....

  next(null, data)

}

Meta Tags

Meta tags allow you to extend the base functionality of your code, from installing other libraries, to setting compiler time variables and even adding entire blocks of code at run time.

include /path/to/file.mu

this #meta allows you to import a file (or entire Github repository) into the current file. #include accepts three kinds of files right now:

Local File You can designate a local file to include, entering the ./path/to/file.mu format. Local Directory If you list a directory, Mu-Format will look for a file called installer.mu and kick off the #include from there. Github Archive This is the same as installing from a local directory, instead you'll you'll enter the full address to the base repo https://github.com/<user>/<repo>.

#file ./path/to/file

Honestly #file works list like #include, except it escapes each line of text with a MUSH null string @@ so they don't get quoted to the Game. This is great for things like license files, and other custom comments text.

#header or #footer <key>=<value>

Add key/value information to be listed at the very top or bottom of the resulting file. #header version=1.0.0 escapes into: @@ version 1.0.0 at the top of the resulting document.

#debug{}

Debug allows you to add code only when the debug flag is set to true.


#header debug = true

#debug{

@set me=quiet
@pemit me= Game>> Installing Blah.. Notes and stuff.

}

Formatting Rules

The rules of the game are pretty simple. If the first column of a line isn't a comment, space or newline, it interprets it as the beginning of a line. If your line begins with any of the above things, it'll be removed. An example:

// This line won't render
&command.cmd #123 = $things:
  @pemit %#=And Stuff. // this line will be added to the first.

Translates to:

&command.cmd #123=$things: @pemit %#=And Stuff

You can add your meta tags anywhere, and if you want an extra newline in your minified code use a single dash - on a line.

@@ minified code comment
-

// This line won't render
&command.cmd #123 = $things:
  @pemit %#=And Stuff. // this line will be added to the first.

Minifies to:

@@ minified code comment

&command.cmd #123=$things: @pemit %#=And Stuff

Where normally the space would have been eaten by the minifier.