Initial commit
This commit is contained in:
90
scripts/wiki/app.js
Normal file
90
scripts/wiki/app.js
Normal file
@ -0,0 +1,90 @@
|
||||
var fs = require('fs');
|
||||
var util = require('util');
|
||||
var logger = require('winston');
|
||||
|
||||
var sanitizeHtml = require('sanitize-html');
|
||||
|
||||
var del = require('delete');
|
||||
var exec = require('sync-exec');
|
||||
|
||||
var inputDirectory = './citra.wiki/';
|
||||
var outputDirectory = '../../site/content/wiki/';
|
||||
|
||||
function url(title) {
|
||||
return '/wiki/' + title.replace(/\s+/g, '-');
|
||||
}
|
||||
|
||||
if (fs.existsSync(inputDirectory)) {
|
||||
logger.info(`Purging input directory: ${outputDirectory}`);
|
||||
del.sync(outputDirectory, {force: true});
|
||||
}
|
||||
|
||||
exec('git clone https://github.com/citra-emu/citra.wiki.git');
|
||||
|
||||
if (fs.existsSync(outputDirectory) == false) {
|
||||
logger.info(`Creating missing output directory: ${outputDirectory}`);
|
||||
fs.mkdirSync(outputDirectory);
|
||||
}
|
||||
|
||||
fs.readdir(inputDirectory, function(err, items) {
|
||||
try {
|
||||
// Look for all .md files within the wiki directory.
|
||||
items.filter(file => file.substr(-3) === '.md').forEach(function(item) {
|
||||
// Generate the title from the filename.
|
||||
let title = item.replace(/-/g, ' ').slice(0, -3);
|
||||
var stats = fs.statSync(`${inputDirectory}${item}`);
|
||||
var modified = new Date(util.inspect(stats.mtime));
|
||||
|
||||
// Read the .md file.
|
||||
fs.readFile(`${inputDirectory}${item}`, 'utf8', function (err,data) {
|
||||
if (err) { logger.error(err); return; }
|
||||
|
||||
try {
|
||||
// Convert various data inside of the markdown language.
|
||||
let cleanData = sanitizeHtml(data);
|
||||
|
||||
// Blackfriday Markdown Rendering requires a blank line before lists.
|
||||
try {
|
||||
var lines = cleanData.split(/\r?\n/);
|
||||
for(var i = 0; i < lines.length; i++) {
|
||||
// If it's the start of the file, ignore to prevent an index issue.
|
||||
if (i > lines.length) { return; }
|
||||
if (i == 0 || lines[i] == '\n') { continue; }
|
||||
|
||||
// Search for the start of a list designated by the * character.
|
||||
if (lines[i].startsWith("* ") && lines[i - 1].startsWith("* ") == false) {
|
||||
i = i + 1;
|
||||
lines.splice(i - 1, 0, '');
|
||||
}
|
||||
}
|
||||
cleanData = lines.join('\n');
|
||||
} catch (ex) {
|
||||
logger.error(ex);
|
||||
}
|
||||
|
||||
// Replacing tags like [[Common Issues on Windows|Common Issues]]
|
||||
cleanData = cleanData.replace(/\[\[(.*)\|(.*)\]\]/g, function(match, p1, p2) {
|
||||
return `[${p1}](${url(p2)})`
|
||||
});
|
||||
|
||||
// Replacing tags like [[Common Issues]]
|
||||
cleanData = cleanData.replace(/\[\[(.*)\]\]/g, function(match, p1) {
|
||||
return `[${p1}](${url(p1)})`
|
||||
});
|
||||
|
||||
// Create the new markdown header for Hugo.
|
||||
let newFileContents = `+++\ntitle = "${title}"\ndate = "${modified.toISOString()}"\n+++\n${cleanData}`;
|
||||
|
||||
fs.writeFile(`${outputDirectory}${item}`, newFileContents, function(err) {
|
||||
if (err) return logger.error(err);
|
||||
logger.info(`Wrote file ${item} to filesystem.`);
|
||||
});
|
||||
} catch (ex) {
|
||||
logger.error(ex);
|
||||
}
|
||||
});
|
||||
});
|
||||
} catch (ex) {
|
||||
logger.error(ex);
|
||||
}
|
||||
});
|
Reference in New Issue
Block a user