# carl ![carl logo](https://codeberg.org/birger/carl/media/branch/main/data/logo.svg) `carl` is a calendar for the commandline. It tries to mimic the various `cal(1)` implementations out there, but also adds enhanced features like colors and ical support. **If you find any bugs or have ideas for additional features, please don't hesitate to create a bug report or a feature request [on codeberg](https://codeberg.org/birger/carl/issues/new) or [github](https://github.com/b1rger/carl/issues/new).** ---
Default output of `carl` `carl` output with custom colors `carl` output with events
from ical highlighted
![Screenshots of default carl](https://codeberg.org/birger/carl/media/branch/main/data/screenshot-default.png) ![Screenshot of carl with custom colors](https://codeberg.org/birger/carl/media/branch/main/data/screenshot-custom.png) ![Screenshot of carl with ical events highlighted](https://codeberg.org/birger/carl/media/branch/main/data/screenshot-ical.png)

Installation

cargo install carl

Commandline flags

Commandline options

Configuration file

The configuration file is located XDG_CONFIG_DIRS/carl/config.toml or XDG_CONFIG_HOME/.carl/config.toml (the latter has precedence).

The configuration file can define the name of a themefile and multiple icalfiles. Themefiles contain listings of date properties together with styledefintions. Icalfile listings contain paths to icalfiles together with styledefinitions.

The name of a them is simple specified using the theme = setting: theme = "default" The themefile is read from XDG_CONFIG_DIRS/carl/<themename>.toml or XDG_CONFIG_HOME/.carl/<themename>.toml (the latter has precedence).

Icalfiles can be specified using the [[ical]] setting: [[ical]] file = "/home/user/birthdays.ics" stylenames = ['FGPurple']

If the file setting points to a directory, carl uses all the files in that directory it can parse.

A sample configuration file is located in data/config.toml.

Styles

Themefiles and Icalfile listings can contain custom style settings. A style changes how a specific date in the calendar is displayed. A style consists of a list of stylenames and optionally a weight and a styletype ('Dark' or 'Light'). If no styletype is set, the style is effective in either case. The various possible stylenames are listed at the bottom.

Example: stylenames = ['Dimmed'] weight = 10 styletype = 'Dark'

Themefile

A themefile consists of a collection of datestyles:

Datestyles

A datestyle consists of a list of properties of a date and a style. The date has to fullfill all of the properties for the style to be applied.

Example: [[date]] properties = ['CurrentDate'] stylenames = ['FGRed'] weight = 3 styletype = 'Light'

Possible properties

A sample theme file is located in data/theme.toml.

Stylenames

Styles

Foreground color names

Background color names

Multiple styles and colors can be combined using lists: ["Bold", "FGRed", "Underline"]