Security News
pnpm 10.0.0 Blocks Lifecycle Scripts by Default
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
A linting tool for Chinese text content.
You could easily install zhlint
through npm
or yarn
:
# install through npm
npm install zhlint -g
# or through yarn
yarn global add zhlint
# glob files, lint them, and print validation report,
# and exit with code `1` if there is any error found.
zhlint <file-pattern>
# glob files and fix their all possilbly found errors.
zhlint <file-pattern> --fix
# lint the file and output fixed content into another file
zhlint <input-file-path> --output=<output-file-path>
# print usage info
zhlint --help
The validation report might look like this:
const { run, report } = require('zhlint')
const value = '自动在中文和English之间加入空格'
const output = run(value)
// print '自动在中文和 English 之间加入空格''
console.log(output.result)
// print validation report
report([output])
And the format of validation report is more like this:
1:6 - There should be a space between a half-width content and a full-width content
自动在中文和English之间加入空格
^
1:13 - There should be a space between a half-width content and a full-width content
自动在中文和English之间加入空格
^
Invalid files:
- foo.md
Found 2 errors.
You could find a JavaScript file dist/zhlint.js
as a standalone version. To use it, for example, you can directly add it into your browser as a <script>
tag. Then there would be a global variable zhlint
for you.
run(str: string, options?: Options): Result
: Lint a certain file.
str
: The text content you want to lint.options
: Some options for advanced usage.value
and the infor of all validations
.report(results: Result[], logger?: Console): void
: Print out the validation reports for each file.
results
: An array for all linted results.logger
: The logger instance, by default it's console
in Node.js/browser.Result
: { file?: string, origin: string, result: string, validations: Validation[] }
file
: The file name. It's an optional field which is only used in CLI.origin
: the original text content.result
: the finally fixed text content.validations
: All the validation information.Validation
: { index: number, length: number, name: string, target: string, message: string }
index
: The index of the target token in the input string.length
: The length of the target token in the input string.
message
: The description of this validation in natural language.Options
: { rules?: string[], hyperParse?: string[], ignoredCases?: IgnoredCase[], logger?: Console }
: Customize your own rules and other advanced options.
rules
: customize the linting rules by their names, could be undefined
which means just use the default rules.hyperParse
: customize the hyper parser by their names, could be undefined
which means just use default ignored cases parser, Markdown parser and the Hexo tags parser.ignoredCases
: provide exception cases which you would like to skip.logger
: same to the parameter in report(...)
.IgnoredCase
: { prefix?, textStart, textEnd?, suffix? }
We support lint your text content in Markdown syntax by default. For example:
run('自动在_中文_和**English**之间加入空格')
It will analyse the Markdown syntax first and extract the pure text content and do the lint job. After that the fixed pure text content could be replaced back to the raw Markdown string and returned as the output value
in result.
Specially, we support Hexo tags syntax just because when we use Hexo to build Vue.js website, the markdown source files more or less include special tags like that so got the unpredictable result.
As a result, we additionally skip the Hexo-style tags by default. For example:
run('现在过滤器只能用在插入文本中 (`{% raw %}{{ }}{% endraw %}` tags)。')
In some real cases we have special text contents not follow the rules by reason. So we could ues ignoredCases
option to config that. For example we'd like to keep the spaces inside a pair of brackets, which is invalid by default. Then we could write one more line of HTML comment anywhere inside the file:
<!-- the good case -->
text before (text inside) text after
<!-- the bad case -->
vm.$on( event, callback )
<!-- then we could write this down below to make it work -->
<!-- zhlint ignore: ( , ) -->
or just pass it through as an option:
run(str, { ignoredCases: { textStart: '( ', textEnd: ' )' } })
ignore
: find all ignored pieces by the HTML comment <!-- zhlint ignore: ... -->
hexo
: find all Hexo tags to avoid them being parsed.markdown
: parse by markdown syntax and find all block-level texts and inline-level marks.Almost the rules come from the past translation experiences in W3C HTML Chinese interest group and Vue.js Chinese docsite.
... and this part might be controversial. So if you don't feel well at some point, we definitely would love to know and improve. Opening an issue is always welcome. Then we could discuss about the possible better option or decision.
mark-raw
: keep one space out of the inline code in markdown
text`text`text
-> text `text` text
mark-hyper
: move the space outside of the markdown marks
text[ text ](link)text
-> text [text](link) text
unify-punctuation
: unify all punctuations with same meaning, as part of the translation conventions, the punctuation should be full-width except brackets.
中文, 中文.
-> 中文,中文。
case-abbr
: escape cases with half-width dots like Mr.
, e.g.
.
Mr.
-> Mr.
space-full-width-content
: keep one space between half-width content and full-width content
中文English中文
-> 中文 English 中文
space-punctuation
: keep no space between full-width punctuation and the content besides, keep one space between half-width punctuation and the content besides
中文 , 中文
-> 中文,中文
case-math-exp
: overwrite cases with math expressions
1+1=2
-> 1 + 1 = 2
case-backslash
: deal with the backslash specially to avoid unpredictable result
这实质上和问题 \#1 是相同的
space-brackets
: keep one space outside and no space inside a pair of brackets when it's half-width, keep no space inside or outside when it's full-widthspace-quotes
: keep one space outside and no space inside a pair of brackets when it's half-width, keep no space inside or outside when it's full-widthcase-traditional
: unify all quotes, as part of the translation conventions.
a「b」c
-> a“b”c
case-datetime
: deal with the date & time specially to avoid unpredictable result
2020/01/02 01:20:30
case-datetime-zh
: deal with the Chinese date & time format specially to avoid unpredictable result
中文2020年1月1日0天0号0时0分00秒
case-ellipsis
: deal with the continuous dots as ellipsis specially to avoid unpredictable result
中文...中文...a...b...中文...中文...a...b...
case-html-entity
: deal with the HTML entities specially to avoid unpredicutable result
中文< & >中文
case-raw
: deal with the inline code in markdown specially to avoid unpredictable result
`Vue.nextTick`/`vm.$nextTick`
case-linebreak
: deal with the linebreak (2 spaces at the end of a line) in markdown specially to avoid unpredictable resultFAQs
A linting tool for Chinese language.
The npm package zhlint receives a total of 491 weekly downloads. As such, zhlint popularity was classified as not popular.
We found that zhlint demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
Product
Socket now supports uv.lock files to ensure consistent, secure dependency resolution for Python projects and enhance supply chain security.
Research
Security News
Socket researchers have discovered multiple malicious npm packages targeting Solana private keys, abusing Gmail to exfiltrate the data and drain Solana wallets.