Fix processing of .editorConfig files with booleans.

This commit is contained in:
Sean McManus 2024-11-04 17:47:42 -08:00
Родитель fcd0b0c25f
Коммит 51f252541d
1 изменённых файлов: 9 добавлений и 3 удалений

Просмотреть файл

@ -92,12 +92,18 @@ function parseEditorConfigContent(content: string): Record<string, any> {
const [key, ...values] = line.split('=');
if (key && values.length > 0) {
const trimmedKey = key.trim();
const value = values.join('=').trim();
let value: any = values.join('=').trim();
if (currentSection) {
// Ensure the current section is initialized.
if (!config[currentSection]) {
config[currentSection] = {};
}
// Convert 'true' and 'false' to boolean.
if (value === 'true') {
value = true;
} else if (value === 'false') {
value = false;
}
config[currentSection][trimmedKey] = value;
}
}
@ -114,7 +120,7 @@ function getEditorConfig(filePath: string): any {
const rootDir: string = path.parse(currentDir).root;
// Traverse from the file's directory to the root directory.
for (;;) {
for (; ;) {
const editorConfigPath: string = path.join(currentDir, '.editorconfig');
if (fs.existsSync(editorConfigPath)) {
const configFileContent: string = fs.readFileSync(editorConfigPath, 'utf-8');
@ -139,7 +145,7 @@ function getEditorConfig(filePath: string): any {
});
// Check if the current .editorconfig is the root.
if (configData['*']?.root?.toLowerCase() === 'true') {
if (configData['*']?.root === true) {
break; // Stop searching after processing the root = true file.
}
}