necessary 13.5.4 → 13.5.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
|
@@ -126,8 +126,8 @@ function readFile(filePath) {
|
|
|
126
126
|
}, content = _fs.default.readFileSync(filePath, options);
|
|
127
127
|
return content;
|
|
128
128
|
}
|
|
129
|
-
function copyFile(sourceFilePath,
|
|
130
|
-
_fs.default.copyFileSync(sourceFilePath,
|
|
129
|
+
function copyFile(sourceFilePath, targetFilepath) {
|
|
130
|
+
_fs.default.copyFileSync(sourceFilePath, targetFilepath);
|
|
131
131
|
}
|
|
132
132
|
function writeFile(filePath, content) {
|
|
133
133
|
_fs.default.writeFileSync(filePath, content);
|
|
@@ -187,4 +187,4 @@ function ensureParentDirectoryExists(entryPath) {
|
|
|
187
187
|
}
|
|
188
188
|
}
|
|
189
189
|
|
|
190
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/utilities/fileSystem.js"],"sourcesContent":["\"use strict\";\n\nimport fs from \"fs\";\nimport path from \"path\";\n\nimport { EMPTY_STRING } from \"../constants\";\nimport { DEFAULT_ENCODING } from \"../defaults\";\n\nexport function getEntryStats(entryPath) {\n  const entryStats = fs.statSync(entryPath);\n\n  return entryStats;\n}\n\nexport function checkEntryExists(entryPath) {\n  const entryExists = fs.existsSync(entryPath);\n\n  return entryExists;\n}\n\nexport function checkFileExists(filePath) {\n  let fileExists = false;\n  \n  const entryPath = filePath, ///\n        entryExists = checkEntryExists(entryPath);\n  \n  if (entryExists) {\n    const entryFile = isEntryFile(entryPath);\n    \n    if (entryFile) {\n      fileExists = true;\n    }\n  }\n  \n  return fileExists;\n}\n\nexport function checkDirectoryExists(directoryPath) {\n  let directoryExists = false;\n\n  const entryPath = directoryPath, ///\n        entryExists = checkEntryExists(entryPath);\n\n  if (entryExists) {\n    const entryDirectory = isEntryDirectory(entryPath);\n\n    if (entryDirectory) {\n      directoryExists = true;\n    }\n  }\n\n  return directoryExists;\n}\n\nexport function isEntryFile(entryPath) {\n  const stats = getEntryStats(entryPath),\n        entryFile = stats.isFile(); ///\n\n  return entryFile;\n}\n\nexport function isEntryDirectory(entryPath) {\n  const stats = getEntryStats(entryPath),\n        entryDirectory = stats.isDirectory(); ///\n\n  return entryDirectory;\n}\n\nexport function isDirectoryEmpty(directoryPath) {\n  const subEntryNames = readDirectory(directoryPath),\n        subEntryNamesLength = subEntryNames.length,\n        directoryEmpty = (subEntryNamesLength === 0);\n\n  return directoryEmpty;\n}\n\nexport function readDirectory(directoryPath) {\n  const subEntryNames = fs.readdirSync(directoryPath);\n\n  return subEntryNames;\n}\n\nexport function readFile(filePath, encoding = DEFAULT_ENCODING) {\n  const options = {\n          encoding\n        },\n        content = fs.readFileSync(filePath, options);\n\n  return content;\n}\n\nexport function copyFile(sourceFilePath, destinationFilepath) {\n  fs.copyFileSync(sourceFilePath, destinationFilepath);\n}\n\nexport function writeFile(filePath, content) {\n  fs.writeFileSync(filePath, content);\n}\n\nexport function appendToFile(filePath, content) {\n  fs.appendFileSync(filePath, content);\n}\n\nexport function createDirectory(directoryPath, recursive = true) {\n  const options = {\n    recursive\n  };\n\n  fs.mkdirSync(directoryPath, options);\n}\n\nexport function createFile(filePath) {\n  const content = EMPTY_STRING;\n\n  fs.writeFileSync(filePath, content);\n}\n\nexport function moveEntry(oldEntryPath, newEntryPath) {\n  ensureParentDirectoryExists(newEntryPath);\n\n  renameEntry(oldEntryPath, newEntryPath);\n}\n\nexport function removeEntry(entryPath) {\n  const force = true,\n        recursive = true,\n        options = {\n          force,\n          recursive\n        };\n\n  fs.rmSync(entryPath, options);\n}\n\nexport function renameEntry(oldEntryPath, newEntryPath) {\n  fs.renameSync(oldEntryPath, newEntryPath);\n}\n\nexport default {\n  getEntryStats,\n  checkEntryExists,\n  checkFileExists,\n  checkDirectoryExists,\n  isEntryFile,\n  isEntryDirectory,\n  isDirectoryEmpty,\n  readDirectory,\n  copyFile,\n  readFile,\n  writeFile,\n  appendToFile,\n  createDirectory,\n  createFile,\n  moveEntry,\n  renameEntry,\n  removeEntry\n};\n\nfunction ensureParentDirectoryExists(entryPath) {\n  const parentDirectoryPath = path.dirname(entryPath), ///\n        parentDirectoryExists = checkDirectoryExists(parentDirectoryPath);\n\n  if (!parentDirectoryExists) {\n    const recursive = true;\n\n    createDirectory(parentDirectoryPath, recursive);\n  }\n}\n"],"names":["appendToFile","checkDirectoryExists","checkEntryExists","checkFileExists","copyFile","createDirectory","createFile","getEntryStats","isDirectoryEmpty","isEntryDirectory","isEntryFile","moveEntry","readDirectory","readFile","removeEntry","renameEntry","writeFile","entryPath","entryStats","fs","statSync","entryExists","existsSync","filePath","fileExists","entryFile","directoryPath","directoryExists","entryDirectory","stats","isFile","isDirectory","subEntryNames","subEntryNamesLength","length","directoryEmpty","readdirSync","encoding","DEFAULT_ENCODING","options","content","readFileSync","sourceFilePath","destinationFilepath","copyFileSync","writeFileSync","appendFileSync","recursive","mkdirSync","EMPTY_STRING","oldEntryPath","newEntryPath","ensureParentDirectoryExists","force","rmSync","renameSync","parentDirectoryPath","path","dirname","parentDirectoryExists"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"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"}
|
|
190
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/utilities/fileSystem.js"],"sourcesContent":["\"use strict\";\n\nimport fs from \"fs\";\nimport path from \"path\";\n\nimport { EMPTY_STRING } from \"../constants\";\nimport { DEFAULT_ENCODING } from \"../defaults\";\n\nexport function getEntryStats(entryPath) {\n  const entryStats = fs.statSync(entryPath);\n\n  return entryStats;\n}\n\nexport function checkEntryExists(entryPath) {\n  const entryExists = fs.existsSync(entryPath);\n\n  return entryExists;\n}\n\nexport function checkFileExists(filePath) {\n  let fileExists = false;\n  \n  const entryPath = filePath, ///\n        entryExists = checkEntryExists(entryPath);\n  \n  if (entryExists) {\n    const entryFile = isEntryFile(entryPath);\n    \n    if (entryFile) {\n      fileExists = true;\n    }\n  }\n  \n  return fileExists;\n}\n\nexport function checkDirectoryExists(directoryPath) {\n  let directoryExists = false;\n\n  const entryPath = directoryPath, ///\n        entryExists = checkEntryExists(entryPath);\n\n  if (entryExists) {\n    const entryDirectory = isEntryDirectory(entryPath);\n\n    if (entryDirectory) {\n      directoryExists = true;\n    }\n  }\n\n  return directoryExists;\n}\n\nexport function isEntryFile(entryPath) {\n  const stats = getEntryStats(entryPath),\n        entryFile = stats.isFile(); ///\n\n  return entryFile;\n}\n\nexport function isEntryDirectory(entryPath) {\n  const stats = getEntryStats(entryPath),\n        entryDirectory = stats.isDirectory(); ///\n\n  return entryDirectory;\n}\n\nexport function isDirectoryEmpty(directoryPath) {\n  const subEntryNames = readDirectory(directoryPath),\n        subEntryNamesLength = subEntryNames.length,\n        directoryEmpty = (subEntryNamesLength === 0);\n\n  return directoryEmpty;\n}\n\nexport function readDirectory(directoryPath) {\n  const subEntryNames = fs.readdirSync(directoryPath);\n\n  return subEntryNames;\n}\n\nexport function readFile(filePath, encoding = DEFAULT_ENCODING) {\n  const options = {\n          encoding\n        },\n        content = fs.readFileSync(filePath, options);\n\n  return content;\n}\n\nexport function copyFile(sourceFilePath, targetFilepath) {\n  fs.copyFileSync(sourceFilePath, targetFilepath);\n}\n\nexport function writeFile(filePath, content) {\n  fs.writeFileSync(filePath, content);\n}\n\nexport function appendToFile(filePath, content) {\n  fs.appendFileSync(filePath, content);\n}\n\nexport function createDirectory(directoryPath, recursive = true) {\n  const options = {\n    recursive\n  };\n\n  fs.mkdirSync(directoryPath, options);\n}\n\nexport function createFile(filePath) {\n  const content = EMPTY_STRING;\n\n  fs.writeFileSync(filePath, content);\n}\n\nexport function moveEntry(oldEntryPath, newEntryPath) {\n  ensureParentDirectoryExists(newEntryPath);\n\n  renameEntry(oldEntryPath, newEntryPath);\n}\n\nexport function removeEntry(entryPath) {\n  const force = true,\n        recursive = true,\n        options = {\n          force,\n          recursive\n        };\n\n  fs.rmSync(entryPath, options);\n}\n\nexport function renameEntry(oldEntryPath, newEntryPath) {\n  fs.renameSync(oldEntryPath, newEntryPath);\n}\n\nexport default {\n  getEntryStats,\n  checkEntryExists,\n  checkFileExists,\n  checkDirectoryExists,\n  isEntryFile,\n  isEntryDirectory,\n  isDirectoryEmpty,\n  readDirectory,\n  copyFile,\n  readFile,\n  writeFile,\n  appendToFile,\n  createDirectory,\n  createFile,\n  moveEntry,\n  renameEntry,\n  removeEntry\n};\n\nfunction ensureParentDirectoryExists(entryPath) {\n  const parentDirectoryPath = path.dirname(entryPath), ///\n        parentDirectoryExists = checkDirectoryExists(parentDirectoryPath);\n\n  if (!parentDirectoryExists) {\n    const recursive = true;\n\n    createDirectory(parentDirectoryPath, recursive);\n  }\n}\n"],"names":["appendToFile","checkDirectoryExists","checkEntryExists","checkFileExists","copyFile","createDirectory","createFile","getEntryStats","isDirectoryEmpty","isEntryDirectory","isEntryFile","moveEntry","readDirectory","readFile","removeEntry","renameEntry","writeFile","entryPath","entryStats","fs","statSync","entryExists","existsSync","filePath","fileExists","entryFile","directoryPath","directoryExists","entryDirectory","stats","isFile","isDirectory","subEntryNames","subEntryNamesLength","length","directoryEmpty","readdirSync","encoding","DEFAULT_ENCODING","options","content","readFileSync","sourceFilePath","targetFilepath","copyFileSync","writeFileSync","appendFileSync","recursive","mkdirSync","EMPTY_STRING","oldEntryPath","newEntryPath","ensureParentDirectoryExists","force","rmSync","renameSync","parentDirectoryPath","path","dirname","parentDirectoryExists"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"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"}
|
package/lib/utilities/logging.js
CHANGED
|
@@ -182,17 +182,17 @@ function lineNumberFromStackMessage(stackMessage) {
|
|
|
182
182
|
var matches = stackMessage.match(/:(\d+)/m), secondMatch = (0, _array.second)(matches), lineNumber = secondMatch; ///
|
|
183
183
|
return lineNumber;
|
|
184
184
|
}
|
|
185
|
-
function padStartWithZeroes(string,
|
|
186
|
-
var padString = _constants.ZERO, paddedString = padStart(string,
|
|
185
|
+
function padStartWithZeroes(string, length) {
|
|
186
|
+
var padString = _constants.ZERO, paddedString = padStart(string, length, padString);
|
|
187
187
|
return paddedString;
|
|
188
188
|
}
|
|
189
|
-
function padStart(string,
|
|
189
|
+
function padStart(string, length, padString) {
|
|
190
190
|
var padding = _constants.EMPTY_STRING;
|
|
191
|
-
for(var index = 0; index <
|
|
191
|
+
for(var index = 0; index < length; index++){
|
|
192
192
|
padding += padString;
|
|
193
193
|
}
|
|
194
|
-
var paddedString = "".concat(padding).concat(string).substr(-
|
|
194
|
+
var paddedString = "".concat(padding).concat(string).substr(-length);
|
|
195
195
|
return paddedString;
|
|
196
196
|
}
|
|
197
197
|
|
|
198
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/utilities/logging.js"],"sourcesContent":["\"use strict\";\n\nimport path from \"path\";\n\nimport { second } from \"../utilities/array\";\nimport { concatenatePaths } from \"../utilities/path\";\nimport { ZERO, EMPTY_STRING } from \"../constants\";\nimport { checkFileExists, readFile, appendToFile, renameFile, getStats } from \"../utilities/fileSystem\";\nimport { DEFAULT_LOG_LEVEL, DEFAULT_LOG_FILE_BASE_NAME, DEFAULT_LOG_DIRECTORY_PATH } from \"../defaults\";\nimport { TRACE_LEVEL, DEBUG_LEVEL, INFO_LEVEL, WARNING_LEVEL, ERROR_LEVEL, FATAL_LEVEL } from \"../levels\";\n\nconst levels = [\n  TRACE_LEVEL,\n  DEBUG_LEVEL,\n  INFO_LEVEL,\n  WARNING_LEVEL,\n  ERROR_LEVEL,\n  FATAL_LEVEL,\n];\n\nlet logLevel = DEFAULT_LOG_LEVEL,\n    logFileBaseName = DEFAULT_LOG_FILE_BASE_NAME,\n    logDirectoryPath = DEFAULT_LOG_DIRECTORY_PATH;\n\nexport function log(messageOrError, level = EMPTY_STRING) {\n  let salientStackMessageIndex = 1;\n\n  if (level !== EMPTY_STRING) {\n    const levelIndex = levels.indexOf(level),\n          logLevelIndex = levels.indexOf(logLevel);\n\n    if (levelIndex < logLevelIndex) {\n      return;\n    }\n\n    salientStackMessageIndex += 2;\n\n    level = `${level}`;  ///\n  }\n\n  let error,\n      message;\n\n  if (messageOrError instanceof Error) {\n    error = messageOrError; ///\n\n    ({ message } = error);\n  } else {\n    message = messageOrError; ///\n\n    error = new Error(message);\n  }\n\n  const { stack } = error,\n        stackMessages = stackMessagesFromStack(stack),\n        salientStackMessage = stackMessages[salientStackMessageIndex],\n        stackMessage = salientStackMessage, ///\n        upperCaseLevel = level.toUpperCase(),\n        currentDateAndTimeString = getCurrentDateAndTimeString(),\n        filePath = filePathFromStackMessage(stackMessage),\n        lineNumber = lineNumberFromStackMessage(stackMessage);\n\n  message = `${upperCaseLevel} ${currentDateAndTimeString} ${filePath}(${lineNumber}) ${message}`;\n\n  console.log(message);\n\n  if (logDirectoryPath !== null) {\n    rollOverLogFile();\n\n    const logFilePath = getLogFilePath(),\n          logFileContent = `${message}\\n`;\n\n    appendToFile(logFilePath, logFileContent);\n  }\n\n  return message;\n}\n\nexport default {\n  log\n}\n\nfunction trace(message) { return log(message, TRACE_LEVEL); }\n\nfunction debug(message) { return log(message, DEBUG_LEVEL); }\n\nfunction info(message) { return log(message, INFO_LEVEL); }\n\nfunction warning(message) { return log(message, WARNING_LEVEL); }\n\nfunction error(message) { return log(message, ERROR_LEVEL); }\n\nfunction fatal(message) { return log(message, FATAL_LEVEL); }\n\nfunction setLogLevel(level) { logLevel = level; }\n\nfunction setLogOptions(logOptions) {\n  const { level, fileBaseName, directoryPath } = logOptions;\n\n  setLogLevel(level);\n\n  setLogFileBaseName(fileBaseName);\n\n  setLogDirectoryPath(directoryPath);\n}\n\nfunction getLogFileContent() {\n  const logFilePath = getLogFilePath(),\n        logFileContent = readFile(logFilePath);\n\n  return logFileContent;\n}\n\nfunction setLogFileBaseName(fileBaseName) { logFileBaseName = fileBaseName; }\n\nfunction setLogDirectoryPath(directoryPath) { logDirectoryPath = directoryPath; }\n\nObject.assign(log, {\n  trace,\n  debug,\n  info,\n  warning,\n  error,\n  fatal,\n  setLogLevel,\n  setLogOptions,\n  getLogFileContent,\n  setLogFileBaseName,\n  setLogDirectoryPath\n});\n\nfunction getLogFilePath() {\n  const logFileName = `${logFileBaseName}.log`,\n        logFilePath = concatenatePaths(logDirectoryPath, logFileName);\n\n  return logFilePath;\n}\n\nfunction getRolledOverLogFilePath() {\n  const currentDateString = getCurrentDateString(),\n        rolledOverLogFileName = `${logFileBaseName}.${currentDateString}.log`,\n        rolledOverLogFilePath = concatenatePaths(logDirectoryPath, rolledOverLogFileName);\n\n  return rolledOverLogFilePath;\n}\n\nfunction getLogFileLastModifiedDate() {\n  const logFilePath = getLogFilePath(),\n        logFileStats = getStats(logFilePath),\n        { mtime } = logFileStats,\n        logFileLastModifiedDate = new Date(mtime);  ///\n\n  return logFileLastModifiedDate;\n}\n\nfunction rollOverLogFile() {\n  const logFilePath = getLogFilePath(),\n        logFileExists = checkFileExists(logFilePath);\n\n  if (!logFileExists) {\n    return;\n  }\n\n  const logFileLastModifiedDate = getLogFileLastModifiedDate(),\n        logFileLastModifiedDateCurrentDate = isDateCurrentDate(logFileLastModifiedDate);\n\n  if (!logFileLastModifiedDateCurrentDate) {\n    const rolledOverLogFilePath = getRolledOverLogFilePath();\n\n    renameFile(logFilePath, rolledOverLogFilePath);\n  }\n}\n\nfunction isDateCurrentDate(date) {\n  const currentDate = new Date(),\n        dateString = date.toDateString(),\n        currentDateString = currentDate.toDateString(),\n        dateCurrentDate = (dateString === currentDateString);\n\n  return dateCurrentDate;\n}\n\nfunction getCurrentDateString() {\n  const date = new Date(),\n        day = padStartWithZeroes(date.getDate(), 2),  ///\n        month = padStartWithZeroes(date.getMonth() + 1, 2), ///\n        year = date.getFullYear(),\n        currentDateAndTimeString = `${day}-${month}-${year}`;\n\n  return currentDateAndTimeString;\n}\n\nfunction getCurrentDateAndTimeString() {\n  const date = new Date(),\n        day = padStartWithZeroes(date.getDate(), 2),  ///\n        month = padStartWithZeroes(date.getMonth() + 1, 2), ///\n        year = date.getFullYear(),\n        hours = padStartWithZeroes(date.getHours(), 2),\n        minutes = padStartWithZeroes(date.getMinutes(), 2),\n        seconds = padStartWithZeroes(date.getSeconds(), 2),\n        milliseconds = padStartWithZeroes(date.getMilliseconds(), 3),\n        currentDateAndTimeString = `${day}-${month}-${year} ${hours}:${minutes}:${seconds}.${milliseconds}`;\n\n  return currentDateAndTimeString;\n}\n\nfunction stackMessagesFromStack(stack) {\n  const stackMessages = [],\n        stackLines = stack.split(/\\r\\n|\\n/);\n\n  let stackMessage = EMPTY_STRING;\n\n  stackLines.forEach((stackLine) => {\n    const matches = /^\\s*at.*/.test(stackLine);\n\n    stackMessage = (stackMessage === EMPTY_STRING) ?\n                      stackLine :\n                        `${stackMessage}\\n${stackLine}`;\n\n    if (matches) {\n      stackMessages.push(stackMessage);\n\n      stackMessage = EMPTY_STRING;\n    }\n  });\n\n  return stackMessages;\n}\n\nfunction filePathFromStackMessage(stackMessage) {\n  const matches = stackMessage.match(/(\\/.+):\\d+:\\d+/m),\n        secondMatch = second(matches),\n        absoluteFilePath = secondMatch,  ///\n        currentWorkingDirectoryPath = path.resolve(\".\"),  ///\n        currentWorkingDirectoryPathLength = currentWorkingDirectoryPath.length,\n        start = currentWorkingDirectoryPathLength + 1,  ///\n        filePath = absoluteFilePath.substr(start);\n\n  return filePath;\n}\n\nfunction lineNumberFromStackMessage(stackMessage) {\n  const matches = stackMessage.match(/:(\\d+)/m),\n        secondMatch = second(matches),\n        lineNumber = secondMatch; ///\n\n  return lineNumber;\n}\n\nfunction padStartWithZeroes(string, targetLength) {\n  const padString = ZERO, ///\n        paddedString = padStart(string, targetLength, padString);\n\n  return paddedString;\n}\n\nfunction padStart(string, targetLength, padString) {\n  let padding = EMPTY_STRING;\n\n  for (let index = 0; index < targetLength; index++) {\n    padding += padString;\n  }\n\n  const paddedString = `${padding}${string}`.substr(-targetLength);\n\n  return paddedString;\n}\n"],"names":["log","levels","TRACE_LEVEL","DEBUG_LEVEL","INFO_LEVEL","WARNING_LEVEL","ERROR_LEVEL","FATAL_LEVEL","logLevel","DEFAULT_LOG_LEVEL","logFileBaseName","DEFAULT_LOG_FILE_BASE_NAME","logDirectoryPath","DEFAULT_LOG_DIRECTORY_PATH","messageOrError","level","EMPTY_STRING","salientStackMessageIndex","levelIndex","indexOf","logLevelIndex","error","message","Error","stack","stackMessages","stackMessagesFromStack","salientStackMessage","stackMessage","upperCaseLevel","toUpperCase","currentDateAndTimeString","getCurrentDateAndTimeString","filePath","filePathFromStackMessage","lineNumber","lineNumberFromStackMessage","console","rollOverLogFile","logFilePath","getLogFilePath","logFileContent","appendToFile","trace","debug","info","warning","fatal","setLogLevel","setLogOptions","logOptions","fileBaseName","directoryPath","setLogFileBaseName","setLogDirectoryPath","getLogFileContent","readFile","Object","assign","logFileName","concatenatePaths","getRolledOverLogFilePath","currentDateString","getCurrentDateString","rolledOverLogFileName","rolledOverLogFilePath","getLogFileLastModifiedDate","logFileStats","getStats","mtime","logFileLastModifiedDate","Date","logFileExists","checkFileExists","logFileLastModifiedDateCurrentDate","isDateCurrentDate","renameFile","date","currentDate","dateString","toDateString","dateCurrentDate","day","padStartWithZeroes","getDate","month","getMonth","year","getFullYear","hours","getHours","minutes","getMinutes","seconds","getSeconds","milliseconds","getMilliseconds","stackLines","split","forEach","stackLine","matches","test","push","match","secondMatch","second","absoluteFilePath","currentWorkingDirectoryPath","path","resolve","currentWorkingDirectoryPathLength","length","start","substr","string","targetLength","padString","ZERO","paddedString","padStart","padding","index"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"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"}
|
|
198
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/utilities/logging.js"],"sourcesContent":["\"use strict\";\n\nimport path from \"path\";\n\nimport { second } from \"../utilities/array\";\nimport { concatenatePaths } from \"../utilities/path\";\nimport { ZERO, EMPTY_STRING } from \"../constants\";\nimport { checkFileExists, readFile, appendToFile, renameFile, getStats } from \"../utilities/fileSystem\";\nimport { DEFAULT_LOG_LEVEL, DEFAULT_LOG_FILE_BASE_NAME, DEFAULT_LOG_DIRECTORY_PATH } from \"../defaults\";\nimport { TRACE_LEVEL, DEBUG_LEVEL, INFO_LEVEL, WARNING_LEVEL, ERROR_LEVEL, FATAL_LEVEL } from \"../levels\";\n\nconst levels = [\n  TRACE_LEVEL,\n  DEBUG_LEVEL,\n  INFO_LEVEL,\n  WARNING_LEVEL,\n  ERROR_LEVEL,\n  FATAL_LEVEL,\n];\n\nlet logLevel = DEFAULT_LOG_LEVEL,\n    logFileBaseName = DEFAULT_LOG_FILE_BASE_NAME,\n    logDirectoryPath = DEFAULT_LOG_DIRECTORY_PATH;\n\nexport function log(messageOrError, level = EMPTY_STRING) {\n  let salientStackMessageIndex = 1;\n\n  if (level !== EMPTY_STRING) {\n    const levelIndex = levels.indexOf(level),\n          logLevelIndex = levels.indexOf(logLevel);\n\n    if (levelIndex < logLevelIndex) {\n      return;\n    }\n\n    salientStackMessageIndex += 2;\n\n    level = `${level}`;  ///\n  }\n\n  let error,\n      message;\n\n  if (messageOrError instanceof Error) {\n    error = messageOrError; ///\n\n    ({ message } = error);\n  } else {\n    message = messageOrError; ///\n\n    error = new Error(message);\n  }\n\n  const { stack } = error,\n        stackMessages = stackMessagesFromStack(stack),\n        salientStackMessage = stackMessages[salientStackMessageIndex],\n        stackMessage = salientStackMessage, ///\n        upperCaseLevel = level.toUpperCase(),\n        currentDateAndTimeString = getCurrentDateAndTimeString(),\n        filePath = filePathFromStackMessage(stackMessage),\n        lineNumber = lineNumberFromStackMessage(stackMessage);\n\n  message = `${upperCaseLevel} ${currentDateAndTimeString} ${filePath}(${lineNumber}) ${message}`;\n\n  console.log(message);\n\n  if (logDirectoryPath !== null) {\n    rollOverLogFile();\n\n    const logFilePath = getLogFilePath(),\n          logFileContent = `${message}\\n`;\n\n    appendToFile(logFilePath, logFileContent);\n  }\n\n  return message;\n}\n\nexport default {\n  log\n}\n\nfunction trace(message) { return log(message, TRACE_LEVEL); }\n\nfunction debug(message) { return log(message, DEBUG_LEVEL); }\n\nfunction info(message) { return log(message, INFO_LEVEL); }\n\nfunction warning(message) { return log(message, WARNING_LEVEL); }\n\nfunction error(message) { return log(message, ERROR_LEVEL); }\n\nfunction fatal(message) { return log(message, FATAL_LEVEL); }\n\nfunction setLogLevel(level) { logLevel = level; }\n\nfunction setLogOptions(logOptions) {\n  const { level, fileBaseName, directoryPath } = logOptions;\n\n  setLogLevel(level);\n\n  setLogFileBaseName(fileBaseName);\n\n  setLogDirectoryPath(directoryPath);\n}\n\nfunction getLogFileContent() {\n  const logFilePath = getLogFilePath(),\n        logFileContent = readFile(logFilePath);\n\n  return logFileContent;\n}\n\nfunction setLogFileBaseName(fileBaseName) { logFileBaseName = fileBaseName; }\n\nfunction setLogDirectoryPath(directoryPath) { logDirectoryPath = directoryPath; }\n\nObject.assign(log, {\n  trace,\n  debug,\n  info,\n  warning,\n  error,\n  fatal,\n  setLogLevel,\n  setLogOptions,\n  getLogFileContent,\n  setLogFileBaseName,\n  setLogDirectoryPath\n});\n\nfunction getLogFilePath() {\n  const logFileName = `${logFileBaseName}.log`,\n        logFilePath = concatenatePaths(logDirectoryPath, logFileName);\n\n  return logFilePath;\n}\n\nfunction getRolledOverLogFilePath() {\n  const currentDateString = getCurrentDateString(),\n        rolledOverLogFileName = `${logFileBaseName}.${currentDateString}.log`,\n        rolledOverLogFilePath = concatenatePaths(logDirectoryPath, rolledOverLogFileName);\n\n  return rolledOverLogFilePath;\n}\n\nfunction getLogFileLastModifiedDate() {\n  const logFilePath = getLogFilePath(),\n        logFileStats = getStats(logFilePath),\n        { mtime } = logFileStats,\n        logFileLastModifiedDate = new Date(mtime);  ///\n\n  return logFileLastModifiedDate;\n}\n\nfunction rollOverLogFile() {\n  const logFilePath = getLogFilePath(),\n        logFileExists = checkFileExists(logFilePath);\n\n  if (!logFileExists) {\n    return;\n  }\n\n  const logFileLastModifiedDate = getLogFileLastModifiedDate(),\n        logFileLastModifiedDateCurrentDate = isDateCurrentDate(logFileLastModifiedDate);\n\n  if (!logFileLastModifiedDateCurrentDate) {\n    const rolledOverLogFilePath = getRolledOverLogFilePath();\n\n    renameFile(logFilePath, rolledOverLogFilePath);\n  }\n}\n\nfunction isDateCurrentDate(date) {\n  const currentDate = new Date(),\n        dateString = date.toDateString(),\n        currentDateString = currentDate.toDateString(),\n        dateCurrentDate = (dateString === currentDateString);\n\n  return dateCurrentDate;\n}\n\nfunction getCurrentDateString() {\n  const date = new Date(),\n        day = padStartWithZeroes(date.getDate(), 2),  ///\n        month = padStartWithZeroes(date.getMonth() + 1, 2), ///\n        year = date.getFullYear(),\n        currentDateAndTimeString = `${day}-${month}-${year}`;\n\n  return currentDateAndTimeString;\n}\n\nfunction getCurrentDateAndTimeString() {\n  const date = new Date(),\n        day = padStartWithZeroes(date.getDate(), 2),  ///\n        month = padStartWithZeroes(date.getMonth() + 1, 2), ///\n        year = date.getFullYear(),\n        hours = padStartWithZeroes(date.getHours(), 2),\n        minutes = padStartWithZeroes(date.getMinutes(), 2),\n        seconds = padStartWithZeroes(date.getSeconds(), 2),\n        milliseconds = padStartWithZeroes(date.getMilliseconds(), 3),\n        currentDateAndTimeString = `${day}-${month}-${year} ${hours}:${minutes}:${seconds}.${milliseconds}`;\n\n  return currentDateAndTimeString;\n}\n\nfunction stackMessagesFromStack(stack) {\n  const stackMessages = [],\n        stackLines = stack.split(/\\r\\n|\\n/);\n\n  let stackMessage = EMPTY_STRING;\n\n  stackLines.forEach((stackLine) => {\n    const matches = /^\\s*at.*/.test(stackLine);\n\n    stackMessage = (stackMessage === EMPTY_STRING) ?\n                      stackLine :\n                        `${stackMessage}\\n${stackLine}`;\n\n    if (matches) {\n      stackMessages.push(stackMessage);\n\n      stackMessage = EMPTY_STRING;\n    }\n  });\n\n  return stackMessages;\n}\n\nfunction filePathFromStackMessage(stackMessage) {\n  const matches = stackMessage.match(/(\\/.+):\\d+:\\d+/m),\n        secondMatch = second(matches),\n        absoluteFilePath = secondMatch,  ///\n        currentWorkingDirectoryPath = path.resolve(\".\"),  ///\n        currentWorkingDirectoryPathLength = currentWorkingDirectoryPath.length,\n        start = currentWorkingDirectoryPathLength + 1,  ///\n        filePath = absoluteFilePath.substr(start);\n\n  return filePath;\n}\n\nfunction lineNumberFromStackMessage(stackMessage) {\n  const matches = stackMessage.match(/:(\\d+)/m),\n        secondMatch = second(matches),\n        lineNumber = secondMatch; ///\n\n  return lineNumber;\n}\n\nfunction padStartWithZeroes(string, length) {\n  const padString = ZERO, ///\n        paddedString = padStart(string, length, padString);\n\n  return paddedString;\n}\n\nfunction padStart(string, length, padString) {\n  let padding = EMPTY_STRING;\n\n  for (let index = 0; index < length; index++) {\n    padding += padString;\n  }\n\n  const paddedString = `${padding}${string}`.substr(-length);\n\n  return paddedString;\n}\n"],"names":["log","levels","TRACE_LEVEL","DEBUG_LEVEL","INFO_LEVEL","WARNING_LEVEL","ERROR_LEVEL","FATAL_LEVEL","logLevel","DEFAULT_LOG_LEVEL","logFileBaseName","DEFAULT_LOG_FILE_BASE_NAME","logDirectoryPath","DEFAULT_LOG_DIRECTORY_PATH","messageOrError","level","EMPTY_STRING","salientStackMessageIndex","levelIndex","indexOf","logLevelIndex","error","message","Error","stack","stackMessages","stackMessagesFromStack","salientStackMessage","stackMessage","upperCaseLevel","toUpperCase","currentDateAndTimeString","getCurrentDateAndTimeString","filePath","filePathFromStackMessage","lineNumber","lineNumberFromStackMessage","console","rollOverLogFile","logFilePath","getLogFilePath","logFileContent","appendToFile","trace","debug","info","warning","fatal","setLogLevel","setLogOptions","logOptions","fileBaseName","directoryPath","setLogFileBaseName","setLogDirectoryPath","getLogFileContent","readFile","Object","assign","logFileName","concatenatePaths","getRolledOverLogFilePath","currentDateString","getCurrentDateString","rolledOverLogFileName","rolledOverLogFilePath","getLogFileLastModifiedDate","logFileStats","getStats","mtime","logFileLastModifiedDate","Date","logFileExists","checkFileExists","logFileLastModifiedDateCurrentDate","isDateCurrentDate","renameFile","date","currentDate","dateString","toDateString","dateCurrentDate","day","padStartWithZeroes","getDate","month","getMonth","year","getFullYear","hours","getHours","minutes","getMinutes","seconds","getSeconds","milliseconds","getMilliseconds","stackLines","split","forEach","stackLine","matches","test","push","match","secondMatch","second","absoluteFilePath","currentWorkingDirectoryPath","path","resolve","currentWorkingDirectoryPathLength","length","start","substr","string","padString","ZERO","paddedString","padStart","padding","index"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"AAAA;;;;;;;;;;;IA8EA,OAEC;eAFD;;IAtDgBA,GAAG;eAAHA;;;2DAtBC;qBAEM;qBACU;yBACE;0BAC2C;wBACY;sBACI;;;;;;;;;;;;;AAE9F,IAAMC,SAAS;IACbC,mBAAW;IACXC,mBAAW;IACXC,kBAAU;IACVC,qBAAa;IACbC,mBAAW;IACXC,mBAAW;CACZ;AAED,IAAIC,WAAWC,2BAAiB,EAC5BC,kBAAkBC,oCAA0B,EAC5CC,mBAAmBC,oCAA0B;AAE1C,SAASb,IAAIc,cAAc;QAAEC,QAAAA,iEAAQC,uBAAY;IACtD,IAAIC,2BAA2B;IAE/B,IAAIF,UAAUC,uBAAY,EAAE;QAC1B,IAAME,aAAajB,OAAOkB,OAAO,CAACJ,QAC5BK,gBAAgBnB,OAAOkB,OAAO,CAACX;QAErC,IAAIU,aAAaE,eAAe;YAC9B;QACF;QAEAH,4BAA4B;QAE5BF,QAAQ,AAAC,GAAQ,OAANA,QAAU,GAAG;IAC1B;IAEA,IAAIM,SACAC;IAEJ,IAAIR,AAAc,YAAdA,gBAA0BS,QAAO;QACnCF,UAAQP,gBAAgB,GAAG;QAExBQ,UAAYD,QAAZC;IACL,OAAO;QACLA,UAAUR,gBAAgB,GAAG;QAE7BO,UAAQ,IAAIE,MAAMD;IACpB;IAEA,IAAM,AAAEE,QAAUH,QAAVG,OACFC,gBAAgBC,uBAAuBF,QACvCG,sBAAsBF,aAAa,CAACR,yBAAyB,EAC7DW,eAAeD,qBACfE,iBAAiBd,MAAMe,WAAW,IAClCC,2BAA2BC,+BAC3BC,WAAWC,yBAAyBN,eACpCO,aAAaC,2BAA2BR;IAE9CN,UAAU,AAAC,GAAoBS,OAAlBF,gBAAe,KAA+BI,OAA5BF,0BAAyB,KAAeI,OAAZF,UAAS,KAAkBX,OAAfa,YAAW,MAAY,OAARb;IAEtFe,QAAQrC,GAAG,CAACsB;IAEZ,IAAIV,qBAAqB,MAAM;QAC7B0B;QAEA,IAAMC,cAAcC,kBACdC,iBAAiB,AAAC,GAAU,OAARnB,SAAQ;QAElCoB,IAAAA,wBAAY,EAACH,aAAaE;IAC5B;IAEA,OAAOnB;AACT;IAEA,WAAe;IACbtB,KAAAA;AACF;AAEA,SAAS2C,MAAMrB,OAAO;IAAI,OAAOtB,IAAIsB,SAASpB,mBAAW;AAAG;AAE5D,SAAS0C,MAAMtB,OAAO;IAAI,OAAOtB,IAAIsB,SAASnB,mBAAW;AAAG;AAE5D,SAAS0C,KAAKvB,OAAO;IAAI,OAAOtB,IAAIsB,SAASlB,kBAAU;AAAG;AAE1D,SAAS0C,QAAQxB,OAAO;IAAI,OAAOtB,IAAIsB,SAASjB,qBAAa;AAAG;AAEhE,SAASgB,MAAMC,OAAO;IAAI,OAAOtB,IAAIsB,SAAShB,mBAAW;AAAG;AAE5D,SAASyC,MAAMzB,OAAO;IAAI,OAAOtB,IAAIsB,SAASf,mBAAW;AAAG;AAE5D,SAASyC,YAAYjC,KAAK;IAAIP,WAAWO;AAAO;AAEhD,SAASkC,cAAcC,UAAU;IAC/B,IAAQnC,QAAuCmC,WAAvCnC,OAAOoC,eAAgCD,WAAhCC,cAAcC,gBAAkBF,WAAlBE;IAE7BJ,YAAYjC;IAEZsC,mBAAmBF;IAEnBG,oBAAoBF;AACtB;AAEA,SAASG;IACP,IAAMhB,cAAcC,kBACdC,iBAAiBe,IAAAA,oBAAQ,EAACjB;IAEhC,OAAOE;AACT;AAEA,SAASY,mBAAmBF,YAAY;IAAIzC,kBAAkByC;AAAc;AAE5E,SAASG,oBAAoBF,aAAa;IAAIxC,mBAAmBwC;AAAe;AAEhFK,OAAOC,MAAM,CAAC1D,KAAK;IACjB2C,OAAAA;IACAC,OAAAA;IACAC,MAAAA;IACAC,SAAAA;IACAzB,OAAAA;IACA0B,OAAAA;IACAC,aAAAA;IACAC,eAAAA;IACAM,mBAAAA;IACAF,oBAAAA;IACAC,qBAAAA;AACF;AAEA,SAASd;IACP,IAAMmB,cAAc,AAAC,GAAkB,OAAhBjD,iBAAgB,SACjC6B,cAAcqB,IAAAA,uBAAgB,EAAChD,kBAAkB+C;IAEvD,OAAOpB;AACT;AAEA,SAASsB;IACP,IAAMC,oBAAoBC,wBACpBC,wBAAwB,AAAC,GAAqBF,OAAnBpD,iBAAgB,KAAqB,OAAlBoD,mBAAkB,SAChEG,wBAAwBL,IAAAA,uBAAgB,EAAChD,kBAAkBoD;IAEjE,OAAOC;AACT;AAEA,SAASC;IACP,IAAM3B,cAAcC,kBACd2B,eAAeC,IAAAA,oBAAQ,EAAC7B,cACxB,AAAE8B,QAAUF,aAAVE,OACFC,0BAA0B,IAAIC,KAAKF,QAAS,GAAG;IAErD,OAAOC;AACT;AAEA,SAAShC;IACP,IAAMC,cAAcC,kBACdgC,gBAAgBC,IAAAA,2BAAe,EAAClC;IAEtC,IAAI,CAACiC,eAAe;QAClB;IACF;IAEA,IAAMF,0BAA0BJ,8BAC1BQ,qCAAqCC,kBAAkBL;IAE7D,IAAI,CAACI,oCAAoC;QACvC,IAAMT,wBAAwBJ;QAE9Be,IAAAA,sBAAU,EAACrC,aAAa0B;IAC1B;AACF;AAEA,SAASU,kBAAkBE,IAAI;IAC7B,IAAMC,cAAc,IAAIP,QAClBQ,aAAaF,KAAKG,YAAY,IAC9BlB,oBAAoBgB,YAAYE,YAAY,IAC5CC,kBAAmBF,eAAejB;IAExC,OAAOmB;AACT;AAEA,SAASlB;IACP,IAAMc,OAAO,IAAIN,QACXW,MAAMC,mBAAmBN,KAAKO,OAAO,IAAI,IACzCC,QAAQF,mBAAmBN,KAAKS,QAAQ,KAAK,GAAG,IAChDC,OAAOV,KAAKW,WAAW,IACvBzD,2BAA2B,AAAC,GAASsD,OAAPH,KAAI,KAAYK,OAATF,OAAM,KAAQ,OAALE;IAEpD,OAAOxD;AACT;AAEA,SAASC;IACP,IAAM6C,OAAO,IAAIN,QACXW,MAAMC,mBAAmBN,KAAKO,OAAO,IAAI,IACzCC,QAAQF,mBAAmBN,KAAKS,QAAQ,KAAK,GAAG,IAChDC,OAAOV,KAAKW,WAAW,IACvBC,QAAQN,mBAAmBN,KAAKa,QAAQ,IAAI,IAC5CC,UAAUR,mBAAmBN,KAAKe,UAAU,IAAI,IAChDC,UAAUV,mBAAmBN,KAAKiB,UAAU,IAAI,IAChDC,eAAeZ,mBAAmBN,KAAKmB,eAAe,IAAI,IAC1DjE,2BAA2B,AAAC,GAASsD,OAAPH,KAAI,KAAYK,OAATF,OAAM,KAAWI,OAARF,MAAK,KAAYI,OAATF,OAAM,KAAcI,OAAXF,SAAQ,KAAcI,OAAXF,SAAQ,KAAgB,OAAbE;IAE3F,OAAOhE;AACT;AAEA,SAASL,uBAAuBF,KAAK;IACnC,IAAMC,gBAAgB,EAAE,EAClBwE,aAAazE,MAAM0E,KAAK,CAAC;IAE/B,IAAItE,eAAeZ,uBAAY;IAE/BiF,WAAWE,OAAO,CAAC,SAACC;QAClB,IAAMC,UAAU,WAAWC,IAAI,CAACF;QAEhCxE,eAAe,AAACA,iBAAiBZ,uBAAY,GAC3BoF,YACE,AAAC,GAAmBA,OAAjBxE,cAAa,MAAc,OAAVwE;QAExC,IAAIC,SAAS;YACX5E,cAAc8E,IAAI,CAAC3E;YAEnBA,eAAeZ,uBAAY;QAC7B;IACF;IAEA,OAAOS;AACT;AAEA,SAASS,yBAAyBN,YAAY;IAC5C,IAAMyE,UAAUzE,aAAa4E,KAAK,CAAC,oBAC7BC,cAAcC,IAAAA,aAAM,EAACL,UACrBM,mBAAmBF,aACnBG,8BAA8BC,aAAI,CAACC,OAAO,CAAC,MAC3CC,oCAAoCH,4BAA4BI,MAAM,EACtEC,QAAQF,oCAAoC,GAC5C9E,WAAW0E,iBAAiBO,MAAM,CAACD;IAEzC,OAAOhF;AACT;AAEA,SAASG,2BAA2BR,YAAY;IAC9C,IAAMyE,UAAUzE,aAAa4E,KAAK,CAAC,YAC7BC,cAAcC,IAAAA,aAAM,EAACL,UACrBlE,aAAasE,aAAa,GAAG;IAEnC,OAAOtE;AACT;AAEA,SAASgD,mBAAmBgC,MAAM,EAAEH,MAAM;IACxC,IAAMI,YAAYC,eAAI,EAChBC,eAAeC,SAASJ,QAAQH,QAAQI;IAE9C,OAAOE;AACT;AAEA,SAASC,SAASJ,MAAM,EAAEH,MAAM,EAAEI,SAAS;IACzC,IAAII,UAAUxG,uBAAY;IAE1B,IAAK,IAAIyG,QAAQ,GAAGA,QAAQT,QAAQS,QAAS;QAC3CD,WAAWJ;IACb;IAEA,IAAME,eAAe,AAAC,GAAYH,OAAVK,SAAiB,OAAPL,QAASD,MAAM,CAAC,CAACF;IAEnD,OAAOM;AACT"}
|
package/package.json
CHANGED
|
@@ -89,8 +89,8 @@ export function readFile(filePath, encoding = DEFAULT_ENCODING) {
|
|
|
89
89
|
return content;
|
|
90
90
|
}
|
|
91
91
|
|
|
92
|
-
export function copyFile(sourceFilePath,
|
|
93
|
-
fs.copyFileSync(sourceFilePath,
|
|
92
|
+
export function copyFile(sourceFilePath, targetFilepath) {
|
|
93
|
+
fs.copyFileSync(sourceFilePath, targetFilepath);
|
|
94
94
|
}
|
|
95
95
|
|
|
96
96
|
export function writeFile(filePath, content) {
|
package/src/utilities/logging.js
CHANGED
|
@@ -247,21 +247,21 @@ function lineNumberFromStackMessage(stackMessage) {
|
|
|
247
247
|
return lineNumber;
|
|
248
248
|
}
|
|
249
249
|
|
|
250
|
-
function padStartWithZeroes(string,
|
|
250
|
+
function padStartWithZeroes(string, length) {
|
|
251
251
|
const padString = ZERO, ///
|
|
252
|
-
paddedString = padStart(string,
|
|
252
|
+
paddedString = padStart(string, length, padString);
|
|
253
253
|
|
|
254
254
|
return paddedString;
|
|
255
255
|
}
|
|
256
256
|
|
|
257
|
-
function padStart(string,
|
|
257
|
+
function padStart(string, length, padString) {
|
|
258
258
|
let padding = EMPTY_STRING;
|
|
259
259
|
|
|
260
|
-
for (let index = 0; index <
|
|
260
|
+
for (let index = 0; index < length; index++) {
|
|
261
261
|
padding += padString;
|
|
262
262
|
}
|
|
263
263
|
|
|
264
|
-
const paddedString = `${padding}${string}`.substr(-
|
|
264
|
+
const paddedString = `${padding}${string}`.substr(-length);
|
|
265
265
|
|
|
266
266
|
return paddedString;
|
|
267
267
|
}
|