mirror of
https://github.com/renovatebot/renovate.git
synced 2025-01-15 09:06:25 +00:00
982cefff2b
* refactor(config): strict null checks * chore: fix test
47 lines
1.5 KiB
TypeScript
47 lines
1.5 KiB
TypeScript
import { logger } from '../logger';
|
|
import { clone } from '../util/clone';
|
|
import * as options from './options';
|
|
import type { RenovateConfig } from './types';
|
|
|
|
export function mergeChildConfig<
|
|
T extends Record<string, any>,
|
|
TChild extends Record<string, any> | undefined
|
|
>(parent: T, child: TChild): T & TChild {
|
|
logger.trace({ parent, child }, `mergeChildConfig`);
|
|
if (!child) {
|
|
return parent as never;
|
|
}
|
|
const parentConfig = clone(parent);
|
|
// eslint-disable-next-line @typescript-eslint/no-unnecessary-type-assertion
|
|
const childConfig = clone(child!);
|
|
const config: Record<string, any> = { ...parentConfig, ...childConfig };
|
|
for (const option of options.getOptions()) {
|
|
if (
|
|
option.mergeable &&
|
|
childConfig[option.name] &&
|
|
parentConfig[option.name]
|
|
) {
|
|
logger.trace(`mergeable option: ${option.name}`);
|
|
if (option.name === 'constraints') {
|
|
config[option.name] = {
|
|
...parentConfig[option.name],
|
|
...childConfig[option.name],
|
|
};
|
|
} else if (option.type === 'array') {
|
|
config[option.name] = (parentConfig[option.name] as unknown[]).concat(
|
|
config[option.name]
|
|
);
|
|
} else {
|
|
config[option.name] = mergeChildConfig(
|
|
parentConfig[option.name] as RenovateConfig,
|
|
childConfig[option.name] as RenovateConfig
|
|
);
|
|
}
|
|
logger.trace(
|
|
{ result: config[option.name] },
|
|
`Merged config.${option.name}`
|
|
);
|
|
}
|
|
}
|
|
return { ...config, ...config.force };
|
|
}
|