Skip to content

Commit

Permalink
Documentation for new includes directory
Browse files Browse the repository at this point in the history
  • Loading branch information
rcdailey committed Apr 24, 2024
1 parent 1ccd89b commit 114f60c
Show file tree
Hide file tree
Showing 5 changed files with 56 additions and 40 deletions.
34 changes: 34 additions & 0 deletions docs/_include-templates-dir.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,34 @@
A directory named `includes` exists under the application data directory where local [include
templates][configdirective] may be placed. Any relative paths to include templates will start at
this directory.

For example, if I have the following include directive in a configuration file named `foo.yml`:

```yml
include:
- config: bar/reusable.yml
```
The expected file structure of my `includes` directory would be visualized as follows:

```txt
.
├── configs/
│ └── foo.yml
└── includes/
└── bar/
└── reusable.yml
```

For more information about include templates, see the respective [behaviors page][include].

:::caution

Configuration files (non-includes) should *not* be placed here; use the [`configs`][configsdir]
directory for those.

:::

[include]: /yaml/config-reference/include.md
[configdirective]: /yaml/config-reference/include.md#config
[configsdir]: /file-structure.md#config-directory
31 changes: 2 additions & 29 deletions docs/behavior/include.md
Original file line number Diff line number Diff line change
Expand Up @@ -393,33 +393,6 @@ custom_formats:

### Include File Structure {#file-structure}

This section covers the currently recommended file structure for local YAML includes.
import IncludeDirectory from '../_include-templates-dir.md'

Recyclarr does not recursively scan for configuration YAML files in the [`configs`
subdirectory][configdir]. This means that you can structure local include YAML files into
subdirectories inside `configs`. This allows the convenient usage of relative paths when using the
[`config` include directive][configdirective].

As an example, consider this file structure:

```txt
.
└── configs/
├── includes/
│ └── reusable.yml
└── my-config.yml
```

And the `my-config.yml` file has the following include directives:

```yml
include:
- config: includes/reusable.yml
```

Because we have our includes within the `configs` directory, we can easily access them with a
relative path. And since those includes are under a subdirectory, Recyclarr will not scan them and
treat them as top-level configuration YAML files.

[configdir]: /file-structure.md#config-directory
[configdirective]: /yaml/config-reference/include.md#config
<IncludeDirectory />
15 changes: 12 additions & 3 deletions docs/file-structure.md
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,16 @@ really have an easy way to specify custom CLI arguments. The following requireme
`--config` command line argument. This behavior is non-recursive; meaning if you place YAML files
in subdirectories under `configs/`, they will not be loaded.
- The names of the files are unimportant and can be whatever you want.
- [Include templates][inc] should *not* be placed in this directory; only real configuration files
are supported here.

[inc]: /yaml/config-reference/include.md
:::caution

Include templates should *not* be placed here; use the [`includes`](#include-directory) directory
instead.

:::

## Include Templates Directory {#include-directory}

import IncludeDirectory from './_include-templates-dir.md'

<IncludeDirectory />
2 changes: 1 addition & 1 deletion docs/schema-validation.md
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@ much easier. You should be interested in this topic if any of the following poin

:::info What's a Schema?

A *schema*, in this case, defines the shape that YAML must conform to. It's a `json` file that
A *schema*, in this case, defines the shape that YAML must conform to. It's a JSON file that
describes the different parts of YAML settings, configuration, and other files that Recyclarr uses.

Schema *validation* refers to the process of using the schema itself to check for issues in your
Expand Down
14 changes: 7 additions & 7 deletions docs/yaml/config-reference/include.md
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@ service_type:
# Include Configuration
include:
- template: uhd-bluray-web
- config: includes/my-config.yml
- config: my-config.yml
```
YAML includes are a mechanism to support reusable configurations. Including YAML is the process of
Expand Down Expand Up @@ -48,22 +48,22 @@ Use this directive to include YAML files on your local filesystem.

**Required.**

An absolute or relative path to the YAML file you wish to include. Relative paths start at the
`configs` directory inside the [app data directory][appdata]
An absolute or relative path to the YAML file you wish to include. If relative paths are used, see
the [app data directory][appdata] page for where those files should be located.

[appdata]: /file-structure.md#appdata-directory
[appdata]: /file-structure.md#include-directory

### Examples

```yml
include:
# An absolute include path
- config: /home/john/my-config.yml
- config: /home/john/my-include.yml
# A relative include path
# Equivalent absolute path is (on Linux):
# /home/john/.config/recyclarr/configs/include/my-config.yml
- config: include/my-config.yml
# /home/john/.config/recyclarr/includes/my-include.yml
- config: my-include.yml
```

## Template Includes {#template}
Expand Down

0 comments on commit 114f60c

Please sign in to comment.