Paths
This document describes all available placeholders and functions for the Soulsolid path parser, which is used to organize music files into directories based on metadata.
Placeholders
Placeholders are variables that get replaced with actual metadata values from the track. They are prefixed with a $ symbol.
Available Placeholders
| Placeholder | Description | Data Type | Example Value |
|---|---|---|---|
$albumartist |
The name of the first album artist | String | “The Beatles” |
$album |
The album title | String | “Abbey Road” |
$year |
The release year | Integer | “1969” |
$original_year |
The original release year (if different from release year) | Integer | “1969” |
$track |
The track number, zero-padded to 2 digits | String | “01” |
$title |
The track title | String | “Come Together” |
$format |
Audio format (flac, mp3, etc.) | String | “flac” |
$genre |
Music genre | String | “Rock” |
Functions
Functions perform operations on placeholders or other values. They are prefixed with % and use curly braces for arguments.
Available Functions
asciify
Converts text to ASCII by removing accents, diacritics, and special characters.
Syntax: %asciify{value}
Parameters:
value: Any string value or placeholder
Example:
%asciify{$albumartist}
For “Björk” → “Bjork”
if
Conditional rendering that returns one of two values based on a condition.
Syntax: %if{condition,true_value,false_value}
Parameters:
condition: Expression to evaluate (returns true if not empty, “0”, or “false”)true_value: Value to return if condition is truefalse_value: Value to return if condition is false (optional)
Examples:
%if{$original_year,$original_year,$year}
Returns $original_year if it exists, otherwise $year
%if{$albumartist,$albumartist,Various Artists}
Returns $albumartist if it exists, otherwise “Various Artists”
Usage Examples
Basic Path Template
$albumartist/$album ($year)/$track $title
Result: The Beatles/Abbey Road (1969)/01 Come Together
With ASCII Conversion
%asciify{$albumartist}/%asciify{$album} (%if{$original_year,$original_year,$year})/%asciify{$track $title}
Result: The Beatles/Abbey Road (1969)/01 Come Together
Album Type Specific Paths
Default Album
%asciify{$albumartist}/%asciify{$album} (%if{$original_year,$original_year,$year})/%asciify{$track $title}
EP
%asciify{$albumartist}/%asciify{$album} [EP] (%if{$original_year,$original_year,$year})/%asciify{$track $title}
Single
%asciify{$albumartist}/%asciify{$album} [Single] (%if{$original_year,$original_year,$year})/%asciify{$track $title}
Soundtrack
%asciify{$albumartist}/%asciify{$album} [OST] (%if{$original_year,$original_year,$year})/%asciify{$track $title}
Compilation
%asciify{$albumartist}/%asciify{$album} (%if{$original_year,$original_year,$year})/%asciify{$track $title}
Advanced Examples
Conditional Album Artist
%if{$albumartist,%asciify{$albumartist},Various Artists}/%asciify{$album} (%if{$original_year,$original_year,$year})/%asciify{$track $title}
Year with Fallback
%asciify{$albumartist}/%asciify{$album} (%if{$original_year,$original_year,%if{$year,$year,Unknown}})/%asciify{$track $title}
Notes
- All placeholders are replaced with actual metadata values from the track
- Functions can be nested within each other
- Unknown placeholders are left as-is in the output
- The
%asciifyfunction is particularly useful for creating filesystem-safe paths - The
%iffunction allows for conditional logic in path templates - Track numbers are automatically zero-padded to 2 digits
- Years are converted to strings automatically
Configuration
These templates can be configured in the config.yaml file under the import.paths section:
import:
paths:
default_path: "%asciify{$albumartist}/%asciify{$album} (%if{$original_year,$original_year,$year})/%asciify{$track $title}"
album:ep: "%asciify{$albumartist}/%asciify{$album} [EP] (%if{$original_year,$original_year,$year})/%asciify{$track $title}"
album:single: "%asciify{$albumartist}/%asciify{$album} [Single] (%if{$original_year,$original_year,$year})/%asciify{$track $title}"
album:soundtrack: "%asciify{$albumartist}/%asciify{$album} [OST] (%if{$original_year,$original_year,$year})/%asciify{$track $title}"
compilations: "%asciify{$albumartist}/%asciify{$album} (%if{$original_year,$original_year,$year})/%asciify{$track $title}"
Soulsolid