diff --git a/.jules/bolt.md b/.jules/bolt.md
index e79ba97..ffcc609 100644
--- a/.jules/bolt.md
+++ b/.jules/bolt.md
@@ -1,3 +1,7 @@
## 2024-05-17 - O(N) lookup optimizations for Discord.js
**Learning:** Found two O(N) operations in bot.js and module Tipper scripts when looking up members or guild count.
**Action:** Replaced `bot.guilds.array().length` with `bot.guilds.size` (O(1)) and `message.guild.members.find('id', recipient)` with `message.guild.members.get(recipient)` (O(1)).
+
+## 2024-06-18 - Optimize Message Parsing Array Allocations
+**Learning:** Found O(N) array operations chaining in token extraction: `.trim().split(' ').filter(n => n !== '')`. This pattern was repeated across `bot.js` and all Tipper modules, resulting in unnecessary intermediate arrays being allocated and garbage collected for every incoming Discord message.
+**Action:** Replaced the chained methods with a single `.match(/\S+/g) || []` which is significantly more memory and CPU efficient, directly returning the required token array without intermediate allocations.
diff --git a/bot/bot.js b/bot/bot.js
index da72836..fe10147 100644
--- a/bot/bot.js
+++ b/bot/bot.js
@@ -12,25 +12,27 @@ config = config.get('bot');
var aliases;
// check if any aliases are defined
try {
- var time = moment()
- .tz('America/Los_Angeles')
- .format('MM-DD-YYYY hh:mm a');
+ var time = moment().tz('America/Los_Angeles').format('MM-DD-YYYY hh:mm a');
aliases = require('./alias.json');
- console.log('[' + time + ' PST][' + pm2Name + '] ' + Object.keys(aliases).length + ' aliases Loaded!');
+ console.log(
+ '[' +
+ time +
+ ' PST][' +
+ pm2Name +
+ '] ' +
+ Object.keys(aliases).length +
+ ' aliases Loaded!',
+ );
} catch (e) {
- var time = moment()
- .tz('America/Los_Angeles')
- .format('MM-DD-YYYY hh:mm a');
+ var time = moment().tz('America/Los_Angeles').format('MM-DD-YYYY hh:mm a');
console.log('[' + time + ' PST][' + pm2Name + '] No aliases defined');
}
var commands = {};
var bot = new Discord.Client();
-bot.on('ready', function() {
- var time = moment()
- .tz('America/Los_Angeles')
- .format('MM-DD-YYYY hh:mm a');
+bot.on('ready', function () {
+ var time = moment().tz('America/Los_Angeles').format('MM-DD-YYYY hh:mm a');
console.log(
'[' +
time +
@@ -40,21 +42,19 @@ bot.on('ready', function() {
bot.user.username +
'Logged in! Serving in ' +
bot.guilds.size + // ⚡ Bolt: O(1) property lookup vs O(N) array creation
- ' servers'
+ ' servers',
+ );
+ bot.channels.get(logChannel).send(
+ '[' +
+ time +
+ ' PST][' +
+ pm2Name +
+ '] ' +
+ bot.user.username +
+ 'Logged in! Serving in ' +
+ bot.guilds.size + // ⚡ Bolt: O(1) property lookup vs O(N) array creation
+ ' servers',
);
- bot.channels
- .get(logChannel)
- .send(
- '[' +
- time +
- ' PST][' +
- pm2Name +
- '] ' +
- bot.user.username +
- 'Logged in! Serving in ' +
- bot.guilds.size + // ⚡ Bolt: O(1) property lookup vs O(N) array creation
- ' servers'
- );
require('./plugins.js').init();
console.log(
'[' +
@@ -63,7 +63,7 @@ bot.on('ready', function() {
pm2Name +
'] type ' +
config.prefix +
- 'tiphelp in Discord for a commands list.'
+ 'tiphelp in Discord for a commands list.',
);
bot.channels
.get(logChannel)
@@ -74,10 +74,19 @@ bot.on('ready', function() {
pm2Name +
'] type ' +
config.prefix +
- 'tiphelp in Discord for a commands list.'
+ 'tiphelp in Discord for a commands list.',
);
bot.user.setActivity(config.prefix + 'Intialized!');
- var text = ['tiprvn', 'tipdoge', 'tiplbc', 'tipufo', 'tipproton', 'tippxc', 'tipftc', 'tiphelp'];
+ var text = [
+ 'tiprvn',
+ 'tipdoge',
+ 'tiplbc',
+ 'tipufo',
+ 'tipproton',
+ 'tippxc',
+ 'tipftc',
+ 'tiphelp',
+ ];
var counter = 0;
setInterval(change, 10000);
@@ -90,10 +99,8 @@ bot.on('ready', function() {
}
});
-process.on('uncaughtException', err => {
- var time = moment()
- .tz('America/Los_Angeles')
- .format('MM-DD-YYYY hh:mm a');
+process.on('uncaughtException', (err) => {
+ var time = moment().tz('America/Los_Angeles').format('MM-DD-YYYY hh:mm a');
console.log('[' + time + ' PST][' + pm2Name + '] uncaughtException: ' + err);
bot.channels
.get(logChannel)
@@ -101,10 +108,8 @@ process.on('uncaughtException', err => {
process.exit(1); //exit node.js with an error
});
-process.on('unhandledRejection', err => {
- var time = moment()
- .tz('America/Los_Angeles')
- .format('MM-DD-YYYY hh:mm a');
+process.on('unhandledRejection', (err) => {
+ var time = moment().tz('America/Los_Angeles').format('MM-DD-YYYY hh:mm a');
console.log('[' + time + ' PST][' + pm2Name + '] unhandledRejection: ' + err);
bot.channels
.get(logChannel)
@@ -112,18 +117,14 @@ process.on('unhandledRejection', err => {
process.exit(1); //exit node.js with an error
});
-bot.on('disconnected', function() {
- var time = moment()
- .tz('America/Los_Angeles')
- .format('MM-DD-YYYY hh:mm a');
+bot.on('disconnected', function () {
+ var time = moment().tz('America/Los_Angeles').format('MM-DD-YYYY hh:mm a');
console.log('[' + time + ' PST][' + pm2Name + '] Disconnected!');
process.exit(1); //exit node.js with an error
});
-bot.on('error', function(error) {
- var time = moment()
- .tz('America/Los_Angeles')
- .format('MM-DD-YYYY hh:mm a');
+bot.on('error', function (error) {
+ var time = moment().tz('America/Los_Angeles').format('MM-DD-YYYY hh:mm a');
console.log('[' + time + ' PST][' + pm2Name + '] error: ' + error);
process.exit(1); //exit node.js with an error
});
@@ -139,29 +140,31 @@ function checkMessageForCommand(msg, isEdit) {
) {
msg.author
.send('Please set your Discord Presence to Online to talk to the bot!')
- .catch(function(error) {
+ .catch(function (error) {
msg.channel
.send(
msg.author +
- ', Please enable Direct Messages from server members to communicate fully with our bot, it is located in the user setting area under Privacy & Safety tab, select the option allow direct messages from server members'
+ ', Please enable Direct Messages from server members to communicate fully with our bot, it is located in the user setting area under Privacy & Safety tab, select the option allow direct messages from server members',
)
.then(
msg.channel.send(
- 'Please set your Discord Presence to Online to talk to the Bot!'
- )
+ 'Please set your Discord Presence to Online to talk to the Bot!',
+ ),
);
return;
});
}
- var cmdTxt = msg.content.split(' ')[0].substring(config.prefix.length);
+ var cmdTxt = (msg.content.match(/\S+/g) || [''])[0].substring(
+ config.prefix.length,
+ );
var suffix = msg.content.substring(
- cmdTxt.length + config.prefix.length + 1
+ cmdTxt.length + config.prefix.length + 1,
); //add one for the ! and one for the space
if (msg.isMentioned(bot.user)) {
try {
- cmdTxt = msg.content.split(' ')[1];
+ cmdTxt = (msg.content.match(/\S+/g) || [''])[1];
suffix = msg.content.substring(
- bot.user.mention().length + cmdTxt.length + config.prefix.length + 1
+ bot.user.mention().length + cmdTxt.length + config.prefix.length + 1,
);
} catch (e) {
//no command
@@ -182,7 +185,7 @@ function checkMessageForCommand(msg, isEdit) {
msg.content +
' from ' +
msg.author.username +
- ' as command'
+ ' as command',
);
try {
cmd.process(bot, msg, suffix, isEdit);
@@ -214,37 +217,33 @@ function checkMessageForCommand(msg, isEdit) {
}
}
-bot.on('message', msg => checkMessageForCommand(msg, false));
+bot.on('message', (msg) => checkMessageForCommand(msg, false));
-exports.addCommand = function(commandName, commandObject) {
+exports.addCommand = function (commandName, commandObject) {
try {
commands[commandName] = commandObject;
} catch (err) {
- var time = moment()
- .tz('America/Los_Angeles')
- .format('MM-DD-YYYY hh:mm a');
+ var time = moment().tz('America/Los_Angeles').format('MM-DD-YYYY hh:mm a');
console.log('[' + time + ' PST][' + pm2Name + '] Error addCommand: ' + err);
bot.channels
.get(logChannel)
.send('[' + time + ' PST][' + pm2Name + '] Error addCommand: ' + err);
}
};
-exports.addCustomFunc = function(customFunc) {
+exports.addCustomFunc = function (customFunc) {
try {
customFunc(bot);
} catch (err) {
- var time = moment()
- .tz('America/Los_Angeles')
- .format('MM-DD-YYYY hh:mm a');
+ var time = moment().tz('America/Los_Angeles').format('MM-DD-YYYY hh:mm a');
console.log(
- '[' + time + ' PST][' + pm2Name + '] Error addCustomFunc: ' + err
+ '[' + time + ' PST][' + pm2Name + '] Error addCustomFunc: ' + err,
);
bot.channels
.get(logChannel)
.send('[' + time + ' PST][' + pm2Name + '] Error addCustomFunc: ' + err);
}
};
-exports.commandCount = function() {
+exports.commandCount = function () {
return Object.keys(commands).length;
};
diff --git a/bot/modules/bot-uptime.js b/bot/modules/bot-uptime.js
index 7df747a..69a2f8a 100644
--- a/bot/modules/bot-uptime.js
+++ b/bot/modules/bot-uptime.js
@@ -6,20 +6,20 @@ exports.commands = ['uptime'];
exports.uptime = {
usage: '',
description: 'gets Uptime for Bot',
- process: function(bot, msg, suffix) {
+ process: function (bot, msg, suffix) {
if (suffix != pm2Name) {
return;
}
msg.channel.send(
'i have been Online for ' +
- Math.round(bot.uptime / (1000 * 60 * 60 * 24)) +
- ' days, ' +
- Math.round(bot.uptime / (1000 * 60 * 60)) +
- ' hours, ' +
- Math.round(bot.uptime / (1000 * 60)) % 60 +
- ' minutes, and ' +
- Math.round(bot.uptime / 1000) % 60 +
- ' seconds'
+ Math.round(bot.uptime / (1000 * 60 * 60 * 24)) +
+ ' days, ' +
+ Math.round(bot.uptime / (1000 * 60 * 60)) +
+ ' hours, ' +
+ (Math.round(bot.uptime / (1000 * 60)) % 60) +
+ ' minutes, and ' +
+ (Math.round(bot.uptime / 1000) % 60) +
+ ' seconds',
);
- }
+ },
};
diff --git a/bot/modules/dogeTipper.js b/bot/modules/dogeTipper.js
index 54258df..ac84477 100644
--- a/bot/modules/dogeTipper.js
+++ b/bot/modules/dogeTipper.js
@@ -19,12 +19,7 @@ exports.tipdoge = {
paytxfee,
process: async function (bot, msg, suffix) {
let tipper = msg.author.id.replace('!', ''),
- words = msg.content
- .trim()
- .split(' ')
- .filter(function (n) {
- return n !== '';
- }),
+ words = msg.content.match(/\S+/g) || [],
subcommand = words.length >= 2 ? words[1] : 'help',
helpmsg =
'__**Dogecoin (DOGE) Tipper**__\nTransaction Fees: **' +
diff --git a/bot/modules/exampleTipper.js b/bot/modules/exampleTipper.js
index 25be559..3f298e0 100644
--- a/bot/modules/exampleTipper.js
+++ b/bot/modules/exampleTipper.js
@@ -29,11 +29,7 @@ exports.tipltc = {
process: async function(bot, msg, suffix) {
let tipper = msg.author.id.replace('!', ''),
words = msg.content
- .trim()
- .split(' ')
- .filter(function(n) {
- return n !== '';
- }),
+ .match(/\S+/g) || [],
subcommand = words.length >= 2 ? words[1] : 'help',
helpmsg =
'__**Litecoin (LTC) Tipper**__\nTransaction Fees: **' + paytxfee + '**\n **!tipltc** : Displays This Message\n **!tipltc balance** : get your balance\n **!tipltc deposit** : get address for your deposits\n **!tipltc withdraw
** : withdraw coins to specified address\n **!tipltc <@user> ** :mention a user with @ and then the amount to tip them\n **!tipltc private ** : put private before Mentioning a user to tip them privately.\n\n **<> : Replace with appropriate value.**',
diff --git a/bot/modules/ftcTipper.js b/bot/modules/ftcTipper.js
index 22bb0b9..bd50846 100644
--- a/bot/modules/ftcTipper.js
+++ b/bot/modules/ftcTipper.js
@@ -19,12 +19,7 @@ exports.tipftc = {
paytxfee,
process: async function (bot, msg, suffix) {
let tipper = msg.author.id.replace('!', ''),
- words = msg.content
- .trim()
- .split(' ')
- .filter(function (n) {
- return n !== '';
- }),
+ words = msg.content.match(/\S+/g) || [],
subcommand = words.length >= 2 ? words[1] : 'help',
helpmsg =
'__**Feathercoin (FTC) Tipper**__\nTransaction Fees: **' +
diff --git a/bot/modules/helpTipper.js b/bot/modules/helpTipper.js
index 95041c9..f87ef49 100644
--- a/bot/modules/helpTipper.js
+++ b/bot/modules/helpTipper.js
@@ -11,27 +11,41 @@ exports.commands = ['tiphelp'];
exports.tiphelp = {
usage: '',
description: 'This commands has been changed to currency specific commands!',
- process: function(bot, message) {
+ process: function (bot, message) {
message.author.send(
- '__**Ravencoin (RVN) Tipper**__\nTransaction Fees: **' + ravenFee + '**\n **!tiprvn balance** : get your balance\n **!tiprvn deposit** : get address for your deposits\n **!tiprvn withdraw ** : withdraw coins to specified address\n **!tiprvn <@user> ** :mention a user with @ and then the amount to tip them\n **!tiprvn private ** : put private before Mentioning a user to tip them privately.\n'
+ '__**Ravencoin (RVN) Tipper**__\nTransaction Fees: **' +
+ ravenFee +
+ '**\n **!tiprvn balance** : get your balance\n **!tiprvn deposit** : get address for your deposits\n **!tiprvn withdraw ** : withdraw coins to specified address\n **!tiprvn <@user> ** :mention a user with @ and then the amount to tip them\n **!tiprvn private ** : put private before Mentioning a user to tip them privately.\n',
);
message.author.send(
- '__**Dogecoin (DOGE) Tipper**__\nTransaction Fees: **' + dogeFee + '**\n **!tipdoge balance** : get your balance\n **!tipdoge deposit** : get address for your deposits\n **!tipdoge withdraw ** : withdraw coins to specified address\n **!tipdoge <@user> ** :mention a user with @ and then the amount to tip them\n **!tipdoge private ** : put private before Mentioning a user to tip them privately.\n'
+ '__**Dogecoin (DOGE) Tipper**__\nTransaction Fees: **' +
+ dogeFee +
+ '**\n **!tipdoge balance** : get your balance\n **!tipdoge deposit** : get address for your deposits\n **!tipdoge withdraw ** : withdraw coins to specified address\n **!tipdoge <@user> ** :mention a user with @ and then the amount to tip them\n **!tipdoge private ** : put private before Mentioning a user to tip them privately.\n',
);
message.author.send(
- '__**LBRY Credit (LBC) Tipper**__\nTransaction Fees: **' + lbryFee + '**\n **!tiplbc balance** : get your balance\n **!tiplbc deposit** : get address for your deposits\n **!tiplbc withdraw ** : withdraw coins to specified address\n **!tiplbc <@user> ** :mention a user with @ and then the amount to tip them\n **!tiplbc private ** : put private before Mentioning a user to tip them privately.\n'
+ '__**LBRY Credit (LBC) Tipper**__\nTransaction Fees: **' +
+ lbryFee +
+ '**\n **!tiplbc balance** : get your balance\n **!tiplbc deposit** : get address for your deposits\n **!tiplbc withdraw ** : withdraw coins to specified address\n **!tiplbc <@user> ** :mention a user with @ and then the amount to tip them\n **!tiplbc private ** : put private before Mentioning a user to tip them privately.\n',
);
message.author.send(
- '__**Proton (PROTON) Tipper**__\nTransaction Fees: **' + protonFee + '**\n **!tipproton balance** : get your balance\n **!tipproton deposit** : get address for your deposits\n **!tipproton withdraw ** : withdraw coins to specified address\n **!tipproton <@user> ** :mention a user with @ and then the amount to tip them\n **!tipproton private ** : put private before Mentioning a user to tip them privately.\n'
+ '__**Proton (PROTON) Tipper**__\nTransaction Fees: **' +
+ protonFee +
+ '**\n **!tipproton balance** : get your balance\n **!tipproton deposit** : get address for your deposits\n **!tipproton withdraw ** : withdraw coins to specified address\n **!tipproton <@user> ** :mention a user with @ and then the amount to tip them\n **!tipproton private ** : put private before Mentioning a user to tip them privately.\n',
);
message.author.send(
- '__**Uniform Fiscal Object (UFO) Tipper**__\nTransaction Fees: **' + ufoFee + '**\n **!tipufo balance** : get your balance\n **!tipufo deposit** : get address for your deposits\n **!tipufo withdraw ** : withdraw coins to specified address\n **!tipufo <@user> ** :mention a user with @ and then the amount to tip them\n **!tipufo private ** : put private before Mentioning a user to tip them privately.\n'
+ '__**Uniform Fiscal Object (UFO) Tipper**__\nTransaction Fees: **' +
+ ufoFee +
+ '**\n **!tipufo balance** : get your balance\n **!tipufo deposit** : get address for your deposits\n **!tipufo withdraw ** : withdraw coins to specified address\n **!tipufo <@user> ** :mention a user with @ and then the amount to tip them\n **!tipufo private ** : put private before Mentioning a user to tip them privately.\n',
);
message.author.send(
- '__**Phoenixcoin (PXC) Tipper**__\nTransaction Fees: **' + phoenixFee + '**\n **!tippxc balance** : get your balance\n **!tippxc deposit** : get address for your deposits\n **!tippxc withdraw ** : withdraw coins to specified address\n **!tippxc <@user> ** :mention a user with @ and then the amount to tip them\n **!tippxc private ** : put private before Mentioning a user to tip them privately.\n'
+ '__**Phoenixcoin (PXC) Tipper**__\nTransaction Fees: **' +
+ phoenixFee +
+ '**\n **!tippxc balance** : get your balance\n **!tippxc deposit** : get address for your deposits\n **!tippxc withdraw ** : withdraw coins to specified address\n **!tippxc <@user> ** :mention a user with @ and then the amount to tip them\n **!tippxc private ** : put private before Mentioning a user to tip them privately.\n',
);
message.author.send(
- '__**Feathercoin (FTC) Tipper**__\nTransaction Fees: **' + featherFee + '**\n **!tipftc balance** : get your balance\n **!tipftc deposit** : get address for your deposits\n **!tipufo withdraw ** : withdraw coins to specified address\n **!tipftc <@user> ** :mention a user with @ and then the amount to tip them\n **!tipftc private ** : put private before Mentioning a user to tip them privately.\n\n **<> : Replace with appropriate value.**'
+ '__**Feathercoin (FTC) Tipper**__\nTransaction Fees: **' +
+ featherFee +
+ '**\n **!tipftc balance** : get your balance\n **!tipftc deposit** : get address for your deposits\n **!tipufo withdraw ** : withdraw coins to specified address\n **!tipftc <@user> ** :mention a user with @ and then the amount to tip them\n **!tipftc private ** : put private before Mentioning a user to tip them privately.\n\n **<> : Replace with appropriate value.**',
);
- }
+ },
};
diff --git a/bot/modules/lbcTipper.js b/bot/modules/lbcTipper.js
index 09ff576..b1d0e20 100644
--- a/bot/modules/lbcTipper.js
+++ b/bot/modules/lbcTipper.js
@@ -19,12 +19,7 @@ exports.tiplbc = {
paytxfee,
process: async function (bot, msg, suffix) {
let tipper = msg.author.id.replace('!', ''),
- words = msg.content
- .trim()
- .split(' ')
- .filter(function (n) {
- return n !== '';
- }),
+ words = msg.content.match(/\S+/g) || [],
subcommand = words.length >= 2 ? words[1] : 'help',
helpmsg =
'__**LBRY Credit (LBC) Tipper**__\nTransaction Fees: **' +
diff --git a/bot/modules/protonTipper.js b/bot/modules/protonTipper.js
index 53da2cd..5b24b10 100644
--- a/bot/modules/protonTipper.js
+++ b/bot/modules/protonTipper.js
@@ -19,12 +19,7 @@ exports.tipproton = {
paytxfee,
process: async function (bot, msg, suffix) {
let tipper = msg.author.id.replace('!', ''),
- words = msg.content
- .trim()
- .split(' ')
- .filter(function (n) {
- return n !== '';
- }),
+ words = msg.content.match(/\S+/g) || [],
subcommand = words.length >= 2 ? words[1] : 'help',
helpmsg =
'__**Proton (PROTON) Tipper**__\nTransaction Fees: **' +
diff --git a/bot/modules/pxcTipper.js b/bot/modules/pxcTipper.js
index db95dc4..150421f 100644
--- a/bot/modules/pxcTipper.js
+++ b/bot/modules/pxcTipper.js
@@ -19,12 +19,7 @@ exports.tippxc = {
paytxfee,
process: async function (bot, msg, suffix) {
let tipper = msg.author.id.replace('!', ''),
- words = msg.content
- .trim()
- .split(' ')
- .filter(function (n) {
- return n !== '';
- }),
+ words = msg.content.match(/\S+/g) || [],
subcommand = words.length >= 2 ? words[1] : 'help',
helpmsg =
'__**Phoenixcoin (PXC) Tipper**__\nTransaction Fees: **' +
diff --git a/bot/modules/rvnTipper.js b/bot/modules/rvnTipper.js
index 814abc4..d3ead43 100644
--- a/bot/modules/rvnTipper.js
+++ b/bot/modules/rvnTipper.js
@@ -19,12 +19,7 @@ exports.tiprvn = {
paytxfee,
process: async function (bot, msg, suffix) {
let tipper = msg.author.id.replace('!', ''),
- words = msg.content
- .trim()
- .split(' ')
- .filter(function (n) {
- return n !== '';
- }),
+ words = msg.content.match(/\S+/g) || [],
subcommand = words.length >= 2 ? words[1] : 'help',
helpmsg =
'__**Ravencoin (RVN) Tipper**__\nTransaction Fees: **' +
diff --git a/bot/modules/ufoTipper.js b/bot/modules/ufoTipper.js
index 74c1cd5..6ccc19b 100644
--- a/bot/modules/ufoTipper.js
+++ b/bot/modules/ufoTipper.js
@@ -19,12 +19,7 @@ exports.tipufo = {
paytxfee,
process: async function (bot, msg, suffix) {
let tipper = msg.author.id.replace('!', ''),
- words = msg.content
- .trim()
- .split(' ')
- .filter(function (n) {
- return n !== '';
- }),
+ words = msg.content.match(/\S+/g) || [],
subcommand = words.length >= 2 ? words[1] : 'help',
helpmsg =
'__**Uniform Fiscal Object (UFO) Tipper**__\nTransaction Fees: **' +
diff --git a/bot/modules/vtlTipper.js b/bot/modules/vtlTipper.js
index 040a3fa..5beb294 100644
--- a/bot/modules/vtlTipper.js
+++ b/bot/modules/vtlTipper.js
@@ -19,12 +19,7 @@ exports.tipvtl = {
paytxfee,
process: async function (bot, msg, suffix) {
let tipper = msg.author.id.replace('!', ''),
- words = msg.content
- .trim()
- .split(' ')
- .filter(function (n) {
- return n !== '';
- }),
+ words = msg.content.match(/\S+/g) || [],
subcommand = words.length >= 2 ? words[1] : 'help',
helpmsg =
'__**Vertical (VTL) Tipper**__\nTransaction Fees: **' +
diff --git a/bot/plugins.js b/bot/plugins.js
index a314cd1..30bbf5d 100644
--- a/bot/plugins.js
+++ b/bot/plugins.js
@@ -44,6 +44,6 @@ function load_plugins() {
}
}
console.log(
- `Loaded ${dbot.commandCount()} chat commands and ${otherFunc} custom functions.`
+ `Loaded ${dbot.commandCount()} chat commands and ${otherFunc} custom functions.`,
);
}