perf(extension): parallelize async operations and cache checks
This commit is contained in:
1140
package-lock.json
generated
1140
package-lock.json
generated
File diff suppressed because it is too large
Load Diff
@@ -2,7 +2,7 @@
|
|||||||
"name": "ai-commit-ext",
|
"name": "ai-commit-ext",
|
||||||
"displayName": "AI Commit Ext",
|
"displayName": "AI Commit Ext",
|
||||||
"description": "Generate commit messages using OpenCode AI",
|
"description": "Generate commit messages using OpenCode AI",
|
||||||
"version": "1.0.0",
|
"version": "1.0.1",
|
||||||
"publisher": "local",
|
"publisher": "local",
|
||||||
"engines": {
|
"engines": {
|
||||||
"vscode": "^1.110.0"
|
"vscode": "^1.110.0"
|
||||||
|
|||||||
@@ -41,7 +41,11 @@ async function handleGenerateCommitMessage(): Promise<void> {
|
|||||||
const showNotification = config.get<boolean>("showNotification", true);
|
const showNotification = config.get<boolean>("showNotification", true);
|
||||||
|
|
||||||
try {
|
try {
|
||||||
const opencodeAvailable = await isOpenCodeAvailable();
|
const [opencodeAvailable, gitExtension] = await Promise.all([
|
||||||
|
isOpenCodeAvailable(),
|
||||||
|
vscode.extensions.getExtension<GitExtension>("vscode.git"),
|
||||||
|
]);
|
||||||
|
|
||||||
if (!opencodeAvailable) {
|
if (!opencodeAvailable) {
|
||||||
if (showNotification) {
|
if (showNotification) {
|
||||||
vscode.window.showErrorMessage(
|
vscode.window.showErrorMessage(
|
||||||
@@ -51,8 +55,6 @@ async function handleGenerateCommitMessage(): Promise<void> {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
const gitExtension =
|
|
||||||
vscode.extensions.getExtension<GitExtension>("vscode.git");
|
|
||||||
if (!gitExtension) {
|
if (!gitExtension) {
|
||||||
if (showNotification) {
|
if (showNotification) {
|
||||||
vscode.window.showErrorMessage("Git extension not found");
|
vscode.window.showErrorMessage("Git extension not found");
|
||||||
|
|||||||
@@ -6,6 +6,8 @@ export interface GenerateOptions {
|
|||||||
model?: string;
|
model?: string;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
let opencodeAvailableCache: boolean | null = null;
|
||||||
|
|
||||||
const DEFAULT_PROMPT = `You are a helpful assistant that generates git commit messages.
|
const DEFAULT_PROMPT = `You are a helpful assistant that generates git commit messages.
|
||||||
Generate a concise Conventional Commit message (max 72 characters for the subject line).
|
Generate a concise Conventional Commit message (max 72 characters for the subject line).
|
||||||
Format: <type>(<scope>): <description>
|
Format: <type>(<scope>): <description>
|
||||||
@@ -15,9 +17,13 @@ Types: feat, fix, refactor, docs, style, test, chore, perf, ci, build, revert
|
|||||||
Only output the commit message, nothing else.`;
|
Only output the commit message, nothing else.`;
|
||||||
|
|
||||||
export async function isOpenCodeAvailable(): Promise<boolean> {
|
export async function isOpenCodeAvailable(): Promise<boolean> {
|
||||||
|
if (opencodeAvailableCache !== null) {
|
||||||
|
return opencodeAvailableCache;
|
||||||
|
}
|
||||||
return new Promise((resolve) => {
|
return new Promise((resolve) => {
|
||||||
exec("which opencode", (error: ExecException | null) => {
|
exec("which opencode", (error: ExecException | null) => {
|
||||||
resolve(!error);
|
opencodeAvailableCache = !error;
|
||||||
|
resolve(opencodeAvailableCache);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@@ -32,8 +38,10 @@ export async function generateCommitMessage(
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
const diff = await getGitDiff();
|
const [diff, repoRoot] = await Promise.all([
|
||||||
const repoRoot = await getRepositoryRoot();
|
getGitDiff(),
|
||||||
|
getRepositoryRoot(),
|
||||||
|
]);
|
||||||
|
|
||||||
const config = vscode.workspace.getConfiguration("aiCommitExt");
|
const config = vscode.workspace.getConfiguration("aiCommitExt");
|
||||||
const model = options.model || config.get<string>("model", "");
|
const model = options.model || config.get<string>("model", "");
|
||||||
|
|||||||
Reference in New Issue
Block a user