Giter VIP home page Giter VIP logo

remark's Introduction

remark

Build Status Coverage Status Inline docs

⚠️

remark recently underwent quite some changes. For one, it’s name changed from mdast. This means all the plug-ins in the ecosystem need to change names too, which may result in some turbulence the coming weeks (but most of the dust has already settled).

Read more about what changed and how to migrate »

remark is a markdown processor powered by plugins. Lots of tests. Node, io.js, and the browser. 100% coverage.

remark is not just another markdown to HTML compiler. It can generate, and reformat, markdown too. It is powered by plugins to do all kinds of things: validate your markdown, add links for GitHub references, or add a table of contents.

The project contains both an extensive JavaScript API for parsing, modifying, and compiling markdown, and a friendly Command Line Interface making it easy to validate, prepare, and compile markdown in a build step.

Table of Contents

Installation

npm:

npm install remark

Read more about alternatives ways to install and use »

Usage

Load dependencies:

var remark = require('remark');
var html = require('remark-html');
var yamlConfig = require('remark-yaml-config');

Use plugins:

var processor = remark().use(yamlConfig).use(html);

Process the document:

var doc = processor.process([
    '---',
    'remark:',
    '  commonmark: true',
    '---',
    '',
    '2) Some *emphasis*, **strongness**, and `code`.'
].join('\n'));

Yields:

<ol start="2">
<li>Some <em>emphasis</em>, <strong>strongness</strong>, and <code>code</code>.</li>
</ol>

API

Get Started with the API »

remark.process(value, options?, done?)

Parse a markdown document, apply plugins to it, and compile it into something else.

Signatures

  • doc = remark.process(value, options?, done?).

Parameters

  • value (string) — Markdown document;

  • options (Object) — Settings:

  • done (function(Error?, string?)) — Callback invoked when the output is generated with either an error, or a result. Only strictly needed when asynchronous plugins are used.

All options (including the options object itself) can be null or undefined to default to their default values.

Returns

string or null: A document. Formatted in markdown by default, or in whatever a plugin generates. The result is null if a plugin is asynchronous, in which case the callback done should’ve been passed (do not worry: plugin creators make sure you know its asynchronous).

remark.use(plugin, options?)

Change the way remark works by using a plugin.

Signatures

  • processor = remark.use(plugin, options?);
  • processor = remark.use(plugins).

Parameters

  • plugin (Function) — A Plugin;
  • plugins (Array.<Function>) — A list of Plugins;
  • options (Object?) — Passed to plugin. Specified by its documentation.

Returns

Object: an instance of Remark: The returned object functions just like remark (it has the same methods), but caches the used plugins. This provides the ability to chain use calls to use multiple plugins, but ensures the functioning of the remark module does not change for other dependents.

CLI

Get Started with the CLI »

Install:

npm install --global remark

Use:

Usage: remark [options] <pathspec...>

Markdown processor powered by plugins

Options:

  -h, --help                output usage information
  -V, --version             output the version number
  -o, --output [path]       specify output location
  -c, --config-path <path>  specify configuration location
  -i, --ignore-path <path>  specify ignore location
  -s, --setting <settings>  specify settings
  -u, --use <plugins>       use transform plugin(s)
  -e, --ext <extensions>    specify extensions
  -w, --watch               watch for changes and reprocess
  -a, --ast                 output AST information
  -q, --quiet               output only warnings and errors
  -S, --silent              output only errors
  -f, --frail               exit with 1 on warnings
  --file-path <path>        specify file path to process as
  --no-stdout               disable writing to stdout
  --no-color                disable color in output
  --no-rc                   disable configuration from .remarkrc
  --no-ignore               disable ignore from .remarkignore

See also: man 1 remark, man 3 remark,
  man 3 remarkplugin, man 5 remarkrc,
  man 5 remarkignore, man 7 remarksetting,
  man 7 remarkconfig, man 7 remarkplugin.

Examples:

  # Process `readme.md`
  $ remark readme.md -o readme-new.md

  # Pass stdin(4) through remark, with settings, to stdout(4)
  $ remark --setting "setext: true, bullet: \"*\"" < readme.md > readme-new.md

  # Use a plugin (with options)
  $ npm install remark-toc
  $ remark readme.md --use "toc=heading:\"contents\"" -o

  # Rewrite markdown in a directory
  $ remark . -o

License

MIT © Titus Wormer

This project was initially a fork of marked.

Copyright (c) 2011-2014, Christopher Jeffrey. (MIT License)

remark's People

Contributors

anandthakker avatar apaleslimghost avatar ben-eb avatar briancavalier avatar chjj avatar chriswren avatar comuttun avatar eush77 avatar guybedford avatar ianstormtaylor avatar ifraixedes avatar isaacs avatar jasonkarns avatar juliantaylor avatar kitsonk avatar lepture avatar matsko avatar mikeal avatar minrk avatar mithgol avatar mkozhukh avatar moox avatar odbol avatar omeid avatar selfcontained avatar thejhh avatar tmcw avatar wooorm avatar wzr1337 avatar zaggino avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.