Parse Markdown to AST with location info.
npm install @textlint/markdown-to-astParse Markdown to AST with location info.
This library is not parser itself, it dependent on wooorm/remark.
> Markdown -> remark -> markdown-to-ast -> TxtNodes
The AST consists of TxtNodes.
A TxtNode of the AST has following properties:
- loc - Nodes have line and column-based location info.
- range - Nodes have an index-based location range (array).
- raw - Node have a raw text.
- value - Node have a value of text.
The interface are defined in textlint/txtnode.md
This library is a part of textlint/textlint.
If you need to markdown parser, please use wooorm/remark directly.
```
npm install @textlint/markdown-to-ast
`sh`
var parse = require("@textlint/markdown-to-ast").parse;
var markdown = "It's a text";
var AST = parse(markdown);
/*
{
"type": "Document",
"children": [
{
"type": "Paragraph",
"children": [
{
"type": "Str",
"value": "It's a ",
"loc": {
"start": {
"line": 1,
"column": 0
},
"end": {
"line": 1,
"column": 7
}
},
"range": [
0,
7
],
"raw": "It's a "
},
{
"type": "Emphasis",
"children": [
{
"type": "Str",
"value": "text",
"loc": {
"start": {
"line": 1,
"column": 8
},
"end": {
"line": 1,
"column": 12
}
},
"range": [
8,
12
],
"raw": "text"
}
],
"loc": {
"start": {
"line": 1,
"column": 7
},
"end": {
"line": 1,
"column": 13
}
},
"range": [
7,
13
],
"raw": "text"
}
],
"loc": {
"start": {
"line": 1,
"column": 0
},
"end": {
"line": 1,
"column": 13
}
},
"range": [
0,
13
],
"raw": "It's a text"
}
],
"loc": {
"start": {
"line": 1,
"column": 0
},
"end": {
"line": 1,
"column": 13
}
},
"range": [
0,
13
],
"raw": "It's a text"
}
*/
If you want to know real use-case, please see textlint/textlint.
``
npm test
See tools/ directory.
1. Fork it!
2. Create your feature branch: git checkout -b my-new-featuregit commit -am 'Add some feature'
3. Commit your changes: git push origin my-new-feature`
4. Push to the branch:
5. Submit a pull request :D
MIT