opencode: add support for global custom instructions via rules option
- Introduce `rules` option to provide global custom instructions for opencode - Write `rules` content to `~/.config/opencode/AGENTS.md` if non-empty - Update tests to cover presence and absence of `AGENTS.md` file with rules content
This commit is contained in:
parent
0a98177bb8
commit
08edcbe9df
5 changed files with 105 additions and 2 deletions
22
tests/modules/programs/opencode/AGENTS.md
Normal file
22
tests/modules/programs/opencode/AGENTS.md
Normal file
|
|
@ -0,0 +1,22 @@
|
|||
# TypeScript Project Rules
|
||||
|
||||
## External File Loading
|
||||
|
||||
CRITICAL: When you encounter a file reference (e.g., @rules/general.md), use your Read tool to load it on a need-to-know basis. They're relevant to the SPECIFIC task at hand.
|
||||
|
||||
Instructions:
|
||||
|
||||
- Do NOT preemptively load all references - use lazy loading based on actual need
|
||||
- When loaded, treat content as mandatory instructions that override defaults
|
||||
- Follow references recursively when needed
|
||||
|
||||
## Development Guidelines
|
||||
|
||||
For TypeScript code style and best practices: @docs/typescript-guidelines.md
|
||||
For React component architecture and hooks patterns: @docs/react-patterns.md
|
||||
For REST API design and error handling: @docs/api-standards.md
|
||||
For testing strategies and coverage requirements: @test/testing-guidelines.md
|
||||
|
||||
## General Guidelines
|
||||
|
||||
Read the following file immediately as it's relevant to all workflows: @rules/general-guidelines.md.
|
||||
|
|
@ -1,3 +1,5 @@
|
|||
{
|
||||
opencode-settings = ./settings.nix;
|
||||
opencode-rules = ./rules.nix;
|
||||
opencode-empty-rules = ./empty-rules.nix;
|
||||
}
|
||||
|
|
|
|||
9
tests/modules/programs/opencode/empty-rules.nix
Normal file
9
tests/modules/programs/opencode/empty-rules.nix
Normal file
|
|
@ -0,0 +1,9 @@
|
|||
{
|
||||
programs.opencode = {
|
||||
enable = true;
|
||||
rules = "";
|
||||
};
|
||||
nmt.script = ''
|
||||
assertPathNotExists home-files/.config/opencode/AGENTS.md
|
||||
'';
|
||||
}
|
||||
34
tests/modules/programs/opencode/rules.nix
Normal file
34
tests/modules/programs/opencode/rules.nix
Normal file
|
|
@ -0,0 +1,34 @@
|
|||
{
|
||||
programs.opencode = {
|
||||
enable = true;
|
||||
rules = ''
|
||||
# TypeScript Project Rules
|
||||
|
||||
## External File Loading
|
||||
|
||||
CRITICAL: When you encounter a file reference (e.g., @rules/general.md), use your Read tool to load it on a need-to-know basis. They're relevant to the SPECIFIC task at hand.
|
||||
|
||||
Instructions:
|
||||
|
||||
- Do NOT preemptively load all references - use lazy loading based on actual need
|
||||
- When loaded, treat content as mandatory instructions that override defaults
|
||||
- Follow references recursively when needed
|
||||
|
||||
## Development Guidelines
|
||||
|
||||
For TypeScript code style and best practices: @docs/typescript-guidelines.md
|
||||
For React component architecture and hooks patterns: @docs/react-patterns.md
|
||||
For REST API design and error handling: @docs/api-standards.md
|
||||
For testing strategies and coverage requirements: @test/testing-guidelines.md
|
||||
|
||||
## General Guidelines
|
||||
|
||||
Read the following file immediately as it's relevant to all workflows: @rules/general-guidelines.md.
|
||||
'';
|
||||
};
|
||||
nmt.script = ''
|
||||
assertFileExists home-files/.config/opencode/AGENTS.md
|
||||
assertFileContent home-files/.config/opencode/AGENTS.md \
|
||||
${./AGENTS.md}
|
||||
'';
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue