Use modern js.

This commit is contained in:
Anduin Xue
2022-03-12 15:07:08 +08:00
parent b249df296b
commit 47c562ede0
2 changed files with 46 additions and 56 deletions

100
.github/manual_lint.js vendored
View File

@@ -1,63 +1,53 @@
// fetch all .md files. const util = require("util");
// Check it's content. const glob = util.promisify(require('glob'));
// Console.LogError for errors. const fs = require("fs").promises;
const path = require('path');
const glob = require("glob"); async function main() {
const fs = require("fs"); var errors = [];
var path = require('path'); var directories = await glob(__dirname + '../../dishes/**/*.md');
var errors = 0; for (var filePath of directories) {
var data = await fs.readFile(filePath, 'utf8');
var getDirectories = function (src, callback) { dataLines = data.split('\n').map(t => t.trim());
glob(src + '../../dishes/**/*.md', callback); var filename = path.parse(filePath).base.replace(".md","");
};
getDirectories(__dirname, function (err, res) { titles = dataLines.filter(t => t.startsWith('#'));
res.forEach(filePath => { secondTitles = titles
// console.log("Linting file: " + filePath + " ..."); .filter(t => t.startsWith('## '));
fs.readFile(filePath, 'utf8' , (err, data) => { if (titles[0].trim() != "# " + filename + "的做法") {
data = data.replace('\r\n', '\n'); errors.push(`File ${filePath} is invalid! It's title should be: ${"# " + filename + "的做法"}! It was ${titles[0].trim()}!`);
data = data.replace('\r', '\n'); continue;
}
if (secondTitles.length != 4) {
errors.push(`File ${filePath} is invalid! It doesn't has 4 second titles!`);
continue;
}
if (secondTitles[0].trim() != "## 必备原料和工具") {
errors.push(`File ${filePath} is invalid! The first title is NOT 必备原料和工具! It was ${secondTitles[0]}!`);
}
if (secondTitles[1].trim() != "## 计算") {
errors.push(`File ${filePath} is invalid! The second title is NOT 计算!`);
}
if (secondTitles[2].trim() != "## 操作") {
errors.push(`File ${filePath} is invalid! The thrid title is NOT 操作!`);
}
if (secondTitles[3].trim() != "## 附加内容") {
errors.push(`File ${filePath} is invalid! The fourth title is NOT 附加内容!`);
}
}
if (errors.length > 0) {
for (var error of errors) {
console.error(error + "\n");
}
dataLines = data.split('\n'); var message = `Found ${errors.length} errors! Please fix!`;
var filename = path.parse(filePath).base.replace(".md",""); throw new Error(message);
}
}
titles = dataLines.filter(t => t.startsWith('#')); main();
secondTitles = titles
.filter(t => t.startsWith('## '));
if (titles[0].trim() != "# " + filename + "的做法") {
console.error(`File ${filePath} is invalid! It's title should be: ${"# " + filename + "的做法"}! It was ${titles[0].trim()}!`);
errors++;
return;
}
if (secondTitles.length != 4) {
console.error(`File ${filePath} is invalid! It doesn't has 4 second titles!`);
errors++;
return;
}
if (secondTitles[0].trim() != "## 必备原料和工具") {
console.error(`File ${filePath} is invalid! The first title is NOT 必备原料和工具! It was ${secondTitles[0]}!`);
errors++;
}
if (secondTitles[1].trim() != "## 计算") {
console.error(`File ${filePath} is invalid! The second title is NOT 计算!`);
errors++;
}
if (secondTitles[2].trim() != "## 操作") {
console.error(`File ${filePath} is invalid! The thrid title is NOT 操作!`);
errors++;
}
if (secondTitles[3].trim() != "## 附加内容") {
console.error(`File ${filePath} is invalid! The fourth title is NOT 附加内容!`);
errors++;
}
});
});
});
if (errors > 0) {
throw `Found ${errors} errors! Please fix!`;
}

View File

@@ -1,4 +1,4 @@
# 吐司+果酱的做法 # 吐司果酱的做法
饱腹感的懒人快速营养早餐2min 搞定 饱腹感的懒人快速营养早餐2min 搞定