2015-04-23 19:24:23 +02:00
# forked-daapd smart playlists
To add a smart playlist to forked-daapd, create a new text file with a filename ending with .smartpl;
the filename doesn't matter, only the .smartpl ending does. The file must be placed somewhere in your
library folder.
## Syntax
The contents of a smart playlist must follow the syntax:
```
"Playlist Name" { expression }
```
There is exactly one smart playlist allowed for a .smartpl file.
An expression consists of:
```
field-name operator operand
```
2018-03-02 16:51:53 -08:00
Where valid field-names (with their types) are:
2018-04-13 20:29:04 +02:00
* `artist` (string)
* `album_artist` (string)
* `album` (string)
* `title` (string)
* `genre` (string)
* `composer` (string)
* `path` (string)
* `type` (string)
* `grouping` (string)
* `data_kind` (enumeration)
* `media_kind` (enumeration)
* `play_count` (integer)
2018-08-18 22:56:27 +02:00
* `skip_count` (integer)
2018-04-13 20:29:04 +02:00
* `rating` (integer)
* `year` (integer)
* `compilation` (integer)
2018-12-10 13:20:20 +01:00
* `track` (integer)
* `disc` (integer)
2018-04-13 20:29:04 +02:00
* `time_added` (date)
* `time_modified` (date)
* `time_played` (date)
2018-08-18 22:56:27 +02:00
* `time_skipped` (date)
2015-04-23 19:24:23 +02:00
Valid operators include:
2018-04-13 20:29:04 +02:00
* `is` , `includes` , `starts with` (string)
* `>` , `<` , `<=` , `>=` , `=` (int)
* `after` , `before` (date)
* `is` (enumeration)
2015-04-23 19:24:23 +02:00
2018-04-13 20:29:04 +02:00
The `is` operator must exactly match the field value, while the `includes` operator matches a substring.
The `starts with` operator matches, if the value starts with the given prefix.
2018-03-17 05:12:45 +01:00
All three matches are case-insensitive.
2015-04-23 19:24:23 +02:00
Valid operands include:
* "string value" (string)
* integer (int)
2018-04-13 20:29:04 +02:00
Valid operands for the enumeration `data_kind` are:
* `file`
* `url`
* `spotify`
* `pipe`
2015-04-23 19:24:23 +02:00
2018-04-13 20:29:04 +02:00
Valid operands for the enumeration `media_kind` are:
* `music`
* `movie`
* `podcast`
* `audiobook`
* `tvshow`
2015-04-23 19:24:23 +02:00
2018-04-13 20:29:04 +02:00
Multiple expressions can be anded or ored together, using the keywords `OR` and `AND` . The unary not operator is also supported using the keyword `NOT` .
2015-04-23 19:24:23 +02:00
2018-04-13 20:29:04 +02:00
It is possible to define the sort order and limit the number of items by adding an order clause and/or a limit clause after the last expression:
```
"Playlist Name" { expression ORDER BY field-name sort-direction LIMIT limit }
```
"sort-direction" is either `ASC` (ascending) or `DESC` (descending). "limit" is the maximum number of items.
## Examples
2015-04-23 19:24:23 +02:00
```
"techno" {
genre includes "techno"
and artist includes "zombie"
}
```
This would match songs by "Rob Zombie" or "White Zombie", as well as those with a genre of "Techno-Industrial" or
"Trance/Techno", for example.
```
"techno 2015" {
genre includes "techno"
and artist includes "zombie"
and not genre includes "industrial"
}
```
This would exclude e. g. songs with the genre "Techno-Industrial".
```
"Local music" {
data_kind is file
and media_kind is music
}
```
This would match all songs added as files to the library that are not placed under the folders for podcasts, audiobooks.
```
"Unplayed podcasts and audiobooks" {
play_count = 0
and (media_kind is podcast or media_kind is audiobook)
}
```
This would match any podcast and audiobook file that was never played with forked-daapd.
2018-04-13 20:29:04 +02:00
```
"Recently added music" {
media_kind is music
order by time_added desc
limit 10
}
```
This would match the last 10 music files added to the library.
2015-04-23 19:24:23 +02:00
2015-04-24 17:28:09 +02:00
## Date operand syntax
2015-04-23 19:24:23 +02:00
One example of a valid date is a date in yyyy-mm-dd format:
```
"Files added after January 1, 2004" {
time_added after 2004-01-01
}
```
There are also some special date keywords:
2018-04-13 20:29:04 +02:00
* `today` , `yesterday` , `last week` , `last month` , `last year`
2015-04-23 19:24:23 +02:00
2018-04-13 20:29:04 +02:00
A valid date can also be made by applying an interval to a date. Intervals can be defined as `days` , `weeks` , `months` , `years` .
2015-04-23 19:24:23 +02:00
As an example, a valid date might be:
```3 weeks before today` `` or ` ``3 weeks ago` ``
Examples:
```
"Recently Added" {
time_added after 2 weeks ago
}
```
This matches all songs added in the last 2 weeks.
```
"Recently played audiobooks" {
time_played after last week
and media_kind is audiobook
}
```
This matches all audiobooks played in the last week.
## Differences to mt-daapd smart playlists
The syntax is really close to the mt-daapd smart playlist syntax (see
http://sourceforge.net/p/mt-daapd/code/HEAD/tree/tags/release-0.2.4.2/contrib/mt-daapd.playlist).
Even this documentation is based on the file linked above.
Some differences are:
* only one smart playlist per file
* the not operator must be placed before an expression and not before the operator
* "||", "&& ", "!" are not supported (use "or", "and", "not")
* comments are not supported