micromark-factory-destination
micromark factory to parse destinations (found in resources, definitions)
Last updated 3 years ago by wooorm .
MIT · Repository · Bugs · Original npm · Tarball · package.json
$ gnpm install micromark-factory-destination 
SYNC missed versions from official npm registry.

micromark-factory-destination

Build Coverage Downloads Size Sponsors Backers Chat

micromark factory to parse destinations (found in resources, definitions).

Contents

Install

npm:

npm install micromark-factory-destination

Use

import {factoryDestination} from 'micromark-factory-destination'
import {codes} from 'micromark-util-symbol/codes'
import {types} from 'micromark-util-symbol/types'

// A micromark tokenizer that uses the factory:
/** @type {Tokenizer} */
function tokenizeResource(effects, ok, nok) {
  return start

  // …

  /** @type {State} */
  function open(code) {
    if (code === codes.rightParenthesis) {
      return end(code)
    }

    return factoryDestination(
      effects,
      destinationAfter,
      nok,
      types.resourceDestination,
      types.resourceDestinationLiteral,
      types.resourceDestinationLiteralMarker,
      types.resourceDestinationRaw,
      types.resourceDestinationString,
      constants.linkResourceDestinationBalanceMax
    )(code)
  }

  // …
}

API

This module exports the following identifiers: factoryDestination. There is no default export.

factoryDestination(…)

Parameters
  • effects (Effects) — Context
  • ok (State) — State switched to when successful
  • nok (State) — State switched to when not successful
  • type (string) — Token type for whole (<a> or b)
  • literalType (string) — Token type when enclosed (<a>)
  • literalMarkerType (string) — Token type for enclosing (< and >)
  • rawType (string) — Token type when not enclosed (b)
  • stringType (string) — Token type for the URI (a or b)
  • max (number, default: Infinity) — Max depth of nested parens
Returns

State.

Examples
<a>
<a\>b>
<a b>
<a)>
a
a\)b
a(b)c
a(b)

Security

See security.md in micromark/.github for how to submit a security report.

Contribute

See contributing.md in micromark/.github for ways to get started. See support.md for ways to get help.

This project has a code of conduct. By interacting with this repository, organisation, or community you agree to abide by its terms.

License

MIT © Titus Wormer

Current Tags

  • 1.0.0                                ...           latest (3 years ago)
  • 1.0.0-beta.1                                ...           next (3 years ago)

5 Versions

  • 1.0.0                                ...           3 years ago
  • 1.0.0-beta.1                                ...           3 years ago
  • 1.0.0-alpha.3                                ...           3 years ago
  • 1.0.0-alpha.2                                ...           4 years ago
  • 1.0.0-alpha.1                                ...           4 years ago
Maintainers (2)
Downloads
Today 1
This Week 1
This Month 1
Last Day 0
Last Week 0
Last Month 0
Dependencies (3)
Dev Dependencies (0)
None
Dependents (1)

Copyright 2013 - present © cnpmjs.org | Home |