feat(euler): update readme when generating

-
This commit is contained in:
newt 2024-10-09 18:02:41 +01:00
parent 704ca26e2c
commit 816dad857f
3 changed files with 47 additions and 19 deletions

View file

@ -3,5 +3,6 @@ const path = require('path');
module.exports = { module.exports = {
resources: path.join(__dirname, 'resources'), resources: path.join(__dirname, 'resources'),
src: path.join(__dirname, 'src'), src: path.join(__dirname, 'src'),
thoughts: path.join(__dirname, 'thoughts') thoughts: path.join(__dirname, 'thoughts'),
root: __dirname
}; };

View file

@ -3,7 +3,8 @@
"scripts": { "scripts": {
"build": "gulp build", "build": "gulp build",
"start": "node scripts/run", "start": "node scripts/run",
"new": "node scripts/generate" "new": "node scripts/generate",
"generate": "node scripts/generate"
}, },
"devDependencies": { "devDependencies": {
"@swc/core": "^1.2.125", "@swc/core": "^1.2.125",

View file

@ -1,18 +1,16 @@
const inquirer = require('inquirer'); const inquirer = require('inquirer');
const fs = require('fs'); const fs = require('fs');
const path = require('path'); const path = require('path');
const { src, thoughts: thoughtsDir } = require('../constants'); const { root, src, thoughts: thoughtsDir } = require('../constants');
const axios = require('axios'); const axios = require('axios');
const cheerio = require('cheerio'); const cheerio = require('cheerio');
const problems = fs const readmeContent = fs.readFileSync(path.join(root, 'readme.md')).toString();
.readFileSync(path.join(__dirname, '..', 'readme.md'))
.toString() const problems = readmeContent.match(/^- \[.] (?:\[(.*)\]|(.*))/gm).map(res => {
.match(/^- \[.] (?:\[(.*)\]|(.*))/gm)
.map(res => {
const sanitised = res.substring(8).replace('[', '').replace(']', ''); const sanitised = res.substring(8).replace('[', '').replace(']', '');
return sanitised.match(/[0-9]* - (.*)/)[1]; return sanitised.match(/[0-9]* - (.*)/)[1];
}); });
inquirer inquirer
.prompt([ .prompt([
@ -20,10 +18,21 @@ inquirer
name: 'problemNumber', name: 'problemNumber',
message: 'Which problem would you like to solve?', message: 'Which problem would you like to solve?',
type: 'number', type: 'number',
validate: input => validate: input => {
parseInt(input) > 100 input = parseInt(input);
? 'Please make sure you choose a number between 1 and 100!'
: true if (input > 100) return 'Please make sure you choose a number between 1 and 100!';
else {
let alreadyGenerated = false;
fs.readdirSync(src).forEach(file => {
if (file.startsWith(input)) alreadyGenerated = true;
});
if (alreadyGenerated)
return 'Please choose a problem you have not already completed!';
else return true;
}
}
}, },
{ {
name: 'thoughts', name: 'thoughts',
@ -32,7 +41,7 @@ inquirer
default: false default: false
} }
]) ])
.then(async ({ problemNumber, thoughts }) => { .then(({ problemNumber, thoughts }) => {
const fileName = `${problemNumber} - ${problems[problemNumber - 1]}`; const fileName = `${problemNumber} - ${problems[problemNumber - 1]}`;
// Fetch the problem data off of projecteuler.net // Fetch the problem data off of projecteuler.net
@ -45,15 +54,32 @@ inquirer
.map(r => `// ${r}`) .map(r => `// ${r}`)
.join('\n'); .join('\n');
// Generate the source file
fs.writeFileSync( fs.writeFileSync(
path.join(src, `${fileName}.ts`), path.join(src, `${fileName}.ts`),
`${problemContent} `${problemContent}
export = {}; export = {};
// Output // Output
console.log();` console.log();`
); );
// Generate the thoughts file
if (thoughts) fs.writeFileSync(path.join(thoughtsDir, `${fileName}.md`), ''); if (thoughts) fs.writeFileSync(path.join(thoughtsDir, `${fileName}.md`), '');
// Check it off in the readme
const regex = new RegExp(` \\[.\\] ${problemNumber} - .*`);
const match = readmeContent.match(regex);
let newLine = ` [x] [${match[0].replace('[ ]', '').trim()}](src/${encodeURIComponent(
fileName
)}.ts)`;
if (thoughts)
newLine += `\n - [Thoughts](thoughts/${encodeURIComponent(fileName)}.md)`;
const newContent = readmeContent.replace(regex, newLine);
fs.writeFileSync(path.join(root, 'readme.md'), newContent);
}); });
}); });