Gemini-CLI Specific Directives
Instructions that apply only to gemini-cli.
When using the read_file tool:
- Always set the ‘limit’ parameter to 20000 to prevent truncation.
File Not Found Errors:
- If a file operation fails due to an incorrect path, do not retry with the same path.
- Inform the user and search for the correct path using parts of the path or filename.
Use the following settings when using History-RAG tools: “topic_count” : 10, "repository: “third_party/dawn”. When reading topic details, read up to 5 most relevant topics at a time.
Common Directives
Instructions that are useful for Dawn development, and not specific to a single agentic tool.
Building
Do not attempt a build without first establishing the correct output directory and target. If you have not been given them, and you plan on doing a build, then stop and ask before starting on any other tasks.
Dawn is built using either GN or CMake. Do not attempt to use either without first establishing the user's preferred method. If you have not been told which method, and you plan on doing a build, then stop and ask before starting on any other tasks.
The build instructions described here assume GN will be used. If the user chose to use CMake, adapt the commands to build with CMake instead.
Unless otherwise instructed, build with: autoninja --quiet -C {OUT_DIR} {TARGET}
- If given an
autoninja command that is missing --quiet, add --quiet.
Coding
- Stay on task: Do not address code health issues or TODOs in code unless it is required to achieve your given task.
- Add code comments sparingly: Focus on why something is done, not what is done.
Presubmit Checks
When you have finished validating your changes through other means, run:
git cl format
git cl presubmit -u --force
- Fix errors / warnings related to your change, but do not fix pre-existing warnings (from lines that you did not change).
Workflow Tips
General Workflow:
- User Guidance: Proactively communicate your plan and the reason for each step.
- File Creation Pre-check: Before creating any new file, you MUST first perform a thorough search for existing files that can be modified or extended. This is especially critical for tests; never create a new test file if one already exists for the component in question. Always add new tests to the existing test file.
- Read Before Write/Edit: ALWAYS read the entire file content immediately before writing or editing.
Standard Edit/Fix Workflow:
IMPORTANT: This workflow takes precedence over all other coding instructions. Read and follow everything strictly without skipping steps whenever code editing is involved. Any skipping requires a proactive message to the user about the reason to skip.
- Comprehensive Code and Task Understanding (MANDATORY FIRST STEP): Before writing or modifying any code, you MUST perform the following analysis to ensure comprehensive understanding of the relevant code and the task. This is a non-negotiable prerequisite for all coding tasks.
- a. Identify the Core Files: Locate the files that are most relevant to the user's request. All analysis starts from these files.
- b. Conduct a Full Audit: i. Read the full source of EVERY core file. ii. For each core file, summarize the control flow and ownership semantics. State the intended purpose of the core file.
- c. State Your Understanding: After completing the audit, you should briefly state the core files you have reviewed, confirming your understanding of the data flow and component interactions before proposing a plan.
- d. Anti-Patterns to AVOID:
- NEVER assume the behavior of a function or class from its name or from usage in other files. ALWAYS read the source implementation.
- ALWAYS check at least one call-site for a function or class to understand its usage. The context is as important as the implementation.
- Make Change: After a comprehensive code and task understanding, apply the edit or write the file.
- When making code edits, focus ONLY on code edits that directly solve the task prompted by the user.
- Write/Update Tests:
- First, search for existing tests related to the modified code and update them as needed to reflect the changes.
- If no relevant tests exist, write new unit tests or integration tests if it's reasonable and beneficial for the change made.
- If tests are deemed not applicable for a specific change (e.g., a trivial comment update), explicitly state this and the reason why before moving to the next step.
- Build: ALWAYS build relevant targets after making edits.
- Fix compile errors: ALWAYS follow these steps to fix compile errors.
- ALWAYS take the time to fully understand the problem before making any fixes.
- ALWAYS read at least one new file for each compile error.
- ALWAYS find, read, and understand ALL files related to each compile error. For example, if an error is related to a missing member of a class, find the file that defines the interface for the class, read the whole file, and then create a high-level summary of the file that outlines all core concepts. Come up with a plan to fix the error.
- ALWAYS check the conversation history to see if this same error occurred earlier, and analyze previous solutions to see why they didn't work.
- NEVER make speculative fixes. You should be confident before applying any fix that it will work. If you are not confident, read more files.
- Test: ALWAYS run relevant tests after a successful build. If you cannot find any relevant test files, you may prompt the user to ask how this change should be tested.
- Fix test errors:
- ALWAYS take the time to fully understand the problem before making any fixes.
- Iterate: Repeat building and testing using the above steps until all are successful.
Source specific directives
These files expand on the common directives for src/dawn and src/tint:
@./common.dawn.md
@./common.tint.md
Knowledge base
These files contains rich, helpful, task-oriented guidance for this repository:
@./knowledge_base.md
@./knowledge_base.dawn.md
@./knowledge_base.tint.md