Overwrite Files

Introduction

DocFX supports processing Markdown files, as well as structured data model in YAML or JSON format.

We call Markdown files Conceptual Files, and the structured data model files Metadata Files.

Current supported Metadata Files include:

  1. YAML files presenting managed reference model following Metadata Format for .NET Languages.
  2. Swagger JSON files presenting Swagger REST API model following Swagger Specification Version 2.0.

Inside DocFX, both Conceptual Files and Metadata Files are represented as Models with different properties. Details on Model structure for these files are described in Data model inside DocFX section.

DocFX introduces the concept of Overwrite File to modify or add properties to Models without changing the input Conceptual Files and Metadata Files.

The format of Overwrite Files

Overwrite Files are Markdown files with multiple Overwrite Sections starting with YAML header block. A valid YAML header for an Overwrite Section MUST take the form of valid YAML set between triple-dashed lines and start with property uid. Here is a basic example of an Overwrite Section:

---
uid: microsoft.com/docfx/Contacts
some_property: value
---
Further description for `microsoft.com/docfx/Contacts`

Each Overwrite Section is transformed to Overwrite Model inside DocFX. For the above example, the Overwrite Model represented in YAML format is:

uid: microsoft.com/docfx/Contacts
some_property: value
conceptual: <p><b>Content</b> in Markdown</p>

Anchor *content

*content is the keyword invented and used specifically in Overwrite Files to represent the Markdown content following YAML header. We leverage Anchors syntax in YAML specification for *content.

The value for *content is always transformed from Markdown content to HTML. When *content is not used, the Markdown content below YAML header will be set to conceptual property; When *content is used, the Markdown content below YAML header will no longer be set to conceptual property. With *content, we can easily add Markdown content to any properties.

---
uid: microsoft.com/docfx/Contacts
footer: *content
---
Footer for `microsoft.com/docfx/Contacts`

In the above example, the value for *content is <p>Footer for <code>microsoft.com/docfx/Contacts</code></p>, and the Overwrite Model represented in YAML format is:

uid: microsoft.com/docfx/Contacts
footer: <p>Footer for <code>microsoft.com/docfx/Contacts</code></p>

uid for an Overwrite Model stands for the Unique IDentifier of the Model it will overwrite. So it is allowed to have multiple Overwrite Sections with YAML Header containing the same uid. For one Overwrite File, the latter Overwrite Section overwrites the former one with the same uid. For different Overwrite Files, the order of overwrite is Undetermined. So it is suggested to have Overwrite Sections with the same uid in the same Overwrite File.

NOTE

Multiple Overwrite Sections in one file doesn't work in markdig markdown engine. You should remove "markdownEngineName": "markdig", from docfx.json to support this feature.

When processing Conceptual Files and Metadata Files, Overwrite Models with the same uid are applied to the processed Models. Different Models have different overwrite principles, Overwrite principles section describes the them in detail.

Apply Overwrite Files

Inside docfx.json, overwrite is used to specify the Overwrite Files.

Overwrite principles

As a general principle, uid is always the key that an Overwrite Model find the Model it is going to overwrite. So a Model with no uid defined will never get overwritten.

Different types of files produce different Models. The quickest way to get an idea of what the Model looks like is to run:

docfx build --exportRawModel

--exportRawModel exports Model in JSON format with .raw.json extension.

The basic principle of Overwrite Model is:

  1. It keeps the same data structure as the Model it is going to overwrite
  2. If the property is defined in Model, please refer Data model inside DocFX for the specific overwrite behavior for a specific property.
  3. If the property is not defined in Model, it is added to Model

Data model inside DocFX

Managed reference model

Key Type Overwrite behavior
uid uid Merge key.
assemblies string[] Ignore.
attributes Attribute[] Ignore.
children uid[] Ignore.
documentation Source Merge.
example string[] Replace.
exceptions Exception[] Merge keyed list.
fullName string Replace.
fullName. string Replace.
id string Replace.
implements uid[] Ignore.
inheritance uid[] Ignore.
inheritedMembers uid[] Ignore.
isEii boolean Replace.
isExtensionMethod boolean Replace.
langs string[] Replace.
modifiers. string[] Ignore.
name string Replace.
name. string Replace.
namespace uid Replace.
overridden uid Replace.
parent uid Replace.
platform string[] Replace.
remarks markdown Replace.
see LinkInfo[] Merge keyed list.
seealso LinkInfo[] Merge keyed list.
source Source Merge.
syntax Syntax Merge.
summary markdown Replace.
type string Replace.

Source

Property Type Overwrite behavior
base string Replace.
content string Replace.
endLine integer Replace.
id string Replace.
isExternal boolean Replace.
href string Replace.
path string Replace.
remote GitSource Merge.
startLine integer Replace.

GitSource

Property Type Overwrite behavior
path string Replace.
branch string Replace.
repo url Replace.
commit Commit Merge.
key string Replace.

Commit

Property Type Overwrite behavior
committer User Replace.
author User Replace.
id string Replace.
message string Replace.

User

Property Type Overwrite behavior
name string Replace.
email string Replace.
date datetime Replace.

Exception

Property Type Overwrite behavior
type uid Merge key.
description markdown Replace.
commentId string Ignore.

LinkInfo

Property Type Overwrite behavior
linkId uid or href Merge key.
altText markdown Replace.
commentId string Ignore.
linkType enum(CRef or HRef) Ignore.

Syntax

Property Type Overwrite behavior
content string Replace.
content. string Replace.
parameters Parameter[] Merge keyed list.
typeParameters Parameter[] Merge keyed list.
return Parameter Merge.

Parameter

Property Type Overwrite behavior
id string Merge key.
description markdown Replace.
attributes Attribute[] Ignore.
type uid Replace.

Attribute

Property Type Overwrite behavior
arguments Argument[] Ignore.
ctor uid Ignore.
namedArguments NamedArgument[] Ignore.
type uid Ignore.

Argument

Property Type Overwrite behavior
type uid Ignore.
value object Ignore.

NamedArgument

Property Type Overwrite behavior
name string Ignore.
type string Ignore.
value object Ignore.

REST API model

Key Type Overwrite behavior
children REST API item model Overwrite when uid of the item model matches
summary string Overwrite
description string Overwrite

REST API item model

Key Type Overwrite behavior
uid string Key

Conceptual model

Key Type Overwrite behavior
title string Overwrite
rawTitle string Overwrite
conceptual string Overwrite