git-subtree-dir: docs git-subtree-mainline: 23545aa7ea599faf17737de9879733a1bde700d1 git-subtree-split: 106142b25c9387ffd002437027ced1b04f494205
2.6 KiB
title | tags | last_updated | keywords | summary | sidebar | permalink | folder | |
---|---|---|---|---|---|---|---|---|
Excluding files |
|
July 3, 2016 | exclusion, separating outputs, removing files from outputs | By default, all the files in your Jekyll project are included in the output (this differs from DITA projects, which don't include files unless noted on the map). If you're single sourcing, you'll need to exclude the files that shouldn't be included in the output. The sidebar doesn't control inclusion or exclusion. | mydoc_sidebar | mydoc_exluding_files.html | mydoc |
About exclusion
By default, all files in your project are included in your output (regardless of whether they're listed in the sidebar_doc.yml file or not). To exclude files, note them in the exclude
section in the configuration file. Here's a sample:
exclude:
- mydoc_writers_*
- bower_components
- Gemfile
If you have different outputs for your site, you'll want to customize the exclude sections in your various configuration files.
Exclude strategies
Here's the process I recommend. Put all files in the root directory of your project. Suppose one project's name is alpha and the other is beta. Then name each file as follows:
- alpha_sample.html
- beta_sample.html
In your exclude list for your beta project, specify it as follows:
exclude:
- alpha_*
In your exclude list for your alpha project, specify it as follows:
exclude:
- beta_*
If you have more sophisticated exclusion, add another level to your file names. For example, if you have different programming languages you want to filter by, add this:
- alpha_java_sample.html
- alpha_cpp_sample.html
Then you exclude files for your Alpha C++ project as follows:
exclude:
- alpha_java_*
- beta_*
And you exclude files for your Alpha Java project as follows:
exclude:
- alpha_cpp_*
- alpha_beta_*
When you exclude folders, include the trailing slash at the end of the folder name:
exclude:
- images/alpha/
There isn't a way to automatically exclude anything. By default, everything is included unless you explicitly list it under the exclude section.
Excluding draft content
If you're working on a draft, put it inside the _drafts folder or add published: false
in the frontmatter. The _drafts folder is excluded by default, so you don't have to specify it in your exclude list.
Limitations
What if a file should appear in two projects but not the third? This can get tricky. For some files, rather than using a wildcard, you may need to manually specify the entire filename that you're excluding instead of excluding it by way of a wildcard pattern.
{% include links.html %}