Schedule automatic AI prompts with cron expressions in VS Code.
📥 Install from VS Code Marketplace
🗓️ Cron Scheduling - Schedule prompts to run at specific times using cron expressions
🤖 Agent & Model Selection - Choose from built-in agents (@workspace, @terminal) and AI models (GPT-4o, Claude Sonnet 4), including runtime quality or experimental quality variants when available
🌐 Multi-language Support - English and Japanese UI with auto-detection
📊 Sidebar TreeView - Manage all your scheduled tasks from the sidebar
🖥️ Webview GUI - Easy-to-use graphical interface for creating and editing tasks
| Expression | Description |
|---|---|
0 9 * * 1-5 |
Weekdays at 9:00 AM |
0 18 * * 1-5 |
Weekdays at 6:00 PM |
0 9 * * * |
Every day at 9:00 AM |
0 9 * * 1 |
Every Monday at 9:00 AM |
*/30 * * * * |
Every 30 minutes |
0 * * * * |
Every hour |
| Command | Description |
|---|---|
Copilot Scheduler: Create Scheduled Prompt |
Create a new task (CLI) |
Copilot Scheduler: Create Scheduled Prompt (GUI) |
Create a new task (GUI) |
Copilot Scheduler: List Scheduled Tasks |
View all tasks |
Copilot Scheduler: Edit Task |
Edit an existing task |
Copilot Scheduler: Delete Task |
Delete a task |
Copilot Scheduler: Toggle Task (Enable/Disable) |
Enable/disable a task |
Copilot Scheduler: Enable Task |
Enable a task |
Copilot Scheduler: Disable Task |
Disable a task |
Copilot Scheduler: Run Now |
Execute a task immediately |
Copilot Scheduler: Copy Prompt to Clipboard |
Copy prompt to clipboard |
Copilot Scheduler: Duplicate Task |
Duplicate a task |
Copilot Scheduler: Move Task to Current Workspace |
Move a workspace task here |
Copilot Scheduler: Open Settings |
Open extension settings |
Copilot Scheduler: Show Version |
Show extension version |
Copilot Scheduler: Show Execution History |
View recent run history |
| Setting | Default | Description |
|---|---|---|
copilotScheduler.enabled |
true |
Enable/disable scheduled execution |
copilotScheduler.defaultScope |
workspace |
Default scope |
copilotScheduler.language |
auto |
UI language (auto/en/ja). Applies to extension Webview/Tree UI; settings-description updates may require window reload. |
copilotScheduler.timezone |
"" |
Timezone for scheduling |
copilotScheduler.jitterSeconds |
600 |
Max random delay (seconds) before execution (0–1800, 0 = off). Each task can override it. |
copilotScheduler.manualRunNextRunPolicy |
advance |
Next-run calculation after Run Now: advance (from existing next run) / fromNow (from current time) |
copilotScheduler.chatSession |
new |
Chat session (new/continue). continue is usually faster. |
copilotScheduler.autoModeDefault |
false |
Default value for new tasks' auto-mode hint (inserts an autonomous-execution instruction at the beginning of the runtime prompt). |
copilotScheduler.commandDelayFactor |
0.8 |
Delay multiplier for Copilot command sequencing (0.1–2.0). Lower is faster, but may be less stable in some environments. |
copilotScheduler.showNotifications |
true |
Show notifications when tasks are executed |
copilotScheduler.notificationMode |
sound |
Notification mode (sound/silentToast/silentStatus) |
copilotScheduler.maxDailyExecutions |
24 |
Daily execution limit across all tasks (0 = unlimited, 1–100). |
copilotScheduler.minimumIntervalWarning |
true |
Warn when cron interval is shorter than 30 minutes |
copilotScheduler.globalPromptsPath |
"" |
Custom global prompts folder path (default: VS Code's User/prompts folder — Windows: %APPDATA%/Code/User/prompts, macOS: ~/Library/Application Support/Code/User/prompts, Linux: $XDG_CONFIG_HOME/Code/User/prompts or ~/.config/Code/User/prompts) |
copilotScheduler.globalAgentsPath |
"" |
Custom global agents folder path (*.agent.md) (default: auto-detect VS Code's User/prompts folder and ~/.copilot/agents; setting this overrides the default discovery roots) |
copilotScheduler.logLevel |
info |
Log level (none/error/info/debug) |
copilotScheduler.executionHistoryLimit |
50 |
Max number of execution history entries kept for the history view (10–500) |
To automatically keep AI-applied edits after review delay, configure VS Code setting chat.editing.autoAcceptDelay (0 = off, 1-100 = seconds, recommended: 5).
Task-level controls (Max Runs/Day, Allowed Time Window) are configured per task in the Webview create/edit form.
The Webview previews Copilot Chat-like thinking effort options for supported model families. If it fails, choose Default.
If execution feels sluggish when a task is triggered, try:
copilotScheduler.chatSession = continuecopilotScheduler.commandDelayFactor = 0.6(or0.5)copilotScheduler.notificationMode = silentStatuscopilotScheduler.logLevel = error(ornone)
Use these placeholders in your prompts:
| Placeholder | Description |
|---|---|
{{date}} |
Current date |
{{time}} |
Current time |
{{datetime}} |
Current date and time |
{{workspace}} |
Workspace name |
{{file}} |
Current file name |
{{filepath}} |
Current file path |
- Global: Task runs in all workspaces
- Workspace: Task runs only in the specific workspace where it was created
Store prompt templates for reuse:
- Local:
.github/prompts/*.mdin your workspace - Global: VS Code user prompts folder (or the folder set in
copilotScheduler.globalPromptsPath) - If you edit prompt text while
Local/Globaltemplate source is selected (after template load completes), the task is automatically saved as Inline to keep execution consistent with the edited content.
Global custom agents are auto-discovered from the VS Code user prompts/customization folder and ~/.copilot/agents when copilotScheduler.globalAgentsPath is empty.
This follows current Copilot custom agent and Copilot CLI file locations, but this extension only discovers agent files. Prompt templates still use the VS Code user prompts folder or copilotScheduler.globalPromptsPath, not ~/.copilot/prompts, and the extension does not manage Copilot CLI sessions.
- VS Code 1.80.0 or higher
- GitHub Copilot extension
Maintainers can publish from GitHub Actions instead of running vsce publish locally.
- Push a tag in the form
vX.Y.Zafter updatingpackage.jsonto the same version. - GitHub Actions runs
npm ci,npm run compile,npm test, packages a.vsix, publishes to VS Code Marketplace, and attaches the.vsixto the GitHub release. - For ad-hoc publishing, use the
Publish Extensionworkflow from the Actions tab to publish the currentpackage.jsonversion manually. - Add the repository secret
VSCE_PATbefore using the workflow.
- Copilot Chat API is still evolving; some features may require updates as the API stabilizes
- Model selection may not work in all configurations
- Experimental model quality relies on evolving VS Code/Copilot internals and may not work in all configurations
Disclaimer: This extension automates Copilot Chat. GitHub's Acceptable Use Policies prohibit "excessive automated bulk activity", the Terms of Service § H (API Terms) allow account suspension for excessive API usage, and the GitHub Copilot Additional Product Terms apply these policies directly to Copilot. Use at your own risk; your account could be rate-limited or restricted. Configure jitter/daily limits/longer intervals to reduce risk, but there is no guarantee.
Note: There are reports of Copilot access being restricted even without using automation tools. These mitigations reduce obvious automation patterns but cannot eliminate that risk.
Initial release:
- Cron-based task scheduling
- Agent and model selection
- English/Japanese localization
- Sidebar TreeView
- Webview GUI for task management
- Prompt template support
Enjoy scheduling your Copilot prompts! 🚀
