Tweaked linebreaks when generating Hugo file. Tweaked No wiki exists yet message. Fixed Github pull
This commit is contained in:
parent
cf653e54ba
commit
80127d17fa
|
@ -27,11 +27,9 @@ function url(title) {
|
||||||
function gitPull(directory, repository) {
|
function gitPull(directory, repository) {
|
||||||
if (fs.existsSync(directory)) {
|
if (fs.existsSync(directory)) {
|
||||||
logger.info(`Fetching latest from Github : ${directory}`);
|
logger.info(`Fetching latest from Github : ${directory}`);
|
||||||
logger.info(`git --git-dir=${directory} pull`);
|
exec(`cd ${directory} && git pull && cd -`);
|
||||||
exec(`git --git-dir=${directory} pull`);
|
|
||||||
} else {
|
} else {
|
||||||
logger.info(`Cloning repository from Github : ${directory}`);
|
logger.info(`Cloning repository from Github : ${directory}`);
|
||||||
logger.info(`git clone ${repository}`);
|
|
||||||
exec(`git clone ${repository}`);
|
exec(`git clone ${repository}`);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -41,6 +39,18 @@ function getDirectories (srcpath) {
|
||||||
.filter(file => fs.lstatSync(path.join(srcpath, file)).isDirectory())
|
.filter(file => fs.lstatSync(path.join(srcpath, file)).isDirectory())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
String.prototype.trimNewline = function() {
|
||||||
|
let string = this.toString();
|
||||||
|
let match = '\r\n'
|
||||||
|
if (string.endsWith('\r\n')) {
|
||||||
|
return string.slice(0, -4);
|
||||||
|
} else if (string.endsWith('\r') || string.endsWith('\n')) {
|
||||||
|
return string.slice(0, -2);
|
||||||
|
} else {
|
||||||
|
return string;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Fetch game information stored in Github repository.
|
// Fetch game information stored in Github repository.
|
||||||
gitPull(inputDirectoryGame, 'https://github.com/citra-emu/citra-games-wiki.git');
|
gitPull(inputDirectoryGame, 'https://github.com/citra-emu/citra-games-wiki.git');
|
||||||
|
|
||||||
|
@ -110,7 +120,10 @@ try {
|
||||||
fsextra.copySync(`${inputDirectorySavefilesGame}/${file}`, `${outputDirectorySavefilesGame}/${file.replace('.zip', '.zip')}`);
|
fsextra.copySync(`${inputDirectorySavefilesGame}/${file}`, `${outputDirectorySavefilesGame}/${file.replace('.zip', '.zip')}`);
|
||||||
} else if (path.extname(file) == '.dat') {
|
} else if (path.extname(file) == '.dat') {
|
||||||
// Store the contents of the file in memory for adding it into the markdown later.
|
// Store the contents of the file in memory for adding it into the markdown later.
|
||||||
savefileMetadataContents.push({ filename: file.replace('.dat', '.zip'), contents: fs.readFileSync(`${inputDirectorySavefilesGame}/${file}`, 'utf8') });
|
savefileMetadataContents.push({
|
||||||
|
filename: file.replace('.dat', '.zip'),
|
||||||
|
contents: fs.readFileSync(`${inputDirectorySavefilesGame}/${file}`, 'utf8').trimNewline()
|
||||||
|
});
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -138,14 +151,14 @@ try {
|
||||||
var stats = fs.statSync(`${inputDirectoryGame}/${game}/game.dat`);
|
var stats = fs.statSync(`${inputDirectoryGame}/${game}/game.dat`);
|
||||||
let modified = new Date(util.inspect(stats.mtime));
|
let modified = new Date(util.inspect(stats.mtime));
|
||||||
|
|
||||||
let datContents = fs.readFileSync(`${inputDirectoryGame}/${game}/game.dat`, 'utf8');
|
let datContents = fs.readFileSync(`${inputDirectoryGame}/${game}/game.dat`, 'utf8').trimNewline();
|
||||||
|
|
||||||
var wikiContents = "";
|
var wikiContents = "";
|
||||||
let wikiPathGame = `${inputDirectoryWiki}/${game}.md`;
|
let wikiPathGame = `${inputDirectoryWiki}/${game}.md`;
|
||||||
if (fs.existsSync(wikiPathGame)) {
|
if (fs.existsSync(wikiPathGame)) {
|
||||||
wikiContents = fs.readFileSync(wikiPathGame, 'utf8');
|
wikiContents = fs.readFileSync(wikiPathGame, 'utf8').trimNewline();
|
||||||
} else {
|
} else {
|
||||||
wikiContents = "No wiki exists yet for this game.";
|
wikiContents = "## No wiki exists yet for this game.";
|
||||||
}
|
}
|
||||||
|
|
||||||
// Fix Blackfriday markdown rendering differences.
|
// Fix Blackfriday markdown rendering differences.
|
||||||
|
@ -155,13 +168,14 @@ try {
|
||||||
// Read all savefiles from array and copy them into the markdown.
|
// Read all savefiles from array and copy them into the markdown.
|
||||||
savefileMetadataContents.forEach(function(savefile) {
|
savefileMetadataContents.forEach(function(savefile) {
|
||||||
let modified = new Date(util.inspect(stats.mtime));
|
let modified = new Date(util.inspect(stats.mtime));
|
||||||
datContents += `\r\n\r\n[[ savefiles ]]\r\n${savefile.contents}\r\nfilename = "${savefile.filename}"\r\ndate = "${modified.toISOString()}"\r\n`;
|
datContents += `\r\n\r\n[[ savefiles ]]\r\nfilename = "${savefile.filename}"\r\ndate = "${modified.toISOString()}"\r\n${savefile.contents}`;
|
||||||
});
|
});
|
||||||
|
|
||||||
let output = `+++\r\ndate = "${modified.toISOString()}"\r\n${datContents}\r\n+++\r\n\r\n${wikiContents}\r\n`;
|
let output = `+++\r\ndate = "${modified.toISOString()}"\r\n${datContents}\r\n+++\r\n\r\n${wikiContents}\r\n`;
|
||||||
fs.writeFileSync(`${outputDirectoryMd}/${game}.md`, output);
|
fs.writeFileSync(`${outputDirectoryMd}/${game}.md`, output);
|
||||||
} catch (ex) {
|
} catch (ex) {
|
||||||
logger.error(`${game} failed to generate: ${ex}`);
|
logger.error(`${game} failed to generate: ${ex}`);
|
||||||
|
logger.error(ex);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
} catch (ex) {
|
} catch (ex) {
|
||||||
|
|
Reference in New Issue