Minor: Refactor the code-base for better organization and compartmentalization. (#934)
* Clean up unused code * Fix media player formatting issue for labels with new line characteres. * Refactor the media player handlers into a class. * More code cleanup and organize shared weather utils into distinct classes. * Flatten some nesting. * Move weather manager in dedicated class and build HTTP Utility class for Rest API calling. * Remove logs * Rebase master merge * Reorg code (WIP) * More reorg * Delete utility scripts * Reorg options * Finish moving all options over * Fix typescript issues * Update options imports to default * missed update * Screw barrel files honestly, work of the devil. * Only initialize power profiles if power-profiles-daemon is running. * Fix window positioning and weather service naming * style dir * More organization * Restructure types to be closer to their source * Remove lib types and constants * Update basic weather object to be saner with extensibility. * Service updates * Fix initialization strategy for services. * Fix Config Manager to only emit changed objects and added missing temp converters. * Update storage service to handle unit changes. * Added cpu temp sensor auto-discovery * Added missing JSDocs to services * remove unused * Migrate to network service. * Fix network password issue. * Move out password input into helper * Rename password mask constant to be less double-negativey. * Dropdown menu rename * Added a component to edit JSON in the settings dialog (rough/WIP) * Align settings * Add and style JSON Editor. * Adjust padding * perf(shortcuts): ⚡ avoid unnecessary polling when shortcuts are disabled Stops the recording poller when shortcuts are disabled, preventing redundant polling and reducing resource usage. * Fix types and return value if shortcut not enabled. * Move the swww daemon checking process outside of the wallpaper service into a dedicated deamon lifecyle processor. * Add more string formatters and use title case for weather status (as it was). * Fix startup errors. * Rgba fix * Remove zod from dependencies --------- Co-authored-by: KernelDiego <gonzalezdiego.contact@gmail.com>
This commit is contained in:
53
src/services/cli/commander/Registry.ts
Normal file
53
src/services/cli/commander/Registry.ts
Normal file
@@ -0,0 +1,53 @@
|
||||
import { Command } from './types';
|
||||
|
||||
/**
|
||||
* The CommandRegistry manages the storage and retrieval of commands.
|
||||
* It supports registration of multiple commands, lookup by name or alias,
|
||||
* and retrieval of all commands for listing and help functionalities.
|
||||
*/
|
||||
export class CommandRegistry {
|
||||
private _commands: Map<string, Command> = new Map();
|
||||
|
||||
/**
|
||||
* Registers a command. If a command with the same name or alias already exists,
|
||||
* it will throw an error.
|
||||
*
|
||||
* @param command - The command to register.
|
||||
* @throws If a command with the same name or alias already exists.
|
||||
*/
|
||||
public register(command: Command): void {
|
||||
if (this._commands.has(command.name)) {
|
||||
throw new Error(`Command "${command.name}" is already registered.`);
|
||||
}
|
||||
this._commands.set(command.name, command);
|
||||
|
||||
if (command.aliases) {
|
||||
for (const alias of command.aliases) {
|
||||
if (this._commands.has(alias)) {
|
||||
throw new Error(`Alias "${alias}" is already in use.`);
|
||||
}
|
||||
this._commands.set(alias, command);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Retrieves a command by its name or alias. Returns undefined if not found.
|
||||
*
|
||||
* @param commandName - The name or alias of the command to retrieve.
|
||||
* @returns The command if found, otherwise undefined.
|
||||
*/
|
||||
public get(commandName: string): Command | undefined {
|
||||
return this._commands.get(commandName);
|
||||
}
|
||||
|
||||
/**
|
||||
* Retrieves all registered commands, ensuring each command is returned once even if it has aliases.
|
||||
*
|
||||
* @returns An array of all registered commands.
|
||||
*/
|
||||
public getAll(): Command[] {
|
||||
const unique = new Set<Command>(this._commands.values());
|
||||
return Array.from(unique);
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user