0.1.5 • Published 4 months ago
hpcmod v0.1.5
hpcmod
#!/usr/bin/env coffee
> @3-/ymlid
@3-/write
fs > readdirSync existsSync
path > join dirname
gen = (dir, yml)=>
dict = ymlid(
join dir, yml
join dir, '.id.yml'
)
rs = [
'''// DON\'T EDIT , GENERATED BY hpcmod
#[macro_export]
macro_rules! err {
() => {
ih::err_code_li!(crate);
};
}'''
]
for [mod, val_id] from Object.entries dict
rs.push "\npub mod #{mod} {"
for [val, id] from Object.entries val_id
rs.push " pub const #{val.toUpperCase()}: u32 = #{id};"
rs.push '}'
write(
join(dirname(dir),'src/err.rs')
rs.join('\n')
)
return
export default (dir)=>
dir_li = readdirSync(dir)
for i in dir_li
err_dir = join dir, i, 'err'
if not existsSync err_dir
continue
for i from readdirSync err_dir
if i.endsWith('.yml') and not i.startsWith('.')
gen(err_dir, i)
break
return
About
This project is an open-source component of i18n.site ⋅ Internationalization Solution.
i18 : MarkDown Command Line Translation Tool
The translation perfectly maintains the Markdown format.
It recognizes file changes and only translates the modified files.
The translated Markdown content is editable; if you modify the original text and translate it again, manually edited translations will not be overwritten (as long as the original text has not been changed).
i18n.site : MarkDown Multi-language Static Site Generator
Optimized for a better reading experience
关于
本项目为 i18n.site ⋅ 国际化解决方案 的开源组件。
翻译能够完美保持 Markdown 的格式。能识别文件的修改,仅翻译有变动的文件。
Markdown 翻译内容可编辑;如果你修改原文并再次机器翻译,手动修改过的翻译不会被覆盖(如果这段原文没有被修改)。
i18n.site : MarkDown多语言静态站点生成器 为阅读体验而优化。