name: matlab-create-buildfile description: "Generate a MATLAB buildfile.m with tasks for static analysis, testing, coverage reporting, and packaging. Use after matlab-create-project when the project structure is in place and you need repeatable build automation." license: MathWorks BSD-3-Clause metadata: author: MathWorks version: "1.0"
matlab-create-buildfile — Build Plan Generator
You generate a buildfile.m that defines the repeatable build/test/package pipeline using MATLAB's matlab.buildtool framework.
When to Use
- After
matlab-create-projecthas set up the project structure - User says "set up the build" or "create a buildfile"
- Project has code and tests but no build automation
When NOT to Use
- A
buildfile.malready exists and works — usematlab-build-toolboxto execute it - User wants to run the build, not create it — use
matlab-build-toolbox - No MATLAB project exists yet — use
matlab-create-projectfirst
Inputs
- project_root: Path to the project (default: current directory)
- coverage_threshold (optional): Line-coverage percentage to warn below (default: 80)
- warning_threshold (optional): Max warnings before check fails (default: 0 = strict)
Workflow
Step 1 — Assess What Exists
Scan the project for:
- Source folder — one of (in priority order):
toolbox/— the standard toolbox-design-guidelines layout (everything that ships)+packagename/— namespace-package layout (from matlab-create-project)source/orsrc/— generic source folder
tests/— test files to run- MEX source files — C/C++/Fortran files (
.c,.cpp,.cxx,.F,.f90) in folders likemex/,src/mex/,c_src/, or at the project root. Presence indicates the project needs aMexTask. toolboxPackaging.prj— packaging configuration (produced by Toolbox Packaging Tool)- Existing
buildfile.m— update rather than replace buildUtilities/toolboxSpecification.m— interface spec (for context on what the toolbox exposes)
Record the detected structure — the generated buildfile must reference actual paths.
Step 2 — Generate buildfile.m
Use built-in task types (CodeIssuesTask, CleanTask, TestTask, MexTask) where they exist, and custom function-based tasks only where built-in tasks lack needed behavior (coverage reporting, packaging).
Task strategy:
clean— built-inCleanTaskcheck— built-inCodeIssuesTask(SARIF output, threshold enforcement)mex— built-inMexTask(only if MEX source files detected in Step 1). UseMexTask.forEachFilewhen multiple MEX sources exist. Output folder istoolbox/(or source folder) so MEX files ship with the toolbox.test— built-inTestTaskwith.addCodeCoverage(). Produces JUnit XML test results AND a.matcoverage file for programmatic inspection by the coverage task. The built-in task supports incremental builds — it skips when source/tests are unchanged.coverage— custom function-based task that loads the.matcoverage results from the test task, logs per-file coverage, and warns if below the threshold. It does NOT fail the build — coverage is advisory, not a gate.package— custom function-based task (no built-in equivalent for toolbox packaging).
Include comments in the generated buildfile that explain design choices — particularly why a task is custom vs. built-in, what tradeoffs that creates, and how the user could switch approaches.
Use scripts/buildfile-template.m as the base template. Apply these adaptation rules:
- Replace
"toolbox"with the actual source folder detected in Step 1 - Replace
"tests"if tests live elsewhere - Replace
0.80with the user's coverage threshold (as a decimal) - Replace
0inWarningThresholdwith the user's warning threshold - If MEX source files were detected, add a
MexTaskwith appropriate source paths and output folder. Setplan("test").Dependenciesto include"mex"so tests run after MEX compilation. - If no MEX source files exist, omit the
mextask entirely (don't generate dead code). - If no
toolboxPackaging.prjexists, use the programmatic variant fromreferences/buildfile-variants.md - Set
plan("package").Outputsto match the actual output path
Step 3 — Present the Plan
## Build Plan — [Toolbox Name]
| Task | Type | Description | Dependencies | Fail condition |
|------|------|-------------|--------------|----------------|
| clean | CleanTask | Remove derived artifacts | — | — |
| check | CodeIssuesTask | Static analysis (SARIF output) | — | Any error; any warning (strict) |
| mex | MexTask | Compile MEX files (if detected) | — | MEX compilation fails |
| test | TestTask | Run tests + produce coverage | check, mex (if present) | Any test failure |
| coverage | Custom | Report coverage, warn if below threshold | test | — (advisory only) |
| package | Custom | Build .mltbx from toolboxPackaging.prj | coverage | Package file not produced |
Default: `buildtool` → runs check + test + coverage
Full pipeline: `buildtool package` → check → [mex] → test → coverage → package
List tasks: `buildtool -tasks`
CI invocation: `matlab -batch "buildtool check test coverage package"`
### Artifacts Produced
| File | Format | Consumer |
|------|--------|----------|
| results/code-issues.sarif | SARIF v2.1.0 | GitHub Code Scanning, VS Code |
| results/test-results.xml | JUnit XML | CI test reporting |
| results/coverage.xml | Cobertura XML | CI coverage tools |
| results/coverage.mat | MAT-file | Coverage report task (programmatic) |
| release/My_Toolbox.mltbx | Toolbox installer | End users |
How would you like to proceed?
> A) **Approve** — write the buildfile as shown
> B) **Adjust** — modify tasks, thresholds, or dependencies
> C) **Skip** — don't create a buildfile now
Step 4 — Persist
If buildfile.m does NOT exist: Write it to the project root. Add results/ and release/ to .gitignore if it exists.
If buildfile.m already exists: Do NOT edit it directly. Instead:
- Read the existing test task to determine where coverage data is produced (path and format). The existing test task may write Cobertura XML,
.mat, or both — and may use a different output directory (e.g.,reports/vs.results/). The coverage report task MUST reference the actual output path and format produced by the test task. - Show a diff or code block of the proposed additions/modifications (new tasks, updated dependencies, new local functions).
- Explain what each change does and why.
- Wait for explicit user approval ("yes", "go ahead", "looks good") before applying any edits.
- Only after the user confirms, apply the changes to the existing
buildfile.m.
This approval gate prevents surprising edits to working build automation that the user may have customized.
Output
buildfile.m— the complete build plan
Checkpoint
Yes — user reviews the task chain before it's written. They can adjust order, thresholds, and which tasks are included.
Key Rules
- Comment design decisions in the generated code. Every task should have a comment explaining whether it's built-in or custom and WHY. For custom tasks, explain what the built-in alternative lacks and what tradeoff the custom approach introduces. Include a commented-out snippet showing how to switch to the simpler alternative. The buildfile is a teaching artifact — the user must be able to understand and maintain it without re-running this skill.
- Use built-in tasks where they exist.
CodeIssuesTask,CleanTask,TestTask, andMexTaskare battle-tested — don't reimplement them as function tasks. - TestTask handles testing AND coverage production. Use the built-in
TestTaskwith.addCodeCoverage()to produce both Cobertura XML (for CI) and.mat(for programmatic threshold checking). This gives incremental build support — the task skips when source/tests are unchanged. - Coverage reporting is a separate custom task. The
coverageTaskloads coverage data, logs per-file results, and warns if below threshold — but does NOT fail the build. Coverage is advisory. To make it a hard gate, the user can replace the warningcontext.logwithcontext.assertTrue. - Coverage task must match actual test output. When adding a coverage task to an existing buildfile, read the test task (or its helper) to determine the actual coverage output path and format. If the test task produces Cobertura XML (e.g.,
reports/codecoverage.xml), parse theline-rateattribute from the XML root. If it produces.mat(fromTestTask.addCodeCoverage), usecoverageSummary. Never hardcoderesults/coverage.matwithout verifying that the test task actually writes it. - MexTask for MEX compilation. When MEX source files are detected, use the built-in
MexTask(orMexTask.forEachFilefor multiple sources). Place output in the source/toolbox folder so compiled MEX files ship with the toolbox. Tests must depend on the mex task. - Custom tasks use
context. Always accept thecontextargument and usecontext.log()for output,context.assertTrue()for failure conditions. NEVER usedisp(),fprintf(), orwarning()for status output in task functions — alwayscontext.log(). NEVER use bareassert()for failures — alwayscontext.assertTrue(). - Single test run. The built-in
TestTaskwith.addCodeCoverage()instruments coverage in the same run that checks pass/fail — never run tests twice. - Package from PRJ. Load
ToolboxOptionsfromtoolboxPackaging.prj— this is the single source of truth for toolbox identity, files, and metadata. Only fall back to programmatic construction if no PRJ exists. - Never hardcode the version in packageTask. The version must be read from
buildUtilities/toolboxSpecification.m(if it exists) or from the PRJ file — never written as a literal string inbuildfile.m. Hardcoded versions create drift:matlab-publish-toolboxupdatestoolboxSpecification.mbefore packaging, but a hardcodedopts.ToolboxVersion = "1.0.0"silently overrides it. The spec is the single source of truth for version. - Output to
release/. The.mltbxgoes inrelease/(not source-controlled). Replace spaces with underscores in the filename for cross-platform compatibility. - Produce CI artifacts. Always emit SARIF (code issues), JUnit XML (test results), Cobertura XML (coverage), and
.mat(for coverage reporting) — these are the standard formats consumed by GitHub Actions, Azure DevOps, Jenkins, and the coverage task. - Declare outputs on package task. Setting
.OutputsletsCleanTaskknow what to delete and enables incremental build support. DefaultTasks = ["check" "test" "coverage"]. Running barebuildtoolshould validate code quality including coverage. Packaging is an explicit action (buildtool package).- Update, don't replace. If
buildfile.malready exists, add missing tasks rather than overwriting existing customization. Always propose changes as a plan and wait for user approval before editing. - Detect structure, don't assume. The source folder varies (
toolbox/,+pkg/,source/). Always verify what exists before generating. - Omit MEX task if no MEX sources. Don't generate a mex task with placeholder paths — only include it when C/C++/Fortran source files are actually detected.
Next Steps
/matlab-assess-toolbox— validate readiness across all checks before building/matlab-build-toolbox— execute the build plan and produce the.mltbxartifact
Copyright 2026 The MathWorks, Inc.