Skip to content

Commit

Permalink
Fill pwsh commands via Get-Command
Browse files Browse the repository at this point in the history
Fixes #235024
  • Loading branch information
Tyriar committed Dec 17, 2024
1 parent c269884 commit f776d06
Showing 1 changed file with 21 additions and 17 deletions.
38 changes: 21 additions & 17 deletions extensions/terminal-suggest/src/terminalSuggestMain.ts
Original file line number Diff line number Diff line change
Expand Up @@ -25,40 +25,44 @@ function getBuiltinCommands(shell: string): string[] | undefined {
}
const filter = (cmd: string) => cmd;
const options: ExecOptionsWithStringEncoding = { encoding: 'utf-8', shell };
let commands: string[] | undefined;
switch (shellType) {
case 'bash': {
const bashOutput = execSync('compgen -b', options);
const bashResult = bashOutput.split('\n').filter(filter);
if (bashResult.length) {
cachedBuiltinCommands?.set(shellType, bashResult);
return bashResult;
}
commands = bashOutput.split('\n').filter(filter);
break;
}
case 'zsh': {
const zshOutput = execSync('printf "%s\\n" ${(k)builtins}', options);
const zshResult = zshOutput.split('\n').filter(filter);
if (zshResult.length) {
cachedBuiltinCommands?.set(shellType, zshResult);
return zshResult;
}
commands = zshOutput.split('\n').filter(filter);
break;
}
case 'fish': {
// TODO: ghost text in the command line prevents
// completions from working ATM for fish
const fishOutput = execSync('functions -n', options);
const fishResult = fishOutput.split(', ').filter(filter);
if (fishResult.length) {
cachedBuiltinCommands?.set(shellType, fishResult);
return fishResult;
}
commands = fishOutput.split(', ').filter(filter);
break;
}
case 'pwsh': {
// native pwsh completions are builtin to vscode
return [];
const output = execSync('Get-Command | Select-Object Name, CommandType, DisplayName | ConvertTo-Json', options);
let json: any;
try {
json = JSON.parse(output);
} catch (e) {
console.error('Error parsing pwsh output:', e);
return [];
}
// TODO: Return a rich type with kind and detail
commands = (json as any[]).map(e => e.Name);
break;
}
}
// TODO: Cache failure results too
if (commands?.length) {
cachedBuiltinCommands?.set(shellType, commands);
return commands;
}
return;

} catch (error) {
Expand Down

0 comments on commit f776d06

Please sign in to comment.