make log prefix consistent

This commit is contained in:
Angelos Bouklis
2023-11-27 23:31:05 +02:00
parent 09450fb8c7
commit eaaf170cc8

View File

@ -6,7 +6,9 @@ import type {
import type {
PluginDef,
PluginConfig, PluginLifecycleExtra, PluginLifecycleSimple,
PluginConfig,
PluginLifecycleExtra,
PluginLifecycleSimple,
} from '@/types/plugins';
export const createPlugin = <
@ -32,38 +34,58 @@ type Options<Config extends PluginConfig> =
| { ctx: 'preload'; context: PreloadContext<Config> }
| { ctx: 'renderer'; context: RendererContext<Config> };
export const startPlugin = <Config extends PluginConfig>(id: string, def: PluginDef<unknown, unknown, unknown, Config>, options: Options<Config>) => {
export const startPlugin = <Config extends PluginConfig>(
id: string,
def: PluginDef<unknown, unknown, unknown, Config>,
options: Options<Config>,
) => {
const lifecycle =
typeof def[options.ctx] === 'function'
? def[options.ctx] as PluginLifecycleSimple<Config, unknown>
: (def[options.ctx] as PluginLifecycleExtra<Config, typeof options.context, unknown>)?.start;
? (def[options.ctx] as PluginLifecycleSimple<Config, unknown>)
: (
def[options.ctx] as PluginLifecycleExtra<
Config,
typeof options.context,
unknown
>
)?.start;
if (!lifecycle) return null;
try {
const defContext = def[options.ctx];
if (defContext && typeof defContext !== 'function') {
Object.entries(defContext)
.forEach(([key, value]) => {
// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment,@typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access
if (typeof value === 'function') defContext[key as keyof typeof defContext] = value.bind(defContext);
});
Object.entries(defContext).forEach(([key, value]) => {
// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment,@typescript-eslint/no-unsafe-call,@typescript-eslint/no-unsafe-member-access
if (typeof value === 'function')
defContext[key as keyof typeof defContext] = value.bind(defContext);
});
}
const start = performance.now();
lifecycle.bind(def[options.ctx])(options.context as Config & typeof options.context);
lifecycle.bind(def[options.ctx])(
options.context as Config & typeof options.context,
);
console.log(`[YTM] Executed ${id}::${options.ctx} in ${performance.now() - start} ms`);
console.log(
`[YTMusic] Executed ${id}::${options.ctx} in ${
performance.now() - start
} ms`,
);
return true;
} catch (err) {
console.error(`[YTM] Failed to start ${id}::${options.ctx}`);
console.error(`[YTMusic] Failed to start ${id}::${options.ctx}`);
console.trace(err);
return false;
}
};
export const stopPlugin = <Config extends PluginConfig>(id: string, def: PluginDef<unknown, unknown, unknown, Config>, options: Options<Config>) => {
export const stopPlugin = <Config extends PluginConfig>(
id: string,
def: PluginDef<unknown, unknown, unknown, Config>,
options: Options<Config>,
) => {
if (!def || !def[options.ctx]) return false;
if (typeof def[options.ctx] === 'function') return false;
@ -72,15 +94,19 @@ export const stopPlugin = <Config extends PluginConfig>(id: string, def: PluginD
try {
const start = performance.now();
stop.bind(def[options.ctx])(options.context as Config & typeof options.context);
stop.bind(def[options.ctx])(
options.context as Config & typeof options.context,
);
console.log(`[YTM] Executed ${id}::${options.ctx} in ${performance.now() - start} ms`);
console.log(
`[YTMusic] Executed ${id}::${options.ctx} in ${
performance.now() - start
} ms`,
);
return true;
} catch (err) {
console.error(
`[YTM] Failed to execute ${id}::${options.ctx}`,
);
console.error(`[YTMusic] Failed to execute ${id}::${options.ctx}`);
console.trace(err);
return false;
}