Class: TraeFormatter¶
Defined in: formatters/src/formatters/trae.ts:32
Abstract base class for markdown-based instruction formatters.
Provides shared section extraction logic (project, tech stack, architecture, code standards, git commits, config files, commands, post-work, documentation, diagrams, restrictions) and standard simple/multifile/full mode implementations.
Subclasses configure behavior via MarkdownFormatterConfig and can override specific methods for format-specific customization.
Extends¶
Constructors¶
Constructor¶
new TraeFormatter():
TraeFormatter
Defined in: formatters/src/formatters/trae.ts:33
Returns¶
TraeFormatter
Overrides¶
MarkdownInstructionFormatter.constructor
Properties¶
config¶
protectedreadonlyconfig:MarkdownFormatterConfig
Defined in: formatters/src/markdown-instruction-formatter.ts:126
Inherited from¶
MarkdownInstructionFormatter.config
defaultConvention¶
readonlydefaultConvention:string
Defined in: formatters/src/markdown-instruction-formatter.ts:124
Default convention for this formatter
Inherited from¶
MarkdownInstructionFormatter.defaultConvention
description¶
readonlydescription:string
Defined in: formatters/src/markdown-instruction-formatter.ts:123
Human-readable description
Inherited from¶
MarkdownInstructionFormatter.description
name¶
readonlyname:string
Defined in: formatters/src/markdown-instruction-formatter.ts:121
Unique formatter identifier
Inherited from¶
MarkdownInstructionFormatter.name
outputPath¶
readonlyoutputPath:string
Defined in: formatters/src/markdown-instruction-formatter.ts:122
Default output file path
Inherited from¶
MarkdownInstructionFormatter.outputPath
standardsExtractor¶
protectedreadonlystandardsExtractor:StandardsExtractor
Defined in: formatters/src/base-formatter.ts:28
Shared standards extractor for consistent extraction across all formatters.
Inherited from¶
MarkdownInstructionFormatter.standardsExtractor
Methods¶
addCommonSections()¶
protectedaddCommonSections(ast,renderer,sections):void
Defined in: formatters/src/markdown-instruction-formatter.ts:525
Parameters¶
ast¶
renderer¶
sections¶
string[]
Returns¶
void
Inherited from¶
MarkdownInstructionFormatter.addCommonSections
addSection()¶
protectedaddSection(sections,content):void
Defined in: formatters/src/markdown-instruction-formatter.ts:545
Parameters¶
sections¶
string[]
content¶
string | null
Returns¶
void
Inherited from¶
MarkdownInstructionFormatter.addSection
architecture()¶
protectedarchitecture(ast,renderer):string|null
Defined in: formatters/src/markdown-instruction-formatter.ts:644
Parameters¶
ast¶
renderer¶
Returns¶
string | null
Inherited from¶
MarkdownInstructionFormatter.architecture
codeStandards()¶
protectedcodeStandards(ast,renderer):string|null
Defined in: formatters/src/markdown-instruction-formatter.ts:657
Parameters¶
ast¶
renderer¶
Returns¶
string | null
Inherited from¶
MarkdownInstructionFormatter.codeStandards
commands()¶
protectedcommands(ast,renderer):string|null
Defined in: formatters/src/markdown-instruction-formatter.ts:713
Parameters¶
ast¶
renderer¶
Returns¶
string | null
Inherited from¶
MarkdownInstructionFormatter.commands
configFiles()¶
protectedconfigFiles(ast,renderer):string|null
Defined in: formatters/src/markdown-instruction-formatter.ts:695
Parameters¶
ast¶
renderer¶
Returns¶
string | null
Inherited from¶
MarkdownInstructionFormatter.configFiles
createRenderer()¶
protectedcreateRenderer(options?):ConventionRenderer
Defined in: formatters/src/base-formatter.ts:34
Create a convention renderer for this formatter. Uses the provided convention from options or falls back to the default.
Parameters¶
options?¶
Returns¶
Inherited from¶
MarkdownInstructionFormatter.createRenderer
dedent()¶
protecteddedent(text):string
Defined in: formatters/src/base-formatter.ts:452
Remove common leading whitespace from all lines (dedent). Handles the case where trim() was already called, causing the first line to lose its indentation while subsequent lines retain theirs. Calculates minimum indent from lines 2+ only.
Parameters¶
text¶
string
Returns¶
string
Inherited from¶
MarkdownInstructionFormatter.dedent
diagrams()¶
protecteddiagrams(ast,renderer):string|null
Defined in: formatters/src/markdown-instruction-formatter.ts:776
Parameters¶
ast¶
renderer¶
Returns¶
string | null
Inherited from¶
MarkdownInstructionFormatter.diagrams
documentation()¶
protecteddocumentation(ast,renderer):string|null
Defined in: formatters/src/markdown-instruction-formatter.ts:757
Parameters¶
ast¶
renderer¶
Returns¶
string | null
Inherited from¶
MarkdownInstructionFormatter.documentation
examples()¶
protectedexamples(ast,renderer):string|null
Defined in: formatters/src/markdown-instruction-formatter.ts:848
Parameters¶
ast¶
renderer¶
Returns¶
string | null
Inherited from¶
MarkdownInstructionFormatter.examples
extractAgents()¶
protectedextractAgents(ast):MarkdownAgentConfig[]
Defined in: formatters/src/markdown-instruction-formatter.ts:446
Parameters¶
ast¶
Returns¶
Inherited from¶
MarkdownInstructionFormatter.extractAgents
extractCommands()¶
protectedextractCommands(ast):MarkdownCommandConfig[]
Defined in: formatters/src/markdown-instruction-formatter.ts:288
Parameters¶
ast¶
Returns¶
Inherited from¶
MarkdownInstructionFormatter.extractCommands
extractExamples()¶
protectedextractExamples(ast):object[]
Defined in: formatters/src/base-formatter.ts:532
Extract examples from the
Parameters¶
ast¶
Returns¶
object[]
Examples¶
block. Returns an array of example definitions with name, input, output, and optional description.
Inherited from¶
MarkdownInstructionFormatter.extractExamples
extractRestrictionsItems()¶
protectedextractRestrictionsItems(content):string[]
Defined in: formatters/src/markdown-instruction-formatter.ts:852
Parameters¶
content¶
Returns¶
string[]
Inherited from¶
MarkdownInstructionFormatter.extractRestrictionsItems
extractSectionWithCodeBlock()¶
protectedextractSectionWithCodeBlock(text,header):string|null
Defined in: formatters/src/base-formatter.ts:176
Safe extraction of a section that contains a header + content + code block + content Avoids ReDoS by using string search instead of backtracking regex. Matches pattern: Header ... ...
Parameters¶
text¶
string
header¶
string
Returns¶
string | null
Inherited from¶
MarkdownInstructionFormatter.extractSectionWithCodeBlock
extractSkillExamples()¶
protectedextractSkillExamples(skillProps):object[]
Defined in: formatters/src/base-formatter.ts:545
Extract examples from a skill's nested examples property. Returns the same shape as extractExamples.
Parameters¶
skillProps¶
Record\<string, Value>
Returns¶
object[]
Inherited from¶
MarkdownInstructionFormatter.extractSkillExamples
extractSkills()¶
protectedextractSkills(ast):MarkdownSkillConfig[]
Defined in: formatters/src/markdown-instruction-formatter.ts:354
Parameters¶
ast¶
Returns¶
Inherited from¶
MarkdownInstructionFormatter.extractSkills
extractTechStackFromContext()¶
protectedextractTechStackFromContext(context):string[]
Defined in: formatters/src/markdown-instruction-formatter.ts:602
Parameters¶
context¶
Block | undefined
Returns¶
string[]
Inherited from¶
MarkdownInstructionFormatter.extractTechStackFromContext
extractTechStackFromStandards()¶
protectedextractTechStackFromStandards(standards):string[]
Defined in: formatters/src/markdown-instruction-formatter.ts:628
Parameters¶
standards¶
Block | undefined
Returns¶
string[]
Inherited from¶
MarkdownInstructionFormatter.extractTechStackFromStandards
extractText()¶
protectedextractText(content):string
Defined in: formatters/src/base-formatter.ts:69
Extract text from block content.
Parameters¶
content¶
Returns¶
string
Inherited from¶
MarkdownInstructionFormatter.extractText
findBlock()¶
protectedfindBlock(ast,name):Block|undefined
Defined in: formatters/src/base-formatter.ts:62
Find a block by name, ignoring internal blocks (starting with __).
Parameters¶
ast¶
name¶
string
Returns¶
Block | undefined
Inherited from¶
MarkdownInstructionFormatter.findBlock
format()¶
format(
ast,options?):FormatterOutput
Defined in: formatters/src/markdown-instruction-formatter.ts:145
Transform AST to tool-specific format
Parameters¶
ast¶
options?¶
Returns¶
Inherited from¶
MarkdownInstructionFormatter.format
formatArray()¶
protectedformatArray(arr):string
Defined in: formatters/src/base-formatter.ts:120
Format an array as comma-separated string.
Parameters¶
arr¶
unknown[]
Returns¶
string
Inherited from¶
MarkdownInstructionFormatter.formatArray
formatFull()¶
protectedformatFull(ast,options?):FormatterOutput
Defined in: formatters/src/formatters/trae.ts:60
Parameters¶
ast¶
options?¶
Returns¶
Overrides¶
MarkdownInstructionFormatter.formatFull
formatMultifile()¶
protectedformatMultifile(ast,options?):FormatterOutput
Defined in: formatters/src/formatters/trae.ts:56
Parameters¶
ast¶
options?¶
Returns¶
Overrides¶
MarkdownInstructionFormatter.formatMultifile
formatSimple()¶
protectedformatSimple(ast,options?):FormatterOutput
Defined in: formatters/src/formatters/trae.ts:52
Parameters¶
ast¶
options?¶
Returns¶
Overrides¶
MarkdownInstructionFormatter.formatSimple
formatStandardsList()¶
protectedformatStandardsList(items):string[]
Defined in: formatters/src/base-formatter.ts:112
Format standards list from array of values (pass-through). Returns array of strings for rendering as bullet list.
Parameters¶
items¶
Returns¶
string[]
Inherited from¶
MarkdownInstructionFormatter.formatStandardsList
generateAgentFile()¶
protectedgenerateAgentFile(config):FormatterOutput
Defined in: formatters/src/markdown-instruction-formatter.ts:470
Parameters¶
config¶
Returns¶
Inherited from¶
MarkdownInstructionFormatter.generateAgentFile
generateCommandFile()¶
protectedgenerateCommandFile(config):FormatterOutput
Defined in: formatters/src/markdown-instruction-formatter.ts:327
Parameters¶
config¶
Returns¶
Inherited from¶
MarkdownInstructionFormatter.generateCommandFile
generateSkillFile()¶
protectedgenerateSkillFile(config):FormatterOutput
Defined in: formatters/src/markdown-instruction-formatter.ts:387
Parameters¶
config¶
Returns¶
Inherited from¶
MarkdownInstructionFormatter.generateSkillFile
getArrayElements()¶
protectedgetArrayElements(content):Value[]
Defined in: formatters/src/base-formatter.ts:144
Extract array elements from block content.
Parameters¶
content¶
Returns¶
Value[]
Inherited from¶
MarkdownInstructionFormatter.getArrayElements
getMetaField()¶
protectedgetMetaField(ast,key):string|undefined
Defined in: formatters/src/base-formatter.ts:134
Get meta field value as string.
Parameters¶
ast¶
key¶
string
Returns¶
string | undefined
Inherited from¶
MarkdownInstructionFormatter.getMetaField
getOutputPath()¶
protectedgetOutputPath(options?):string
Defined in: formatters/src/base-formatter.ts:55
Get the output path, respecting options override.
Parameters¶
options?¶
Returns¶
string
Inherited from¶
MarkdownInstructionFormatter.getOutputPath
getPrettierOptions()¶
protectedgetPrettierOptions(options?):Required\<PrettierMarkdownOptions>
Defined in: formatters/src/base-formatter.ts:45
Get resolved Prettier options, merging provided options with defaults.
Parameters¶
options?¶
Returns¶
Required\<PrettierMarkdownOptions>
Inherited from¶
MarkdownInstructionFormatter.getPrettierOptions
getProp()¶
protectedgetProp(content,key):Value|undefined
Defined in: formatters/src/base-formatter.ts:83
Get a specific property from block content.
Parameters¶
content¶
key¶
string
Returns¶
Value | undefined
Inherited from¶
MarkdownInstructionFormatter.getProp
getProps()¶
protectedgetProps(content):Record\<string,Value>
Defined in: formatters/src/base-formatter.ts:97
Get all properties from block content.
Parameters¶
content¶
Returns¶
Record\<string, Value>
Inherited from¶
MarkdownInstructionFormatter.getProps
getSectionName()¶
protectedgetSectionName(key):string
Defined in: formatters/src/markdown-instruction-formatter.ts:272
Parameters¶
key¶
Returns¶
string
Inherited from¶
MarkdownInstructionFormatter.getSectionName
getSkillBasePath()¶
getSkillBasePath():
string|null
Defined in: formatters/src/markdown-instruction-formatter.ts:137
Base path for skills, or null if formatter has no skill support.
Returns¶
string | null
Inherited from¶
MarkdownInstructionFormatter.getSkillBasePath
getSkillFileName()¶
getSkillFileName():
string|null
Defined in: formatters/src/markdown-instruction-formatter.ts:141
Skill file name, or null if formatter has no skill support.
Returns¶
string | null
Inherited from¶
MarkdownInstructionFormatter.getSkillFileName
gitCommits()¶
protectedgitCommits(ast,renderer):string|null
Defined in: formatters/src/markdown-instruction-formatter.ts:673
Parameters¶
ast¶
renderer¶
Returns¶
string | null
Inherited from¶
MarkdownInstructionFormatter.gitCommits
isSafeSkillName()¶
protectedisSafeSkillName(name):boolean
Defined in: formatters/src/base-formatter.ts:622
Check if a skill name is safe for use in file paths.
Parameters¶
name¶
string
Returns¶
boolean
Inherited from¶
MarkdownInstructionFormatter.isSafeSkillName
knowledgeContent()¶
protectedknowledgeContent(ast,_renderer):string|null
Defined in: formatters/src/markdown-instruction-formatter.ts:801
Render remaining
Parameters¶
ast¶
_renderer¶
Returns¶
string | null
Knowledge¶
text content that isn't consumed by other sections. Strips "## Development Commands" and "## Post-Work Verification" sub-sections since those are already rendered by commands() and postWork().
Inherited from¶
MarkdownInstructionFormatter.knowledgeContent
normalizeMarkdownForPrettier()¶
protectednormalizeMarkdownForPrettier(content):string
Defined in: formatters/src/base-formatter.ts:204
Normalize markdown content to match Prettier formatting. - Strips common leading indentation from lines - Trims trailing whitespace from lines - Normalizes markdown table formatting - Adds blank lines before lists when preceded by text - Adds blank lines before code blocks when preceded by text - Escapes markdown special characters in paths
Parameters¶
content¶
string
Returns¶
string
Inherited from¶
MarkdownInstructionFormatter.normalizeMarkdownForPrettier
postWork()¶
protectedpostWork(ast,renderer):string|null
Defined in: formatters/src/markdown-instruction-formatter.ts:744
Parameters¶
ast¶
renderer¶
Returns¶
string | null
Inherited from¶
MarkdownInstructionFormatter.postWork
project()¶
protectedproject(ast,renderer):string|null
Defined in: formatters/src/markdown-instruction-formatter.ts:549
Parameters¶
ast¶
renderer¶
Returns¶
string | null
Inherited from¶
MarkdownInstructionFormatter.project
referenceProvenance()¶
protectedreferenceProvenance(sourcePath):string
Defined in: formatters/src/base-formatter.ts:615
Generate a provenance comment for a reference file.
Parameters¶
sourcePath¶
string
Returns¶
string
Inherited from¶
MarkdownInstructionFormatter.referenceProvenance
referencesMode()¶
referencesMode():
"none"|"directory"|"inline"
Defined in: formatters/src/base-formatter.ts:608
How this formatter handles skill references. - 'directory': emit as separate files in references/ subdirectory - 'inline': append as sections in the main output file - 'none': references not supported
Returns¶
"none" | "directory" | "inline"
Inherited from¶
MarkdownInstructionFormatter.referencesMode
renderCodeFence()¶
protectedrenderCodeFence(content,lang?):string
Defined in: formatters/src/base-formatter.ts:630
Render content inside a code fence, using a longer fence if the content itself contains triple backticks (prevents code fence injection).
Parameters¶
content¶
string
lang?¶
string = ''
Returns¶
string
Inherited from¶
MarkdownInstructionFormatter.renderCodeFence
renderExamplesSection()¶
protectedrenderExamplesSection(ast,renderer,sectionName?):string|null
Defined in: formatters/src/base-formatter.ts:561
Render an examples section from the
Parameters¶
ast¶
renderer¶
sectionName?¶
string = 'Examples'
Custom section heading name (default: 'Examples')
Returns¶
string | null
Examples¶
block. Shared rendering logic used by Claude, GitHub, and MarkdownInstructionFormatter.
Inherited from¶
MarkdownInstructionFormatter.renderExamplesSection
resolveVersion()¶
protectedresolveVersion(version?):MarkdownVersion
Defined in: formatters/src/markdown-instruction-formatter.ts:163
Parameters¶
version?¶
string
Returns¶
Inherited from¶
MarkdownInstructionFormatter.resolveVersion
restrictions()¶
protectedrestrictions(ast,renderer):string|null
Defined in: formatters/src/markdown-instruction-formatter.ts:838
Parameters¶
ast¶
renderer¶
Returns¶
string | null
Inherited from¶
MarkdownInstructionFormatter.restrictions
sanitizeResourceFiles()¶
protectedsanitizeResourceFiles(resources,targetDir):FormatterOutput[]
Defined in: formatters/src/base-formatter.ts:483
Filter resource files to only include safe paths. Rejects paths with traversal, absolute paths, and unsafe names.
Parameters¶
resources¶
object[] | undefined
targetDir¶
string
Returns¶
Inherited from¶
MarkdownInstructionFormatter.sanitizeResourceFiles
stripAllIndent()¶
protectedstripAllIndent(content):string
Defined in: formatters/src/base-formatter.ts:348
Strip all leading indentation from markdown content. Used for AGENTS.md where content from multiple sources has inconsistent indentation. Preserves indentation inside code blocks.
Parameters¶
content¶
string
Returns¶
string
Inherited from¶
MarkdownInstructionFormatter.stripAllIndent
techStack()¶
protectedtechStack(ast,renderer):string|null
Defined in: formatters/src/markdown-instruction-formatter.ts:582
Parameters¶
ast¶
renderer¶
Returns¶
string | null
Inherited from¶
MarkdownInstructionFormatter.techStack
transformRestrictionItem()¶
protectedtransformRestrictionItem(s):string
Defined in: formatters/src/markdown-instruction-formatter.ts:280
Parameters¶
s¶
string
Returns¶
string
Inherited from¶
MarkdownInstructionFormatter.transformRestrictionItem
truncate()¶
protectedtruncate(str,max):string
Defined in: formatters/src/base-formatter.ts:127
Truncate string to max length with ellipsis.
Parameters¶
str¶
string
max¶
number
Returns¶
string
Inherited from¶
MarkdownInstructionFormatter.truncate
valueToString()¶
protectedvalueToString(value):string
Defined in: formatters/src/base-formatter.ts:154
Convert value to string representation.
Parameters¶
value¶
Returns¶
string
Inherited from¶
MarkdownInstructionFormatter.valueToString
yamlString()¶
protectedyamlString(value):string
Defined in: formatters/src/markdown-instruction-formatter.ts:496
Parameters¶
value¶
string
Returns¶
string
Inherited from¶
MarkdownInstructionFormatter.yamlString
getSupportedVersions()¶
staticgetSupportedVersions():SimpleFormatterVersions
Defined in: formatters/src/formatters/trae.ts:48