std/index.js
Killer Boss Original 4750bfee76
Update index.js
2023-01-24 17:29:16 +01:00

70 lines
2 KiB
JavaScript

const { writeFile, readFile, mkdir } = require('node:fs/promises');
const { stdin, stdout } = require('node:process');
var readlineSync = require('readline-sync');
var name, debug, logs1;
function getTime () {
const date_time = new Date();
const year = date_time.getFullYear();
const month = ("0" + (date_time.getMonth() + 1)).slice(-2);
const day = ("0" + date_time.getDate()).slice(-2);
const hours = date_time.getHours();
const minutes = date_time.getMinutes();
const seconds = date_time.getSeconds();
return({year, month, day, hours, minutes, seconds})
};
function createLog () {
mkdir('./logs', { recursive: true });
var time = getTime();
name = `${time.year}.${time.month}.${time.day}.${time.hours}.${time.minutes}.${time.seconds}.log`;
writeFile(`./logs/${name}`, '');
return(name)
};
function log (string) {
readFile(`./logs/${name}`, 'utf8')
.then(async (err, data) => {
if (!data) data = '';
data += string + '\n';
writeFile(`./logs/${name}`, data);
})
};
function cin (question, hide) {
return new Promise((resolve, reject) => {
try {
var answer = readlineSync.question(`${question} `, {
hideEchoBack: hide || false
})
return resolve(answer);
} catch (e) {
console.log(e)
return resolve('error');
}
})
};
class createCout {
constructor (debugLevel, logs) {
if (!debugLevel) debugLevel = 0;
if (!logs) logs = false;
debug = debugLevel;
logs1 = logs;
}
cout (string, debugLevel) {
if (!debugLevel) debugLevel = 0;
var time = getTime();
if (debug >= debugLevel) {
console.log(`[${time.year}.${time.month}.${time.day}-${time.hours}:${time.minutes}:${time.seconds}] | ${String(string)}`);
if (logs1) {
log(string);
}
}
return;
};
}
module.exports = { cin, createCout, createLog, log };