Categorization

This commit is contained in:
Angelos Chalaris
2017-12-14 18:24:49 +02:00
parent 65000577a8
commit 06018e143a
3 changed files with 785 additions and 680 deletions

1423
README.md

File diff suppressed because it is too large Load Diff

View File

@ -4,7 +4,10 @@ var path = require('path');
var snippetsPath = './snippets'; var snippetsPath = './snippets';
var staticPartsPath = './static-parts'; var staticPartsPath = './static-parts';
var snippets = {}, startPart = '', endPart = '', output = ''; var snippets = {}, startPart = '', endPart = '', output = '', tagDbData = {};
const objectFromPairs = arr => arr.reduce((a, v) => (a[v[0]] = v[1], a), {});
const capitalize = (str, lowerRest = false) => str.slice(0, 1).toUpperCase() + (lowerRest ? str.slice(1).toLowerCase() : str.slice(1));
console.time('Builder'); console.time('Builder');
@ -39,14 +42,28 @@ catch (err){
process.exit(1); process.exit(1);
} }
try {
tagDbData = objectFromPairs(fs.readFileSync('tag_database','utf8').split('\n').slice(0,-1).map(v => v.split(':').slice(0,2)));
}
catch (err){
console.log('Error during tag database loading: '+err);
process.exit(1);
}
try { try {
output += `${startPart+'\n'}`; output += `${startPart+'\n'}`;
for(var snippet of Object.entries(snippets)) for(var tag of [...new Set(Object.entries(tagDbData).map(t => t[1]))].sort((a,b) => a.localeCompare(b))){
output += `* [${snippet[0][0].toUpperCase() + snippet[0].replace(/-/g,' ').slice(1,snippet[0].length-3)}](#${snippet[0].slice(0,snippet[0].length-3).replace(/\(/g,'').replace(/\)/g,'').toLowerCase()})\n` output +=`### ${capitalize(tag, true)}\n`;
for(var taggedSnippet of Object.entries(tagDbData).filter(v => v[1] === tag))
output += `* [${taggedSnippet[0][0].toUpperCase() + taggedSnippet[0].replace(/-/g,' ').slice(1)}](#${taggedSnippet[0].replace(/\(/g,'').replace(/\)/g,'').toLowerCase()})\n`
output += '\n'; output += '\n';
for(var snippet of Object.entries(snippets)) }
output += `${snippet[1]+'\n[⬆ back to top](#table-of-contents)\n'}`; for(var tag of [...new Set(Object.entries(tagDbData).map(t => t[1]))].sort((a,b) => a.localeCompare(b))){
output += `${endPart+'\n'}`; output +=`## ${capitalize(tag, true)}\n`;
for(var taggedSnippet of Object.entries(tagDbData).filter(v => v[1] === tag))
output += `\n${snippets[taggedSnippet[0]+'.md']+'\n[⬆ back to top](#table-of-contents)\n'}`;
}
output += `\n${endPart+'\n'}`;
fs.writeFileSync('README.md', output); fs.writeFileSync('README.md', output);
} }
catch (err){ catch (err){

View File

@ -35,11 +35,8 @@ catch (err){
} }
try { try {
tagDbData = objectFromPairs(fs.readFileSync('tag_database','utf8').split('\n').map(v => v.split(':').slice(0,2))); tagDbData = objectFromPairs(fs.readFileSync('tag_database','utf8').split('\n').slice(0,-1).map(v => v.split(':').slice(0,2)));
// for(var tag of [...new Set(Object.entries(tagDbData).map(x => x[1]))]) tagDbStats = Object.entries(tagDbData).sort((a,b) => a[1].localeCompare(b[1])).reduce((acc, val) => {acc.hasOwnProperty(val[1]) ? acc[val[1]]++ : acc[val[1]] = 1; return acc;}, {});
// tagDbStats[tag] = Object.values(tagDbData).filter(v => v === tag);
// console.log(tagDbStats);
tagDbStats = Object.entries(tagDbData).reduce((acc, val) => {acc.hasOwnProperty(val[1]) ? acc[val[1]]++ : acc[val[1]] = 1; return acc;}, {});
} }
catch (err){ catch (err){
console.log('Error during tag database loading: '+err); console.log('Error during tag database loading: '+err);
@ -61,7 +58,7 @@ catch (err){
console.log('Error during README generation: '+err); console.log('Error during README generation: '+err);
process.exit(1); process.exit(1);
} }
console.log(`\n===Tag database statistics===`) console.log(`\n=== TAG STATS ===`)
for(var tagData of Object.entries(tagDbStats).filter(v => v[0] !== 'undefined')){ for(var tagData of Object.entries(tagDbStats).filter(v => v[0] !== 'undefined')){
console.log(`${chalk.green(tagData[0])}: ${tagData[1]} snippets`); console.log(`${chalk.green(tagData[0])}: ${tagData[1]} snippets`);
} }