mirror of
https://github.com/Ellpeck/Contentless.git
synced 2024-11-25 08:28:34 +01:00
document the config
This commit is contained in:
parent
a436b1f70a
commit
525275f9b2
5 changed files with 33 additions and 11 deletions
13
Contentless/Config.cs
Normal file
13
Contentless/Config.cs
Normal file
|
@ -0,0 +1,13 @@
|
||||||
|
using Newtonsoft.Json;
|
||||||
|
|
||||||
|
namespace Contentless {
|
||||||
|
public class Config {
|
||||||
|
|
||||||
|
[JsonProperty(PropertyName = "exclude")]
|
||||||
|
public string[] ExcludedFiles = {"bin/", "obj/"};
|
||||||
|
|
||||||
|
[JsonProperty(PropertyName = "logSkipped")]
|
||||||
|
public bool LogSkipped = true;
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
|
@ -69,13 +69,15 @@ namespace Contentless {
|
||||||
|
|
||||||
// is the file in an excluded directory?
|
// is the file in an excluded directory?
|
||||||
if (excluded.Any(e => e.IsMatch(relative))) {
|
if (excluded.Any(e => e.IsMatch(relative))) {
|
||||||
Console.WriteLine($"Skipping excluded file {relative}");
|
if (config.LogSkipped)
|
||||||
|
Console.WriteLine($"Skipping excluded file {relative}");
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
// is the file already in the content file?
|
// is the file already in the content file?
|
||||||
if (HasEntry(content, relative)) {
|
if (HasEntry(content, relative)) {
|
||||||
Console.WriteLine($"Skipping file {relative} as it is already part of the content file");
|
if (config.LogSkipped)
|
||||||
|
Console.WriteLine($"Skipping file {relative} as it is already part of the content file");
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
16
README.md
16
README.md
|
@ -10,10 +10,22 @@ Next, add Contentless to your build process by adding the following task to your
|
||||||
<Exec Command="..\..\Contentless\Build\Contentless.exe Content/Content.mgcb" />
|
<Exec Command="..\..\Contentless\Build\Contentless.exe Content/Content.mgcb" />
|
||||||
</Target>
|
</Target>
|
||||||
```
|
```
|
||||||
Contentless will now automatically add any content files from your `Content` directory and subdirectories (excluding `bin` and `obj`) to your `Content.mgcb` file if they haven't already been added either manually or by Contentless. No existing items' configurations will be overridden, so you can still use the Content Pipeline tool to modify any settings as well.
|
Contentless will now automatically add any content files from your `Content` directory and subdirectories to your `Content.mgcb` file if they haven't already been added either manually or by Contentless. No existing items' configurations will be overridden, so you can still use the Content Pipeline tool to modify any settings as well.
|
||||||
|
|
||||||
|
# Configuring
|
||||||
|
To add a configuration file to Contentless, simply create a file named `Contentless.json` in the same directory as your `Content.mgcb` file. You can use the config to change several options. For reference, here is a configuration file with the default values that are used if no config is supplied:
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"exclude": [
|
||||||
|
"obj/",
|
||||||
|
"bin/"
|
||||||
|
],
|
||||||
|
"logSkipped": true
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
# What it does
|
# What it does
|
||||||
When running Contentless and supplying the location of a MonoGame Content Pipeline project (`Content.mgcb`), it scans all of the files in the project's directory as well as its subdirectories (excluding `bin` and `obj`). For each file, it checks if the `Content.mgcb` file already contains any references to that file. If no references are found, then a new reference to the file is added.
|
When running Contentless and supplying the location of a MonoGame Content Pipeline project (`Content.mgcb`), it scans all of the files in the project's directory as well as its subdirectories. For each file, it checks if the `Content.mgcb` file already contains any references to that file. If no references are found, then a new reference to the file is added.
|
||||||
|
|
||||||
Contentless figures out which importer and processor to register for any given file by generating a list of all of the importers and processors that are available, both inside of MonoGame, and inside of References added to the `Content.mgcb` file. This process is similar to what occurs when adding an existing file through MonoGame's Content Pipeline tool. If Contentless sets the wrong importer or processor for any file, the user can simply open `Content.mgcb` in MonoGame's Content Pipeline tool and edit it manually.
|
Contentless figures out which importer and processor to register for any given file by generating a list of all of the importers and processors that are available, both inside of MonoGame, and inside of References added to the `Content.mgcb` file. This process is similar to what occurs when adding an existing file through MonoGame's Content Pipeline tool. If Contentless sets the wrong importer or processor for any file, the user can simply open `Content.mgcb` in MonoGame's Content Pipeline tool and edit it manually.
|
||||||
|
|
||||||
|
|
|
@ -64,9 +64,3 @@
|
||||||
/importer:TiledMapTilesetImporter
|
/importer:TiledMapTilesetImporter
|
||||||
/processor:TiledMapTilesetProcessor
|
/processor:TiledMapTilesetProcessor
|
||||||
/build:Tiled/Tileset.tsx
|
/build:Tiled/Tileset.tsx
|
||||||
|
|
||||||
#begin Contentless.json
|
|
||||||
/importer:TexturePackerJsonImporter
|
|
||||||
/processor:TexturePackerProcessor
|
|
||||||
/build:Contentless.json
|
|
||||||
|
|
||||||
|
|
|
@ -3,5 +3,6 @@
|
||||||
"obj/",
|
"obj/",
|
||||||
"bin/",
|
"bin/",
|
||||||
"Ex*.png"
|
"Ex*.png"
|
||||||
]
|
],
|
||||||
|
"logSkipped": false
|
||||||
}
|
}
|
Loading…
Reference in a new issue