Markdown parser, done right. 100% CommonMark support, extensions, syntax plugins & high speed
https://markdown-it.github.io/
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
110 lines
3.3 KiB
110 lines
3.3 KiB
PATH := ./node_modules/.bin:${PATH}
|
|
|
|
NPM_PACKAGE := $(shell node -e 'process.stdout.write(require("./package.json").name)')
|
|
NPM_VERSION := $(shell node -e 'process.stdout.write(require("./package.json").version)')
|
|
|
|
TMP_PATH := /tmp/${NPM_PACKAGE}-$(shell date +%s)
|
|
|
|
REMOTE_NAME ?= origin
|
|
REMOTE_REPO ?= $(shell git config --get remote.${REMOTE_NAME}.url)
|
|
|
|
CURR_HEAD := $(firstword $(shell git show-ref --hash HEAD | cut -b -6) master)
|
|
GITHUB_PROJ := https://github.com//markdown-it/${NPM_PACKAGE}
|
|
|
|
|
|
demo: lint
|
|
rm -rf ./demo
|
|
mkdir ./demo
|
|
./support/demodata.js > ./support/demo_template/sample.json
|
|
jade ./support/demo_template/index.jade --pretty \
|
|
--obj ./support/demo_template/sample.json \
|
|
--out ./demo
|
|
stylus -u autoprefixer-stylus \
|
|
< ./support/demo_template/index.styl \
|
|
> ./demo/index.css
|
|
rm -rf ./support/demo_template/sample.json
|
|
browserify ./ -s markdownit > ./demo/markdown-it.js
|
|
#cp ./dist/markdown-it.js ./demo/
|
|
cp ./support/demo_template/index.js ./demo/
|
|
cp ./support/demo_template/README.md ./demo/
|
|
mkdir ./demo/plugins
|
|
cp ./node_modules/markdown-it-emoji/dist/* ./demo/plugins
|
|
|
|
gh-demo: demo
|
|
touch ./demo/.nojekyll
|
|
cd ./demo \
|
|
&& git init . \
|
|
&& git add . \
|
|
&& git commit -m "Auto-generate demo" \
|
|
&& git remote add origin git@github.com:markdown-it/markdown-it.github.io.git \
|
|
&& git push --force origin master
|
|
rm -rf ./demo
|
|
|
|
lint:
|
|
eslint --reset .
|
|
|
|
test: lint
|
|
mocha -R spec
|
|
echo "CommonMark stat:\n"
|
|
./support/specsplit.js test/fixtures/commonmark/spec.txt
|
|
|
|
coverage:
|
|
rm -rf coverage
|
|
istanbul cover node_modules/.bin/_mocha
|
|
|
|
test-ci: lint
|
|
istanbul cover ./node_modules/mocha/bin/_mocha --report lcovonly -- -R spec && cat ./coverage/lcov.info | ./node_modules/coveralls/bin/coveralls.js && rm -rf ./coverage
|
|
|
|
doc:
|
|
@if test ! `which ndoc` ; then \
|
|
echo "You need 'ndoc' installed in order to generate docs." >&2 ; \
|
|
echo " $ npm install -g ndoc" >&2 ; \
|
|
exit 128 ; \
|
|
fi
|
|
rm -rf ./apidoc
|
|
ndoc --link-format "{package.homepage}/blob/${CURR_HEAD}/{file}#L{line}"
|
|
|
|
gh-doc: doc
|
|
touch ./apidoc/.nojekyll
|
|
cd ./apidoc \
|
|
&& git init . \
|
|
&& git add . \
|
|
&& git commit -m "Auto-generate API doc" \
|
|
&& git remote add remote git@github.com:markdown-it/markdown-it.git \
|
|
&& git push --force remote +master:gh-pages
|
|
rm -rf ./apidoc
|
|
|
|
publish:
|
|
@if test 0 -ne `git status --porcelain | wc -l` ; then \
|
|
echo "Unclean working tree. Commit or stash changes first." >&2 ; \
|
|
exit 128 ; \
|
|
fi
|
|
@if test 0 -ne `git fetch ; git status | grep '^# Your branch' | wc -l` ; then \
|
|
echo "Local/Remote history differs. Please push/pull changes." >&2 ; \
|
|
exit 128 ; \
|
|
fi
|
|
@if test 0 -ne `git tag -l ${NPM_VERSION} | wc -l` ; then \
|
|
echo "Tag ${NPM_VERSION} exists. Update package.json" >&2 ; \
|
|
exit 128 ; \
|
|
fi
|
|
git tag ${NPM_VERSION} && git push origin ${NPM_VERSION}
|
|
npm publish ${GITHUB_PROJ}/tarball/${NPM_VERSION}
|
|
|
|
browserify:
|
|
rm -rf ./dist
|
|
mkdir dist
|
|
# Browserify
|
|
( printf "/*! ${NPM_PACKAGE} ${NPM_VERSION} ${GITHUB_PROJ} @license MIT */" ; \
|
|
browserify ./ -s markdownit \
|
|
) > dist/markdown-it.js
|
|
# Minify
|
|
uglifyjs dist/markdown-it.js -b beautify=false,ascii-only=true -c -m \
|
|
--preamble "/*! ${NPM_PACKAGE} ${NPM_VERSION} ${GITHUB_PROJ} @license MIT */" \
|
|
> dist/markdown-it.min.js
|
|
|
|
todo:
|
|
grep 'TODO' -n -r ./lib 2>/dev/null || test true
|
|
|
|
|
|
.PHONY: publish lint test todo demo coverage doc
|
|
.SILENT: help lint test todo
|
|
|