No description
Find a file
marihachi bedaa56c28 🐱
2022-01-10 01:13:10 +09:00
.github Create config.yml 2021-08-28 18:02:05 +09:00
docs update doc 2022-01-09 17:13:25 +09:00
etc Introduce nesting limit (#87) 2022-01-06 01:05:37 +09:00
src fix opts of internal parsing 2022-01-09 22:55:55 +09:00
test fix bug of link label parsing 2022-01-09 18:21:57 +09:00
test-d Introduce coverage integration 2021-06-26 23:48:46 +09:00
.editorconfig update CI configuration 2021-04-01 11:37:44 +09:00
.eslintignore Introduce api-extractor and lint 2021-07-31 15:12:43 +09:00
.eslintrc.js Update .eslintrc.js 2022-01-09 19:25:43 +09:00
.gitignore add package-lock 2021-07-31 15:15:44 +09:00
api-extractor.json Introduce api-extractor and lint 2021-07-31 15:12:43 +09:00
CHANGELOG.md 🐱 2022-01-10 01:13:10 +09:00
CODE_OF_CONDUCT.md Create CODE_OF_CONDUCT.md 2021-08-23 23:43:00 +09:00
codecov.yml Introduce coverage integration 2021-06-26 23:48:46 +09:00
CONTRIBUTING.md Update contribution guides 2021-08-28 15:52:36 +09:00
jest.config.ts Introduce coverage integration 2021-06-26 23:48:46 +09:00
LICENSE update copyright 2022-01-01 21:57:03 +09:00
package-lock.json Fix vulnerability of third-party packages 2021-10-14 22:05:35 +09:00
package.json 0.20.0 2021-10-02 10:34:57 +09:00
README.md chore: remove trailing spaces 2021-06-27 00:00:09 +09:00
tsconfig.json fix tsconfig 2021-06-27 00:10:39 +09:00

mfm.js

An MFM parser implementation with PEG.js. Try it out!

Test codecov

NPM

Installation

npm i mfm-js

Usage

Please see docs for the detail.

TypeScript:

import * as mfm from 'mfm-js';

const inputText =
`<center>
Hello $[tada everynyan! 🎉]

I'm @ai, A bot of misskey!

https://github.com/syuilo/ai
</center>`;

// Generate a MFM tree from the MFM text.
const mfmTree = mfm.parse(inputText);

// Generate a MFM tree from the MFM plain text.
const plainMfmTree = mfm.parsePlain('I like the hot soup :soup:');

// Reverse to a MFM text from the MFM tree.
const text = mfm.toString(mfmTree);

Develop

1. Clone

git clone https://github.com/misskey-dev/mfm.js.git

2. Install packages

cd mfm.js
npm i

3. Build

npm run build

Use the interactive CLI parser

full parser:

npm run parse

plain parser:

npm run parse-plain

License

This software is released under the MIT License.