Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

v1.4 refactor and rename #31

Merged
merged 36 commits into from
Jan 6, 2025
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
36 commits
Select commit Hold shift + click to select a range
bef173b
Add ESLint configuration and Prettier settings; update VSCode configu…
codybrom Jan 6, 2025
48b4fd3
Merge remote-tracking branch 'origin/main' into v4
codybrom Jan 6, 2025
a5c34bb
Fix formatting in README for clarity and consistency
codybrom Jan 6, 2025
c84f2d9
Update pretest script to use 'build' instead of 'compile'
codybrom Jan 6, 2025
b298eaa
Remove deprecated ESLint configuration file and update ignore pattern…
codybrom Jan 6, 2025
2752ef7
Add TypeScript SDK path to VSCode settings
codybrom Jan 6, 2025
15f6089
Update ESLint script to remove file extension specification
codybrom Jan 6, 2025
5981648
Refactor ignore module import and update variable declarations for co…
codybrom Jan 6, 2025
ad52af3
Remove unused test files and related test runner code
codybrom Jan 6, 2025
a9af97c
Migrate Prettier configuration from .prettierrc.json to package.json
codybrom Jan 6, 2025
54cf597
Remove Airbnb code style badge from README
codybrom Jan 6, 2025
acca191
Add custom spell check words to VSCode settings
codybrom Jan 6, 2025
888b2f1
Add utility functions for token estimation, import extraction, and fi…
codybrom Jan 6, 2025
764b621
Add command handler and context generator for GPT-friendly context cr…
codybrom Jan 6, 2025
0fdc582
Remove Prettier configuration path from VSCode settings
codybrom Jan 6, 2025
4153742
Refactor file utility functions and reorganize file structure
codybrom Jan 6, 2025
a3da8fc
Rename treeProvider to markedFilesProvider and update file path utili…
codybrom Jan 6, 2025
05c64f5
move importParser and markdownUtils into utils
codybrom Jan 6, 2025
518b108
Replace gpt-3-encoder with @dqbd/tiktoken, add highlight.js, and refa…
codybrom Jan 6, 2025
395a161
move commandHandler and contextGenerator files, and update import pat…
codybrom Jan 6, 2025
5f7bc7a
Refactor command handling: remove CommandHandler, implement clear and…
codybrom Jan 6, 2025
ce3ea97
Refactor context and marked files handling: streamline imports and en…
codybrom Jan 6, 2025
b4529ca
Refactor IgnoreManager: convert to instance-based implementation and …
codybrom Jan 6, 2025
ea8dc05
Refactor formatFileComment: simplify return value to include language…
codybrom Jan 6, 2025
60aada8
Add SVG icons for clear actions and enhance marked files functionality
codybrom Jan 6, 2025
6d5f8be
Refactor MarkedFilesProvider: streamline file watcher initialization …
codybrom Jan 6, 2025
b195ae7
Refactor markFile functionality: unify marking logic for files and di…
codybrom Jan 6, 2025
0bc41a4
Refactor markFile command: improve error handling, streamline file ma…
codybrom Jan 6, 2025
4a5ac4c
chore: update VSCode engine version to ^1.96.0
codybrom Jan 6, 2025
e08ff95
chore: optimize build process with esbuild
codybrom Jan 6, 2025
711a1e8
release: update version to 1.4.0 in package.json
codybrom Jan 6, 2025
4f2fa19
chore: remove unused prettier configuration from VSCode settings
codybrom Jan 6, 2025
8ecdc4d
Refactor: update project name and description to reflect LLM context …
codybrom Jan 6, 2025
dae36fa
feat: add token warning threshold configuration and update package.js…
codybrom Jan 6, 2025
a02893e
feat: add support for custom ignore files in context generation
codybrom Jan 6, 2025
4d143c1
docs: update README to add ignore files section
codybrom Jan 6, 2025
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
feat: add token warning threshold configuration and update package.js…
…on inclusion details in README
  • Loading branch information
codybrom committed Jan 6, 2025
commit dae36fa784fc11d8d3fd4cb2978363d518cfe35c
6 changes: 5 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -63,10 +63,14 @@ Configure the extension in VS Code settings:
- `plaintext`: Plain text (default)
- `markdown`: Markdown formatting

- **Include package.json**
- **Include package.json** (for open file context only)
- Include package.json when generating context for open file
- Default: `true`

- **Token Warning Threshold**
- Token count threshold for showing warnings
- Default: `8000`

- **Detected File Extensions**
- Customize which file types to include
- Supports many languages and formats:
Expand Down
5 changes: 5 additions & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -202,6 +202,11 @@
"type": "boolean",
"default": true,
"description": "Include package.json as part of the context (Open File Only)."
},
"gpt-context-generator.tokenWarningThreshold": {
"type": "number",
"default": 8000,
"description": "Token count threshold for showing warnings. Default is 8000 tokens."
}
}
},
Expand Down
17 changes: 6 additions & 11 deletions src/commands/createContext.ts
Original file line number Diff line number Diff line change
@@ -1,25 +1,20 @@
import { workspace } from 'vscode';
import { createContextGenerator } from '../generators/contextGenerator';
import { markedFiles } from '../providers/markedFilesProvider';
import { getActiveFilePath, validateWorkspace } from '../utils/vscodeUtils';
import {
getActiveFilePath,
getConfig,
validateWorkspace,
} from '../utils/vscodeUtils';

export const createContext = {
getConfig() {
const config = workspace.getConfiguration('gpt-context-generator');
return {
includePackageJson:
(config.get('includePackageJson') as boolean) ?? false,
};
},

async generateContext(
workspacePath: string,
options: { openFilePath?: string; markedFiles?: string[] },
) {
const contextGenerator = createContextGenerator(workspacePath);
await contextGenerator.handleContextGeneration({
...options,
includePackageJson: this.getConfig().includePackageJson,
includePackageJson: getConfig().includePackageJson,
});
},

Expand Down
20 changes: 4 additions & 16 deletions src/generators/contextGenerator.ts
Original file line number Diff line number Diff line change
Expand Up @@ -13,31 +13,19 @@ import { formatFileComment } from '../utils/markdownUtils';
import { estimateTokenCount } from '../utils/tokenUtils';
import { extractImports } from '../utils/importParser';
import { initializeIgnoreFilter, isIgnored } from '../utils/ignoreUtils';
import { showMessage } from '../utils/vscodeUtils';
import {
env,
ViewColumn,
window,
workspace,
WorkspaceConfiguration,
} from 'vscode';
import { getConfig, showMessage } from '../utils/vscodeUtils';
import { env, ViewColumn, window, workspace } from 'vscode';

export class ContextGenerator {
private config: WorkspaceConfiguration;
private detectedFileExtensions: string[];

constructor(private workspacePath: string) {
this.config = workspace.getConfiguration('gpt-context-generator');
this.detectedFileExtensions = this.config.get(
'detectedFileExtensions',
) as string[];
this.detectedFileExtensions = getConfig().detectedFileExtensions;
initializeIgnoreFilter(workspacePath);
}

async handleContextGeneration(options: ContextOptions): Promise<void> {
const outputMethod = this.config.get('outputMethod') as string;
const outputLanguage = this.config.get('outputLanguage') as string;

const { outputMethod, outputLanguage } = getConfig();
const gptContext = await this.generateContext(options);
await this.handleOutput(gptContext, outputMethod, outputLanguage);
this.showTokenCount(gptContext);
Expand Down
33 changes: 23 additions & 10 deletions src/utils/vscodeUtils.ts
Original file line number Diff line number Diff line change
@@ -1,13 +1,5 @@
import { window, workspace } from 'vscode';

export const validateWorkspace = (): string | null => {
if (!workspace.workspaceFolders) {
showMessage.error('Please open a workspace to use this extension.');
return null;
}
return workspace.workspaceFolders[0].uri.fsPath;
};

export const getActiveFilePath = (): string | null => {
if (!window.activeTextEditor) {
showMessage.error('Please open a file to use this feature.');
Expand All @@ -16,19 +8,40 @@ export const getActiveFilePath = (): string | null => {
return window.activeTextEditor.document.uri.fsPath;
};

export const getConfig = () => {
const config = workspace.getConfiguration('gpt-context-generator');
return {
tokenWarningThreshold:
(config.get('tokenWarningThreshold') as number) ?? 8000,
includePackageJson: (config.get('includePackageJson') as boolean) ?? false,
outputMethod: config.get('outputMethod') as string,
outputLanguage: config.get('outputLanguage') as string,
detectedFileExtensions: config.get('detectedFileExtensions') as string[],
};
};

export const showMessage = {
info: (message: string) => window.showInformationMessage(message),
error: (message: string) => window.showErrorMessage(message),
warning: (message: string) => window.showWarningMessage(message),
copySuccess: () => showMessage.info('LLM-ready context copied to clipboard.'),
tokenCount: (count: number) => {
const threshold = getConfig().tokenWarningThreshold;
const message = `The generated context is approximately ${count} tokens${
count > 8000 ? ', which is greater than 8000 tokens' : ''
count > threshold ? `, which is greater than ${threshold} tokens` : ''
}.`;
if (count > 8000) {
if (count > threshold) {
showMessage.warning(message);
} else {
showMessage.info(message);
}
},
};

export const validateWorkspace = (): string | null => {
if (!workspace.workspaceFolders) {
showMessage.error('Please open a workspace to use this extension.');
return null;
}
return workspace.workspaceFolders[0].uri.fsPath;
};
Loading