Skip to content

Commit

Permalink
Support Skip Loading Compile Commands for Higher Performace Experience
Browse files Browse the repository at this point in the history
  • Loading branch information
FANG.Ge committed Jun 25, 2022
1 parent 3ca837b commit fe753a1
Show file tree
Hide file tree
Showing 5 changed files with 17 additions and 3 deletions.
6 changes: 6 additions & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -1950,6 +1950,12 @@
"default": false,
"description": "%cmake-tools.configuration.cmake.ignoreCMakeListsMissing.description%",
"scope": "resource"
},
"cmake.skipLoadingCompileCommands": {
"type": "boolean",
"default": false,
"description": "%cmake-tools.configuration.cmake.skipLoadingCompileCommands.description%",
"scope": "resource"
}
}
},
Expand Down
3 changes: 2 additions & 1 deletion package.nls.json
Original file line number Diff line number Diff line change
Expand Up @@ -146,5 +146,6 @@
"cmake-tools.configuration.cmake.launchBehavior.description": "Controls what happens with the launch terminal when you launch a target.",
"cmake-tools.configuration.cmake.launchBehavior.reuseTerminal.description": "The launch terminal instance is reused and the target will launch as soon as the terminal is idle.",
"cmake-tools.configuration.cmake.launchBehavior.breakAndReuseTerminal.description": "The launch terminal instance is reused and a break command is sent to terminate any active foreground process before launching the target.",
"cmake-tools.configuration.cmake.launchBehavior.newTerminal.description": "A new terminal instance is created and the target is launched in it. Existing terminals are not automatically cleaned up."
"cmake-tools.configuration.cmake.launchBehavior.newTerminal.description": "A new terminal instance is created and the target is launched in it. Existing terminals are not automatically cleaned up.",
"cmake-tools.configuration.cmake.omitLoadCompileCommand.description" : "Omit loading compile_commands.json, sacrifice some features for a higher performance experience."
}
5 changes: 3 additions & 2 deletions src/cmakeTools.ts
Original file line number Diff line number Diff line change
Expand Up @@ -1182,8 +1182,9 @@ export class CMakeTools implements api.CMakeToolsAPI {
log.debug(localize('cannot.copy.compile.commands', 'Cannot copy {1} because it does not exist at {0}', compdbPath, 'compile_commands.json'));
}
}

if (compdbPaths.length > 0) {
if (this.workspaceContext.config.skipLoadingCompileCommands) {
this.compilationDatabase = null;
} else if (compdbPaths.length > 0) {
// Read the compilation database, and update our db property
const newDB = await CompilationDatabase.fromFilePaths(compdbPaths);
this.compilationDatabase = newDB;
Expand Down
5 changes: 5 additions & 0 deletions src/config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -123,6 +123,7 @@ export interface ExtensionConfigurationSettings {
emscriptenSearchDirs: string[];
mergedCompileCommands: string | null;
copyCompileCommands: string | null;
skipLoadingCompileCommands: boolean;
configureOnOpen: boolean | null;
configureOnEdit: boolean;
skipConfigureIfCachePresent: boolean | null;
Expand Down Expand Up @@ -400,6 +401,9 @@ export class ConfigurationReader implements vscode.Disposable {
get copyCompileCommands(): string | null {
return this.configData.copyCompileCommands;
}
get skipLoadingCompileCommands(): boolean {
return this.configData.skipLoadingCompileCommands;
}
get showSystemKits(): boolean {
return this.configData.showSystemKits;
}
Expand Down Expand Up @@ -469,6 +473,7 @@ export class ConfigurationReader implements vscode.Disposable {
emscriptenSearchDirs: new vscode.EventEmitter<string[]>(),
mergedCompileCommands: new vscode.EventEmitter<string | null>(),
copyCompileCommands: new vscode.EventEmitter<string | null>(),
skipLoadingCompileCommands: new vscode.EventEmitter<boolean>(),
configureOnOpen: new vscode.EventEmitter<boolean | null>(),
configureOnEdit: new vscode.EventEmitter<boolean>(),
skipConfigureIfCachePresent: new vscode.EventEmitter<boolean | null>(),
Expand Down
1 change: 1 addition & 0 deletions test/unit-tests/config.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -39,6 +39,7 @@ function createConfig(conf: Partial<ExtensionConfigurationSettings>): Configurat
emscriptenSearchDirs: [],
mergedCompileCommands: null,
copyCompileCommands: null,
skipLoadingCompileCommands: false,
configureOnOpen: null,
configureOnEdit: true,
skipConfigureIfCachePresent: null,
Expand Down

0 comments on commit fe753a1

Please sign in to comment.