routie dev init since i didn't adhere to any proper guidance up until now
This commit is contained in:
+36
@@ -0,0 +1,36 @@
|
||||
import { Settings } from './get-settings.js'
|
||||
/**
|
||||
* Merges configuration options with settings and defaults in priority order.
|
||||
*
|
||||
* Combines three levels of configuration with increasing priority:
|
||||
*
|
||||
* 1. Default values (lowest priority)
|
||||
* 2. Global settings from ESLint configuration.
|
||||
* 3. Rule-specific options (highest priority).
|
||||
*
|
||||
* This ensures that user-provided options always override settings, and
|
||||
* settings always override defaults.
|
||||
*
|
||||
* @example
|
||||
*
|
||||
* ```ts
|
||||
* const finalOptions = complete(
|
||||
* { type: 'natural' }, // User options (highest priority)
|
||||
* { order: 'asc' }, // Global settings
|
||||
* { type: 'alphabetical', order: 'desc' }, // Defaults (lowest priority)
|
||||
* )
|
||||
* // Returns: { type: 'natural', order: 'asc' }
|
||||
* ```
|
||||
*
|
||||
* @template T - Type of the configuration object.
|
||||
* @param options - Rule-specific options provided by the user (highest
|
||||
* priority).
|
||||
* @param settings - Global settings from ESLint configuration.
|
||||
* @param defaults - Default values for the configuration (lowest priority).
|
||||
* @returns Merged configuration object with all three levels combined.
|
||||
*/
|
||||
export declare function complete<T extends Record<string, unknown>>(
|
||||
options?: Partial<T>,
|
||||
settings?: Settings,
|
||||
defaults?: T,
|
||||
): T
|
||||
Reference in New Issue
Block a user