cobib


Namecobib JSON
Version 5.2.3 PyPI version JSON
download
home_pageNone
SummaryConsole Bibliography
upload_time2024-12-15 15:19:07
maintainerNone
docs_urlNone
authorNone
requires_python>=3.9
licenseMIT License
keywords reference-manager citation-manager bibliography cli tui command-line terminal console bibtex doi arxiv isbn
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            [![coBib](https://gitlab.com/cobib/cobib/-/raw/master/logo/cobib_logo.svg)](https://cobib.gitlab.io/cobib/cobib.html)

# coBib

[![pipeline](https://gitlab.com/cobib/cobib/badges/master/pipeline.svg)](https://gitlab.com/cobib/cobib/-/pipelines)
[![coverage](https://gitlab.com/cobib/cobib/badges/master/coverage.svg)](https://gitlab.com/cobib/cobib/-/graphs/master/charts)
[![PyPI](https://img.shields.io/pypi/v/cobib)](https://pypi.org/project/cobib/)

coBib is a simple, command-line based bibliography management tool.
It is the result of the need for an easy-to-use alternative to full-blown reference managers like Mendeley or Zotero.
As such it follows some basic design goals:

* **plain-text database**: which means you get full access and control over the database.
* **git-integration**: as a benefit of the above, you can keep track of your database through version control.
* **centralized database, location-independent library**: this means, that coBib *only* manages the
  database file in a centralized fashion but allows you to spread the actual contents of your
  library across the entire file system (this is the major different to
  [papis](https://papis.readthedocs.io/en/latest/library_structure.html)).
* **command-line and TUI support**: all features are available through the command-line as well as a
  [textual](https://textual.textualize.io/)-based TUI


## Installation

For all common purposes you can install coBib via `pip`:

```
pip install cobib
```

Note: Use `pip3` if you still have Python 2 installed.

If you would also like to install the man-page, you need to download the source
code and do the following:

```
git clone https://gitlab.com/cobib/cobib
cd cobib
make install_extras
```

### Arch Linux

coBib is packaged in the AUR.
* [cobib](https://aur.archlinux.org/packages/cobib/)
* [cobib-git](https://aur.archlinux.org/packages/cobib-git/)

### Windows

coBib _might_ work on Windows as is, but it is not being tested so no guarantees are given.
If you are using Windows 10 or later and are running into issues, you should be able to install and
use coBib's full functionality within the Linux subsystem.


## Getting started

To get started, you must initialize the database:

```
cobib init
```

If you would like to enable the git-integration, you should run:

```
cobib init --git
```

*and* enable `config.database.git` (see also [configuration](#configuration)).

Be sure to check out my [Quickstart blog post](https://mrossinek.gitlab.io/programming/introducing-cobib/)
for a more guided introduction compared to the following section!

### Importing your library

coBib provides an `import` command through which you can easily import your library
from another bibliography manager. For more details check out:

```
cobib import --help
```

So far, coBib knows how to import your library from Zotero by simply running:

```
cobib import --zotero
```

Check out the following command, the man page or the online documentation for more details:

```
cobib import --zotero -- --help
```

## Usage

### Adding new entries

You can now add new entries to your database (see also `cobib.commands.add`[^1]):

```
cobib add --bibtex some_biblatex_file.bib
cobib add --arxiv <some arXiv ID>
cobib add --doi <some DOI>
cobib add --isbn <some ISBN>
```

**Note**: when adding data from a `.bib` file, make sure that it is in the Bib**La**Tex format!

### Viewing your database and entries

You can view the contents of your database with (see also `cobib.commands.list_`):

```
cobib list
```

You can show a specific entry with (see also `cobib.commands.show`):

```
cobib show <some entry label>
```

You can open an associated file of an entry with (see also `cobib.commands.open`):

```
cobib open <some entry label>
```

You can even search through your database with (see also `cobib.commands.search`):

```
cobib search "some text"
```

### Editing your database

You can delete an entry with (see also `cobib.commands.delete`):

```
cobib delete <some entry label>
```

You can edit an entry manually with (see also `cobib.commands.edit`):

```
cobib edit <some entry label>
```

You can also apply simple modifications to multiple entries at once with (see also
`cobib.commands.modify`):

```
cobib modify tags:private -- <some entry label> <another entry label> ...
```

### Exporting your database

You can export your database with (see also `cobib.commands.export`):

```
cobib export --bibtex my_bibliography.bib
cobib export --zip my_library.zip
```

### Integrated version control

If you have enabled the git-integration, you can undo and re-apply changes to your database with
(see also `cobib.commands.undo` and `cobib.commands.redo`):

```
cobib undo
cobib redo
```

### Getting help

Each subcommand provides additional help via:

```
cobib <subcommand> --help
```

and you can find extensive information in the online documentation (linked above) and the man-page:

```
man cobib
```

### TUI

Finally, you can also use coBib's TUI for a more interactive experience (see also `cobib.ui.tui`),
by simply typing
```
cobib
```

Here is an example screenshot of the TUI when listing the entries in your database:

![coBib TUI List](https://gitlab.com/cobib/cobib/-/raw/master/html/cobib_tui_list.svg)

And here is an example screenshot for listing search results:

![coBib TUI Search](https://gitlab.com/cobib/cobib/-/raw/master/html/cobib_tui_search.svg)


## Configuration

You can overwrite the default configuration by placing a `config.py` file in `~/.config/cobib/`.
The easiest way to get started with this file is by copying [`example.py`](https://gitlab.com/cobib/cobib/-/blob/master/src/cobib/config/example.py)
or by using:

```
cobib _example_config > ~/.config/cobib/config.py
```

You can then modify it to your liking.

You may also specify a different config file at runtime by using the `-c` or `--config` command line argument or by specifying a custom path in the `COBIB_CONFIG` environment variable.
You can also disable loading of _any_ configuration file be setting this environment variable to one of the following values: `"", 0, "f", "false", "nil", "none"`.

Finally, be sure to take a look at the man page (`man cobib`) and/or the online documentation for more information.


## Plugins

coBib supports the implementation of plugins!
You can find an example plugin in [this folder](./plugin) or read the docs of
`cobib_dummy` (when viewing the hosted documentation online).


## Documentation

coBib's documentation is hosted [here](https://cobib.gitlab.io/cobib/cobib.html).

If you would like to generate a local version during development, you need to clone the source code, and install [`pdoc`](https://github.com/mitmproxy/pdoc) in order to generate it:

```
git clone https://gitlab.com/cobib/cobib.git
cd cobib
pip install pdoc
pdoc -d google -e cobib=https://gitlab.com/cobib/cobib/-/blob/master/src/cobib/ -t html -o docs src/cobib tests
```

You can then browse the documentation from `docs/cobib.html`.


## History

I have started this project when I was looking into alternatives to popular reference managers such as Mendeley,
which has more features than I use on a regular basis and does not allow me to work from the command line which is where I spent most of the time that I spent on the computer.

Hence, I have decided to make it my own task of implementing a simple, yet fast, reference manager.
coBib is written in Python and uses a YAML file to store its bibliography in a plain text format.

### Changelog

You can find the detailed changes throughout coBib's history in [the Changelog](https://gitlab.com/cobib/cobib/-/blob/master/CHANGELOG.md).


## License

coBib is licensed under the [MIT License](https://gitlab.com/cobib/cobib/-/blob/master/LICENSE.txt).

[^1]: References like this one get interpreted by the documentation generator. If you are reading this as the README page, you may find the [online documentation](https://cobib.gitlab.io/cobib/cobib.html) more enjoyable.

[//]: # ( vim: set ft=markdown: )

# Changelog
All notable changes to this project will be documented in this file.

The format is based on [Keep a Changelog](https://keepachangelog.com/),
and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).

## [Unreleased]


## [5.2.3] - 2024-12-15

Pypi: https://pypi.org/project/cobib/5.2.3/

### Fixed

- the interactive handling of notes inside the TUI (#148,!288)


## [5.2.2] - 2024-12-06

Pypi: https://pypi.org/project/cobib/5.2.2/

### **Breaking Change**

- The `config.theme.dark` and `config.theme.design` settings have been replaced
  by the new `config.theme.theme` setting, which can be either the name of one
  of textual's builtin themes, or a custom `textual.theme.Theme` instance
  (#147,!279). Due to how recent these settings have been introduced (as part of
  5.2.0), I am opting for a quick removal in this bugfix release rather than a
  proper version bump (in the sense that they have likely not been adopted, yet)
  and the severness of the bug that this is causing outweighs the needs here.

### Fixed

- compatibility with `textual>=0.86`


## [5.2.1] - 2024-10-30

Pypi: https://pypi.org/project/cobib/5.2.1/

### Fixed

- compatibility with `textual>=0.80`


## [5.2.0] - 2024-10-30

Pypi: https://pypi.org/project/cobib/5.2.0/

### Prelude

With the addition of the new `note` command, the database entry fields called
`"note"` have obtained a special meaning. Use the `lint` command to check
whether your database is affected by this. If it is, you should rename those
fields.

### Added
- new configuration settings to customize the appearance of coBib (!222):
  - `cobib.config.theme.dark`: to specify whether a dark or light theme is used
  - `cobib.config.theme.design`: to customize the colors themselves
  - the following settings to customize the appearance of `rich.Syntax` displays:
    - `cobib.config.theme.syntax.theme`
    - `cobib.config.theme.syntax.background_color`
    - `cobib.config.theme.syntax.line_numbers`
- the `note` command (#139,!206).
  Please refer to its online documentation or the man-page for more details on
  how to use it.
  This new command comes with:
  - the `cobib.config.commands.note.default_filetype` setting
  - the `PreNoteCommand` and `PostNoteCommand` event hooks
- (DEV) the `add_files` argument to the `BaseCommand.git` function
- Python 3.13 is now officially tested and supported
- new configuration settings for the search command (#146,!269)
  - For dealing with skipping/including associated files during searches:
    - `cobib.config.commands.search.skip_files` sets the default
    - `--skip-files` overwrites this at runtime (this is not actually new)
    - `--include-files` overwrites this at runtime (the opposite)
  - For dealing with skipping/including associated notes during searches:
    - `cobib.config.commands.search.skip_notes` sets the default
    - `--skip-notes` overwrites this at runtime (this is not actually new)
    - `--include-notes` overwrites this at runtime (the opposite)

### Changed
- the keybinding to recursively toggle all folds in the TUI's search result view
  was changed from `ENTER` to `BACKSPACE` (!218)
- (DEV) `cobib.ui.components.entry_points` was moved to `cobib.utils.entry_points`
- replaced the custom help screen with textual's new builtin help panel (!240)

### Fixed
- the behavior of the `Home` and `End` keybindings in the TUI's list view (!217)
- gracefully handles Zotero imported entries without a `journal` field (#145)


## [5.1.3] - 2024-08-23

Pypi: https://pypi.org/project/cobib/5.1.3/

### Fixed
- the behavior of the `Home` and `End` keybindings in the TUI's list view (!217)


## [5.1.2] - 2024-06-23

Pypi: https://pypi.org/project/cobib/5.1.2/

### Fixed
- support database locations in nested folders of a git repository (!204)


## [5.1.1] - 2024-05-28

Pypi: https://pypi.org/project/cobib/5.1.1/

### Fixed

- when printing the changelog, do not remove list indents


## [5.1.0] - 2024-05-28

Pypi: https://pypi.org/project/cobib/5.1.0/

### Prelude

Check out my blog post to learn more about the features of this new release:
https://mrossinek.gitlab.io/programming/cobib-becomes-fuzzy/

### Added
- approximate (or fuzzy) filter matching and search functionality (#107,#130,!177)
  - the `list` and `search` commands now support the following features to
    perform approximate filter matching and searching, respectively:
    - LaTeX sequences can be decoded to Unicode characters:
      - using `--decode-latex` from the command-line
      - setting `config.commands.list_.decode_latex = True`
      - setting `config.commands.search.decode_latex = True`
    - Unicode characters can be converted to a close ASCII equivalent:
      - using `--decode-unicode` from the command-line
      - setting `config.commands.list_.decode_unicode = True`
      - setting `config.commands.search.decode_unicode = True`
    - a number of fuzzy errors can be set (this requires the optional dependency
      [`regex`](https://pypi.org/project/regex/) to be installed):
      - using `--fuzziness <int>` from the command-line
      - setting `config.commands.list_.fuzzines` to some integer
      - setting `config.commands.search.fuzzines` to some integer
- (DEV) the following method arguments have been converted to be accepted only
  as keyword arguments:
  - in `cobib.database.Entry.matches`: `ignore_case`
  - in `cobib.database.Entry.search`: `context`, `ignore_case`, and `skip_files`
- (DEV) the return-type of `cobib.database.Entry.search` has been changed


## [5.0.1] - 2024-05-01

Pypi: https://pypi.org/project/cobib/5.0.1/

### Fixed
- the ability to use an empty string as the separator in `config.database.format.label_suffix` (#138)


## [5.0.0] - 2024-04-28

Pypi: https://pypi.org/project/cobib/5.0.0/

### Added

- the ability to add custom `commands`, `importers`, and `parsers` through entry points (#135, !139)
  - (DEV) a dummy plugin show-casing these extensions

### Changed
- the entire `shell_helper` module has been replaced as follows (!139):
  - the following deprecated helper methods were removed without replacement:
    - `_list_commands`
    - `_list_filters`
    - `_list_labels`
  - the following secondary commands have been refactored:
    - `_lint_database` is now `cobib.commands.lint.LintCommand`
    - `_unify_labels` is now `cobib.commands.unify_labels.UnifyLabelsCommand`
    - `_example_config` is now `cobib.config.command.ExampleConfigCommand`
- the interactive disambiguation mechanism during the `add` command now handles
  multiple matching related entries (#121,!168)
  - this includes the ability to `cancel` the disambiguation and entry addition

### Removed

- the previously deprecated `console` attribute of all commands has been removed (!139)
- the previously deprecated `prompt` attribute of all commands has been removed (!139)
- the `cobib.ui.shell_helper` and `cobib.utils.shell_helper` modules have been removed (!139)
- the previously deprecated `--update` argument of the `add` command (!168)
- the previously deprecated `--skip-existing` argument of the `add` command (!168)
- the previously deprecated `LabelSuffix.CAPTIAL` attribute (!168)
- Python 3.8 is no longer supported (!173)


## [4.5.0] - 2024-03-17

Pypi: https://pypi.org/project/cobib/4.5.0/

### Added
- the new `cobib.utils.context.get_active_app` method which returns any running
  textual App and replaces the need for the `cobib.utils.prompt.Prompt.console`
  and `cobib.utils.progress.Progress.console` (which have been removed) (!137)
- `cobib.parsers.YAMLParser.parse` can now also parse strings directly (rather
  than always interpreting the argument as the path to a file) (!137)
- the `review` command (#131,!137).
  Please refer to its online documentation or the man-page for more details on
  how to use it.
- the `cobib.database.Entry.merge` method (!137)

### Changed
- log messages will now be displayed in the `LogPanel` of the TUI (which can be
  toggled with the `z` keybinding) (#132,!133)
- the `cobib.ui.components.prompt` module has been refactored into `cobib.utils.prompt` (!133)

### Deprecated
- the `console` argument to all commands has been deprecated since it no longer
  has any effect (!133)
- the `prompt` argument to all commands has been deprecated since it no longer
  has any effect (!133)
- access to the following `shell_helper` commands will change in the next release:
  - `cobib _lint_database` will become `cobib lint`
  - `cobib _unify_labels` will become `cobib unify_labels`
  - `cobib _example_config` will become `cobib example_config`

### Fixed
- loading a cached database will be bypassed during `_lint_database` (#133)
  - to support this the `bypass_cache` keyword-argument was added to the
    `Database.read` method

### Removed
- official Windows support label. It _might_ work but no guarantees are made (#136)


## [4.4.0] - 2023-12-15

Pypi: https://pypi.org/project/cobib/4.4.0/

### Added
- a primitive caching mechanism to speed up the database loading. This feature
  is enabled by default and will store its cache at `~/.cache/cobib/databases/`.
  You can configure the location via `config.database.cache` or even disable
  caching entirely by changing this setting to `None`. (see also #129 and !108)
- added the `-r/--remove` option to the `modify` command (#128)
  - this can achieve the opposite of `-a/--add` in the sense that it will try to
    remove the specified modification from a list or subtract a number from
    numeric values
  - other field types than lists or numbers are not supported by this option
- added the `-l/--limit` option to the `list` command (#127)
  - exposed the `ListCommand.sort_entries` method in the public API
  - added the `ListCommand.execute_dull` method in the public API
- the `search`, `export`, and `modify` commands now also support sorting and limiting options to be
  passed onto the `list` command (along with the already existing filtering options)
- the `config.tui.tree_folding` setting which allows you to configure the
  default folding state of the tree nodes in the TUI's search result view
- the `ENTER` binding in the TUI's search result view to recursively toggle all
  folds of the current node

### Changed
- when using the TUI you may now use the `:show <label>` command to jump to the
  specified label (#126,!116)
- the `search` command now reports its progress live (!117)

### Fixed
- unblocked the vertical scrollbar of the TUI's list view from the scroll offset


## [4.3.1] - 2023-11-12

Pypi: https://pypi.org/project/cobib/4.3.1/

### **Breaking Change**
Note, that the introduction of the detailed author information parsing in v4.3.0
resulted in possible breaking of a custom `config.database.format.label_default`
setup. This bugfix release is meant to emphasize this breaking change and
updates the documented example in the example configuration file. For the sake
of verbosity, here is the change applied to the example:

- old: `"{unidecode(author.split(' and ')[0].split()[-1])}{year}"`
- new: `"{unidecode(author[0].last)}{year}"`


## [4.3.0] - 2023-11-12

Pypi: https://pypi.org/project/cobib/4.3.0/

### Prelude

#### Detailed Authors
coBib now has the ability to store more detailed author information (see #92 and
!88). This means, that the `author` field of an entry is analyzed in more detail
and coBib will separate out the first and last names as well as name pre- and
suffixes. The new setting `config.database.format.author_format` determines,
whether this detailed information is kept directly in the database (the
`AuthorFormat.YAML` setting; the **new default**) or is only constructed at
runtime and the author field is still simply saved in BibLaTeX form
(`AuthorFormat.BIBLATEX`).

Note, that the `YAML` format also implies, that Unicode characters are allowed
and will *not* be encoded in LaTeX form. This has an effect on how you may need
to format your searches. See also #130 for some more insights on this.

If you have company names or any author name which you want to have treated
verbatim, you can simply wrap it in curly braces (e.g. `{My Company}`).
Refer to the online documentation of `cobib.database.Author` and the above
setting for more details.

#### Wiki
coBib now has a [Wiki](https://gitlab.com/cobib/cobib/-/wikis/home) where we can
gather useful configuration resources and other details which may not make it
into the full documentation.

For example, if you are interested in the tracking more metadata of your
database (as suggested in #123), be sure to check out
[this wiki page](https://gitlab.com/cobib/cobib/-/wikis/Useful-Event-Hooks)!

### Added
- the `-f` short-hand alias for the `--field` argument of the `open` command
- the `opened_entries` attribute of the `OpenCommand` (which is accessible during the `PostOpenCommand` hook)
- the new `git` command to simplify running git operations on the database (#124)
- new bindings for `Home`, `End`, `PageUp`, and `PageDown` in the TUI
- (DEV) added a new `DEPRECATED` logging level which has value 45
- Python 3.12 is now officially tested and supported
- the `config.commands.show.encode_latex` setting
- the `encode_latex` attribute to the `BibtexParser`
- the `config.database.format.verbatim_fields` setting
- the `config.database.format.author_format` setting. The new default behavior
  is to store detailed author information in YAML form.
- the `encode_latex` keyword-argument to the `Entry.stringify` method
- the `Entry.formatted` method. This replaces the `Entry.escape_special_chars` method.

### Changed
- an error will be logged when a file is not found during the `open` command
- the following commands are now treated specially when run via the `:` prompt of the TUI:
  - `init`: will log an error
  - `git`: will log an error
  - `show`: will log a warning

### Deprecated
- The `LabelSuffix.CAPTIAL` value because it was misspelled. Please use `LabelSuffix.CAPITAL` instead.

### Fixed
- non-asynchronous commands triggered via the `:` prompt of the TUI will no longer break it (#125)
- ensure UTF-8 encoding is used for downloaded data (this fixes many odd encounters w.r.t. special characters)
- the spelling of the `LabelSuffix.CAPITAL` value (it used to be spelled `LabelSuffix.CAPTIAL`)

### Removed
- the `Entry.escape_special_chars` method. Use `Entry.formatted` instead.


## [4.2.0] - 2023-08-08

Pypi: https://pypi.org/project/cobib/4.2.0/

### Added
- added the `config.tui.scroll_offset` setting
- added the `--field` command line option to the `open` command
- (DEV) added a new `HINT` logging level which has value 35 and thus allows to
  provide information to the user with a higher priority than `WARNING`
- added the new `config.tui.preset_filters` (#114)
  - preset filters can be selected from the TUI via the `p` key binding
  - the first 9 filters can be selected directly by pressing the respective number
  - pressing `0` resets any applied filter
- implemented special tags (#63,!83)
  - adds new builtin tags which will trigger special highlights of entries: `new`, `high`, `medium`, `low`
  - adds the new `config.theme` settings section for configuring these settings
  - you can also add more special tags via `config.theme.tags.user_tags`
- added the `--skip-files` command line option to the `search` command

### Changed
- unicode symbols in entry labels will now be replaced with ascii ones (#119,#120)
  - this is configured via the `config.database.format.default_label` setting, so if you are using a
    custom value for this, be sure to update your config to make use of this feature
- some user-visible logging messages around label disambiguation have been added (see also #121)
- a warning has been added when the YAML parser encounters identical labels (which normally should
  not occur in the database but if it does, coBib does not really know how to resolve this)
- DOI redirect links are now followed recursively (up to 3 times), improving PDF
  download link detection in the process (#97)

### Deprecated
- the `config.commands.search.highlights` section is deprecated in favor of `config.theme.search`

### Fixed
- retain scroll position in the TUI's list view


## [4.1.0] - 2023-06-11

Pypi: https://pypi.org/project/cobib/4.1.0/

### Added
- added the following settings which specify whether or not to preserve
  associated files during the respective commands being run:
  - `config.commands.delete.preserve_files`
  - `config.commands.edit.preserve_files`
  - `config.commands.modify.preserve_files`
- added a confirmation prompt before deleting an entry (#110)
  - this prompt can be disabled by setting `config.commands.delete.confirm` to `False`
- added the `--no-ignore-case` (`-I` for short) command line options to the
  `list` and `search` command (#116)
- added the `--no-preserve-files` command line options to the `delete`, `edit`
  and `modify` command (#116)
- added the `config.commands.search.context` setting which configures the
  default number of context lines to be provided for search query matches
- added more options to configure the automatic download behavior:
  - the new `config.commands.add.skip_download` setting
  - the new `--force-download` option of the `add` command
  - the new `config.commands.import_.skip_download` setting
  - the new `--force-download` option of the `import` command
- the user is asked for confirmation when quitting the TUI (!71)

### Changed
- refactored the TUI by leveraging textual's `Screen` concept (#111,!71)
  - this means the TUI will look slightly different but no real functional change has occurred
  - the view of an `Entry` can now be scrolled when the output exceeds the available space
- switched from the `BeautifulSoup` HTML parser to `lxml`
  - this is supposed to give more accurate results but adds an extra dependency

### Deprecated
- The following shell helpers are no longer used with the zsh completion being
  removed. Thus, these methods will be removed in the future:
  - `cobib _list_commands`
  - `cobib _list_filters`
  - `cobib _list_labels`
  - If you see warnings because of this while you are using the CLI, you
    probably still have the (now removed) zsh completion script installed. You
    should remove the `_cobib` file which will be located in one of the
    directories listed in your `$FPATH` environment variable.

### Fixed
- the proper pre-population of the TUI prompt during the sorting action (#117)
- preserves the value of `config.commands.list_.default_columns` and
  properly removes a field if it is no longer sorted by in the TUI (#117)
- properly updates the list of entries in the TUI after changing the database contents;
  for example via `add` (#113) or `delete` (#113) or `edit` (#118)
- an issue where file-accessing operations performed on a newly added entry within
  the same TUI session would fail because the path would not be iterated correctly
- the live updating of the download progress bar inside the TUI (#112)

### Removed
- the crude and very slow zsh completion script


## [4.0.0] - 2023-05-20

Pypi: https://pypi.org/project/cobib/4.0.0/

### **Breaking Changes**
- Configuration settings can no longer be set by item access and instead must
  use attribute syntax. For example you need to change:
  ```python
  config["database"]["git"] = True
  ```
  to
  ```python
  config.database.git = True
  ```
  - the `config.commands.list` section had to be renamed to `config.commands.list_`
  - the `config.tui` section has been entirely removed
- The `cobib.commands.list` module was moved to `cobib.commands.list_`.
- The function signature of all command- and importer-related events has changed!
  For more details please refer to the
  [online documentation](https://cobib.gitlab.io/cobib/cobib/config/event.html).

### Added
- Python 3.11 is now officially tested and supported
- Full rewrite of all commands to use `rich` for a nicer CLI (#78,!51)
- Full rewrite of the TUI based on `textual` (#78,!51)
- the `--disambiguation` argument of the `add` command (#99,!58)
- the `--ignore-case` argument of the `list` command (#105)
  - this also comes with the new `config.commands.list_.ignore_case` setting
- the `search` command now accepts multiple query strings at once which will be
  searched over independently (#106)

### Changed
- the new default value of `config.parsers.yaml.use_c_lib_yaml` is now `True` as announced in version [3.4.0]
- refactored the entire config as a dataclass (!63)
  - this implies that settings can only be set via attributes
  - but as a benefit the maintainability and documentation have improved significantly
- The function signature of all command-related events has changed! Please refer to the
  [online documentation](https://cobib.gitlab.io/cobib/cobib/config/event.html)
  for more details. (!63)
- The function signature of all importer-related events has changed! Please refer to the
  [online documentation](https://cobib.gitlab.io/cobib/cobib/config/event.html)
  for more details. (!66)
- the API of the `cobib.commands` and `cobib.importers` module has been improved (!64)
  - this should not have any end-user facing effects
- the `cobib.commands.list` module was moved to `cobib.commands.list_`

### Deprecated
- the `--update` argument of the `add` command is deprecated in favor of `--disambiguation update`
- the `--skip-existing` argument of the `add` command is deprecated in favor of `--disambiguation keep`

### Fixed
- the detection whether an entry already exists broke when label disambiguation was added in [3.3.0]
  and is now fixed by means of an interactive prompt during the `add` command

### Removed
- the warning triggered upon setting `config.database.format.month` which got removed in [3.1.0]
- Python 3.7 is no longer supported


## [3.5.5] - 2023-04-11

Pypi: https://pypi.org/project/cobib/3.5.5/

### Fixed
- opening of non-list type fields (#100)


## [3.5.4] - 2022-12-26

Pypi: https://pypi.org/project/cobib/3.5.4/

### Fixed
- missing files encountered during searching will log warnings gracefully instead of harshly
- handle newline characters in the TUI (#98)


## [3.5.3] - 2022-11-16

Pypi: https://pypi.org/project/cobib/3.5.3/

### Fixed
- incorrect author concatenation in ISBN Parser
- using the disambiguated label for the names of downloaded files (#96)


## [3.5.2] - 2022-05-22

Pypi: https://pypi.org/project/cobib/3.5.2/

### Fixed
- run TUI on BSD platforms (!52)


## [3.5.1] - 2022-04-25

Pypi: https://pypi.org/project/cobib/3.5.1/

### Fixed
- safely check cache existence before attempting to write (#94)


## [3.5.0] - 2022-01-13

Pypi: https://pypi.org/project/cobib/3.5.0/

### **News:** coBib v4.0 will come with a new UI!
The plan is to switch to [rich][rich] and [textual][textual] instead of the current curses TUI.
This will open up some great possibilities for a much more modern UI.

However, this change will require some *major* refactoring including breaking changes of the API
and some of the user configuration options. It will also be a rather drastic change in style.
Thus, I will attempt to support v3.5 with bugfix releases until 1.1.2023

It will likely take a few months until v4.0 gets released but I am starting development on it now.
You can follow the progress here: <https://gitlab.com/cobib/cobib/-/issues/78>

[rich]: https://github.com/Textualize/rich
[textual]: https://github.com/Textualize/textual

### Added
- the configuration loading can be disabled via the environment variable `COBIB_CONFIG`
    - values which disable the loading entirely are: `"", 0, f, false, nil, none`
    - you can also specify a custom path to a configuration file in this variable

### Removed
- the `INI`-style configuration got fully removed (as deprecated in [3.0.0] - 2021-04-10)


## [3.4.0] - 2021-12-01

Pypi: https://pypi.org/project/cobib/3.4.0/

- coBib now requires the `requests-oauthlib` package
    - technically this is an optional dependency for now, but it will likely become a requirement soon

### Added
- the new `config.parsers.yaml.use_c_lib_yaml` setting which significantly improves loading performance
    - this setting will change its default value to `True` in version 4.0.0
* the `Import` command (#86,!49):
    - can be used to import libraries from other bibliography managers (see next bullet)
    - see `cobib import --help` for more information
- the `cobib.importers` module:
    - provides importer classes for various other bibliography managers
    - these get registered at runtime under the `cobib import` command
    - this release provides the `--zotero` importer
    - see `cobib import --zotero -- --help` for more information
- the `config.logging.cache` option, specifying the location of a simple json cache
- the `config.commands.open.fields` option, specifying the names of the data fields which are checked for openable URLs (#89)

### Changed
- the `PreFileDownload` event now takes an additional argument: `headers: Optional[Dict[str, str]]`

### Fixed
- downloaded file names will not duplicate the `.pdf` suffix


## [3.3.2] - 2021-11-17

Pypi: https://pypi.org/project/cobib/3.3.2/

### Fixed
- re-enable the terminal keypad during resize event
    - this ensures proper arrow-key behavior after returning from an external editor
- clear screen after closing TUI to remove all screen artifacts

### Security
- remove warning when using the DOI parser because the upstream issue related to #91 got fixed


## [3.3.1] - 2021-10-19

Pypi: https://pypi.org/project/cobib/3.3.1/

### Fixed
- erroneous label disambiguation of Entry labels which already conform with `config.database.format.default_label_format` (#87,!47)
- do not add empty file list when unifying database

### Security
- log warning when using the DOI parser because of (#91)


## [3.3.0] - 2021-10-04

Pypi: https://pypi.org/project/cobib/3.3.0/

### Added
- print Changelog since the last run version (cached in `config.logging.version`) (#82)
- the `AddCommand` now has a new `--update` option (#79,!41)
- the `_lint_database` utility now takes the `--format` argument, which automatically resolves all lint messages (#81,!42)
- the new `URLParser` (available via `cobib add --url <URL>` (#84,!44)
    - it attempts importing from a plain URL
    - simultaneously the arXiv, DOI, and ISBN parsers now also support URL containing a matching identifier directly
- the `--dry` argument of the `ModifyCommand` to prevent errors during large bulk modifications
* the `config.database.format.label_default` and `config.database.format.label_suffix` options (#85,!45)
    - labels will automatically be formatted according to the default option
    - if labels conflict with existing ones, the suffix option will be used for disambiguation
    - the `AddCommand` has a new `--skip-existing` option which disables automatic label disambiguation
    - use `cobib _unify_labels --apply` to unify all labels in your database
- subscribable events (#71,!46)
    - allows registering of hooks to be executed in certain situation
    - more information is provided at the [online documentation](https://cobib.gitlab.io/cobib/cobib/config/event.html)

### Changed
- when an unknown variable is encountered in the modification of the `modify` command it falls back to an empty string rather than the name of the attempted variable

### Removed
- the `-s` option of the `AddCommand` is no longer available. You need to write out `--skip-download`
- the `ID` filter argument on the `list` command (deprecated in v3.2.0 in favor of the `label` filter)


## [3.2.1] - 2021-07-15

Pypi: https://pypi.org/project/cobib/3.2.1/

### Fixed
- when adding multiple entries at once, continue adding after encountering a single duplicate (#83)


## [3.2.0] - 2021-06-26

Pypi: https://pypi.org/project/cobib/3.2.0/

### Added
- basic auto-downloading of PDF files for arXiv IDs and configured DOIs (#25,!35,!39):
    - the default download location can be configured via `config.utils.file_downloader.default_location`
    - on a per addition basis, this default can be overwritten via the `--path` keyword option of the `AddCommand`
    - if a file already exists in this location of the file system, the download will be skipped
    - download for DOI entries must configure URL patterns in `config.utils.file_downloader.url_map`
    - on a per addition basis, the entire automatic download can be skipped with `--skip-download`
- automatic journal abbreviations (#62,!36):
    - users can configure a list of journal abbreviations via `config.utils.journal_abbreviations`
    - if present, coBib will store the journal in its elongated form
    - a user can then automatically convert to abbreviated forms during exporting (see the new `--abbreviate` and `--dotless` arguments)
- Tentative Windows support by disabling the TUI
- a `--preserve-files` argument was added to the following commands. Unless it is given, these will delete/rename associated files of affected entries:
    - `DeleteCommand`
    - `EditCommand`
    - `ModifyCommand`

### Changed
- the `modifications` of a `ModifyCommand` get interpreted as f-strings (#77,!37):
    - available variables are the entry's label and data fields
- any `ListCommand` filter gets interpreted as a regex pattern (#76)

### Deprecated
- the `ID` filter argument was fully replaced by `label`, unifying the CLI API. Support will be dropped in v3.3.0

### Fixed
- Removed (most) duplication of log messages


## [3.1.1] - 2021-05-25

Pypi: https://pypi.org/project/cobib/3.1.1/

### Fixed
- Pypi package metadata


## [3.1.0] - 2021-05-24

Pypi: https://pypi.org/project/cobib/3.1.0/

### Added
- the YAML format of the database has been extended to support the following: (#55)
    - numbers can be stored as integers
    - the `ID` field is no longer required and will be properly inferred from the label
    - the following fields can be stored as lists: `file`, `tags`, `url`
- three new configuration options were added to complement the above list format options:
    - `config.database.stringify.list_separator.file`
    - `config.database.stringify.list_separator.tags`
    - `config.database.stringify.list_separator.url`
- the `_lint_database` shell utility has been added which can be used to detect possible improvements for the database
- the append-mode of the `ModifyCommand` was implemented (#60):
    - specifying `-a`/`--add` will add the modification value to the field of the entries rather than overwrite it
    - this can be used for string or list concatenation and even number addition on numeric fields

### Changed
- use file paths relative to user-home (achieved by replacing `os.path` with `pathlib`) (#69)
- the shell helper `_list_tags` has been renamed to `_list_labels`
- (DEV): the `logging` and `zsh_helper` modules have been relocated to the `cobib.utils` package
- `+` symbols will no longer be stripped from tags (this was a left-over artifact from pre-v1.0.0)

### Deprecated
- the `config.database.format.month` setting is deprecated in favor of proper three-letter code encoding to support common citation style macros (!34)

### Fixed
- renaming the label during the `edit` command does not leave the previous label entry behind:
    - a followup also ensured that renaming entries happens in-place (#75)
- the sorting of the `list` command


## [3.0.0] - 2021-04-10

Pypi: https://pypi.org/project/cobib/3.0.0/

- From now on, `coBib` is the official way of spelling!

### Added
- coBib's documentation is now generated by [`pdoc`](https://pdoc.dev/) and hosted at https://cobib.gitlab.io/cobib/cobib.html
- (DEV): the `cobib.database.Database`-Singleton has been added to centrally manage the bibliographic runtime data (!28)
- the new option `config.database.format.suppress_latex_warnings`
- the new option `config.commands.edit.editor` which takes precedence over the `$EDITOR` variable

### Changed
- the `INI`-style configuration is replaced with a `Python`-based configuration (#54,!25)
    - for guidance on how to migrate an existing configuration please read https://mrossinek.gitlab.io/programming/cobibs-new-configuration/
- (DEV): `cobib.parser.Entry` has been moved to `cobib.database.Entry`
- the `cobib.parsers` module has been extracted (prep for #49, !28)
- the filenames of the associated files are preserved when exporting to a Zip file
- when trying to add an entry with an existing label, the database is not written to and a warning is raised early
- month conversion and special character escaping are only done upon saving entries to the database
- the path to the default logfile can now be configured via `config.logging.logfile` and defaults to `~/.cache/cobib/cobib.log`

### Deprecated
- the `INI`-style configuration is deprecated
    - new configuration options will not be added to this style
    - only bugs which fully break usability will be fixed with regards to this configuration style
    - legacy-support will be fully removed on 1.1.2022

### Fixed
- the ZSH helper utilities now respect the `-c`, `-l`, and `-v` command line options
- the `RedoCommand` should only revert a previously `UndoCommand` operation (#65)
- the `SearchCommand` got some contexts improvements and correctly splits grep results
- unwrapping does not crash the TUI if the cursor was multiple lines below the new buffer height
- line continuation guides are not swallowed by current line highlighting
- ensure the TUI's top line does not become negative
- the TUI's handler for resizing events
- `JSONDecodeError`s thrown by the `ISBNParser` are caught and handled gracefully

### Removed
- the functions `read_database()` and `write_database()` are no longer available (!28)


## [2.6.1] - 2021-02-05

Pypi: https://pypi.org/project/cobib/2.6.1/

Note: [2.6.1] was not released from the `master`-branch, which resulted in a non-linear development.

### Changed
- `init --git` will not initialize a repository unless git has configured both, `name` and `email`

### Fixed
- TUI no longer crashes when aborting to quit (#64)


## [2.6.0] - 2020-12-31

Pypi: https://pypi.org/project/cobib/2.6.0/

### Added
- Git integration (#44, !20):
    - will automatically track any changes done to the database file with git
    - must be enabled by setting the `DATABASE/git` option to `True` **and** running `cobib init --git`
    - Note, that you must have at least set a `name` and `email` in the git config!
- Undo/Redo commands to operate on git history of the database (#59,!23)
    - for obvious reasons these commands require the Git integration (see above) to be enabled
- the `Prompt` command inside of the TUI:
    - allows executing arbitrary CoBib CLI commands
    - the default key binding is `:`
- the `Modify` command: (#60,!24)
    - allows bulk modification of multiple entries in a `<field>:<value>` format
    - for now, this will **always** overwrite the field with the new value!
    - an extension to appending values is planned for a later release
    - the set of entries to be modified can be specified just like with the `export` command through `list`-command filters or manual selection (by setting the `--selection` flag)

### Changed
- the viewport history is preserved correctly (#21,!22)
    - this allows performing a search while showing an entry and reverts back to the correct view after quitting the search
    - the changes mainly involved refactoring of the `cobib/tui` module
- the **positional** argument of the `modify` and `search` has been renamed internally from `list_arg` to `filter`
    - this should not have any visible effect to an end-user but may be relevant to developers

### Fixed
- gracefully handle multiple terminal sizing issues with regards to popups (#58)
- catch messages on `stdout` during deletion from TUI
- added missing help strings to the TUI help menu

### Removed
- The `--force` argument to the `init` command has now been removed (after being deprecated in v2.5.0).


## [2.5.0] - 2020-12-08

Pypi: https://pypi.org/project/cobib/2.5.0/

### Added
- support for multiple associated files (#42,!19)
- interactive menu when opening an entry with multiple associated files (!19)

### Deprecated
- The `--force` argument to the `init` command has been deprecated. I don't think there is any
  benefit to providing the user the option to nuke their database file from the CLI. Instead,
  they can simply edit the file manually.

### Fixed
- always store years as strings to be compatible with bibtexparser
- handle invalid arXiv or DOI IDs gracefully (#57)


## [2.4.1] - 2020-11-01

Pypi: https://pypi.org/project/cobib/2.4.1/

### Fixed
- ISBN parser was missing the ENTRYTYPE and did not use strings for number fields
- the ISBN parser can now handle empty entries (#53)
- the TUI will not crash on stdout/stderr messages exceeding the window width
- the TUI respects quoted strings in the prompt handler (#52)


## [2.4.0] - 2020-10-14

Pypi: https://pypi.org/project/cobib/2.4.0/

### Added
- the `FORMAT/default_entry_type` option used for manual entry addition
- a **manual** insertion mode available through `edit -a new_label` and `add -l new_label`
- a ISBN-based parser for adding new entries (#45)
- the TUI-based `select` command (and corresponding settings) (#8,!18)
- the `--selection` argument for the `export` command (!18)

### Changed
- TUI color highlighting is now prioritized (!17)

### Fixed
- support URLs in file field during `open` command (#47)
- the TUI no longer crashes when encountering long prompt inputs (#48)
- the `edit` command can handle labels which start with common substrings (#46)
- support multiple ANSI colors on a single line (#50)


## [2.3.4] - 2020-09-14

Pypi: https://pypi.org/project/cobib/2.3.4/

### Fixed
- another AUR package installation error


## [2.3.3] - 2020-09-14

Pypi: https://pypi.org/project/cobib/2.3.3/

### Fixed
- AUR package installation error

## [2.3.2] - 2020-09-10

Pypi: https://pypi.org/project/cobib/2.3.2/

### Added
- option to default to case-insensitive searching (`DATABASE/search_ignore_case`)

### Changed
- clearing the prompt, aborts the command execution

### Fixed
- search command correctly handles missing arguments in TUI (#43)

## [2.3.1] - 2020-09-10

Pypi: https://pypi.org/project/cobib/2.3.1/

### Fixed
- faulty Pypi package

## [2.3.0] - 2020-09-10

Pypi: https://pypi.org/project/cobib/2.3.0/

### Added
- Logging functionality has been added. The verbosity level can be controlled via `-v` (INFO) and `-vv` (DEBUG).
  As soon as the TUI starts, all logging output is redirected to `/tmp/cobib.log`.
- Command line argument `-l` or `--logfile` can be used to specify the output path of the log. This will overwrite the `/tmp/cobib.log` location.
- the `TUI/scroll_offset` setting was added. It defaults to `3` and behaves similar to Vim's `scrolloff` setting.
- Configuration validation has been added. This extends the logging functionality to support more runtime debug information.
- popup window support: stdout and stderr messages are presented in a popup similarly to the help window

### Changed
- `-v` command line argument now refers to `--verbose` rather than `--version`
- Performance of the `add` command has been improved by not refreshing the database when outside of the TUI.

### Fixed
- bug when resizing causes the window width to become greater than the buffer width (#39)
- do not escape special characters in labels (#40)
- avoid special character encoding in file paths

## [2.2.2] - 2020-08-13

Pypi: https://pypi.org/project/cobib/2.2.2/

### Fixed
- current line highlight if viewport is wider than buffer was not correctly reset
- the `ignore_non_standard_types` setting had no effect

## [2.2.1] - 2020-08-10

Pypi: https://pypi.org/project/cobib/2.2.1/

### Changed
- when wrapping the TUI lines, indent until after the label column (#26)
- renamed `default.ini` to `example.ini` in the documentation folder

### Fixed
- current line highlight after viewport width was not correctly reset
- correctly convert boolean configuration options (#34)
- fix crash of TUI in wrap command when viewport is empty (#37)
- default configuration settings are managed centrally and consistently (#35)


## [2.2.0] - 2020-07-12

Pypi: https://pypi.org/project/cobib/2.2.0/

### Added
- allow configuring the program used to `open` associated files
- prompt user before actually quitting CoBib (#33)
- implements the Search command (#7, !12)

### Fixed
- the default value of the `open` command was not set correctly


## [2.1.0] - 2020-06-14

Pypi: https://pypi.org/project/cobib/2.1.0/

### Added
- added half- and full-page scrolling (#22)

### Changed
- importing from `bibtex` data defaults to **not** ignored non-standard entry types (#28)
- suppress LaTex encoding warnings except when adding entries (#29)
- `Search` and `Select` print warnings to the prompt while not implemented

### Fixed
- `init` command ensures directory of database file exists
- remove window artifacts after `help` menu is closed (#20)
- configuration file detection was missing a user home expansion (#31)

## [2.0.0] - 2020-06-06

Pypi: https://pypi.org/project/cobib/2.0.0/

### Fixed
- respect sort order reversing and filter `XOR`ing from the TUI (#18)
- `edit` command on Mac OS (#19)

### Changed
- made `init` command safe against database overwriting
- TUI: list entries in reverse order by default (config: TUI/reverse_order)


## [2.0.0b4] - 2020-05-16

Pypi: https://pypi.org/project/cobib/2.0.0b4/

### Fixed
- reset viewport position when updating buffer


## [2.0.0b3] - 2020-05-16

Pypi: https://pypi.org/project/cobib/2.0.0b3/

### Fixed
- properly assert valid current line number


## [2.0.0b2] - 2020-05-16

Pypi: https://pypi.org/project/cobib/2.0.0b2/

### Fixed
- fixed TUI startup


## [2.0.0b1] - 2020-05-16

**Warning**: do NOT use! The TUI is broken in this release!

Pypi: https://pypi.org/project/cobib/2.0.0b1/

### Fixed
- TUI does not crash when opening an entry with no associated file
- correctly reset current line positions after filtering and editing


## [2.0.0b0] - 2020-04-28

Pypi: https://pypi.org/project/cobib/2.0.0b0/

### Changed
- _internal_: refactored the config into a class
- centralized the database handling to improve performance (#12,!9)

### Fixed
- the `Show` command does not break after scrolling the viewport (#13)


## [2.0.0a2] - 2020-04-27

Pypi: https://pypi.org/project/cobib/2.0.0a2/

### Added
- user configuration options for:
    - TUI colors
    - TUI key bindings
    - TUI default list arguments
- help window highlighting

### Changed
- sorting and filtering commands remain persistent when updating the list view


## [2.0.0a1] - 2020-04-23

Pypi: https://pypi.org/project/cobib/2.0.0a1/

### Added
- Added a basic curses-based TUI (#5,!7)

### Changed
- _internal_: refactored commands into separate module


## [1.1.0] - 2020-03-28

Pypi: https://pypi.org/project/cobib/1.1.0/

### Added
- add `FORMAT.month` configuration option to configure the default type for
    month fields (defaults to `int`) (#3,!4)
- escape special LaTeX characters (#2,!5)

### Fixed
- `list` no longer breaks with a `KeyError` when a queried field does not exist
    in any bibliography entry (!2)
- `--label` can now correctly overwrite the ID (#4,!3)

### Changed
- `set_config()` and global `CONFIG` exported to separate module


## [1.0.2] - 2020-01-12

Pypi: https://pypi.org/project/cobib/1.0.2/

Note: this removal is not seen as a MINOR version bump because this is
      essentially a long out-standing bug fix

### Removed/Fixed
- doi extraction from pdf files (476efc4f)
  - also removes the ability to add entries directly via pdf files


## [1.0.1] - 2020-01-12

Pypi: https://pypi.org/project/cobib/1.0.1/

### Changed
- metadata for pypi


## [1.0.0] - 2020-01-12

First MAJOR release. Also available via Pypi: https://pypi.org/project/cobib/1.0.0/
The project was renamed from `CReMa` to `CoBib`

### Added
- allow sorting the list output (2a5a94f1)
- crude and slow (!!!) zsh completion (9f28f441)
- support Darwin's `open` command

### Changed
- suppress list output when exporting
- add used tags to columns when listing
- sort YAML database entries by keys (d2af42d2)

### Fixed
- fixed arxiv parser (7ce3726f)


## [0.2] - 2019-09-02

Note: this release was not marked MAJOR because this is still a WIP and early
      alpha release.

### Added
- complete rewrite to use a plain-text `yaml` database instead of `sqlite3` !1

### Removed
- `sqlite3` database


## [0.1] - 2019-04-29

### Added
- initial version with a basic `sqlite3`-based database


[Unreleased]: https://gitlab.com/cobib/cobib/-/compare/v5.2.3...master
[5.2.3]: https://gitlab.com/cobib/cobib/-/tags/v5.2.3
[5.2.2]: https://gitlab.com/cobib/cobib/-/tags/v5.2.2
[5.2.1]: https://gitlab.com/cobib/cobib/-/tags/v5.2.1
[5.2.0]: https://gitlab.com/cobib/cobib/-/tags/v5.2.0
[5.1.3]: https://gitlab.com/cobib/cobib/-/tags/v5.1.3
[5.1.2]: https://gitlab.com/cobib/cobib/-/tags/v5.1.2
[5.1.1]: https://gitlab.com/cobib/cobib/-/tags/v5.1.1
[5.1.0]: https://gitlab.com/cobib/cobib/-/tags/v5.1.0
[5.0.1]: https://gitlab.com/cobib/cobib/-/tags/v5.0.1
[5.0.0]: https://gitlab.com/cobib/cobib/-/tags/v5.0.0
[4.5.0]: https://gitlab.com/cobib/cobib/-/tags/v4.5.0
[4.4.0]: https://gitlab.com/cobib/cobib/-/tags/v4.4.0
[4.3.1]: https://gitlab.com/cobib/cobib/-/tags/v4.3.1
[4.3.0]: https://gitlab.com/cobib/cobib/-/tags/v4.3.0
[4.2.0]: https://gitlab.com/cobib/cobib/-/tags/v4.2.0
[4.1.0]: https://gitlab.com/cobib/cobib/-/tags/v4.1.0
[4.0.0]: https://gitlab.com/cobib/cobib/-/tags/v4.0.0
[3.5.5]: https://gitlab.com/cobib/cobib/-/tags/v3.5.5
[3.5.4]: https://gitlab.com/cobib/cobib/-/tags/v3.5.4
[3.5.3]: https://gitlab.com/cobib/cobib/-/tags/v3.5.3
[3.5.2]: https://gitlab.com/cobib/cobib/-/tags/v3.5.2
[3.5.1]: https://gitlab.com/cobib/cobib/-/tags/v3.5.1
[3.5.0]: https://gitlab.com/cobib/cobib/-/tags/v3.5.0
[3.4.0]: https://gitlab.com/cobib/cobib/-/tags/v3.4.0
[3.3.2]: https://gitlab.com/cobib/cobib/-/tags/v3.3.2
[3.3.1]: https://gitlab.com/cobib/cobib/-/tags/v3.3.1
[3.3.0]: https://gitlab.com/cobib/cobib/-/tags/v3.3.0
[3.2.1]: https://gitlab.com/cobib/cobib/-/tags/v3.2.1
[3.2.0]: https://gitlab.com/cobib/cobib/-/tags/v3.2.0
[3.1.1]: https://gitlab.com/cobib/cobib/-/tags/v3.1.1
[3.1.0]: https://gitlab.com/cobib/cobib/-/tags/v3.1.0
[3.0.0]: https://gitlab.com/cobib/cobib/-/tags/v3.0.0
[2.6.1]: https://gitlab.com/cobib/cobib/-/tags/v2.6.1
[2.6.0]: https://gitlab.com/cobib/cobib/-/tags/v2.6.0
[2.5.0]: https://gitlab.com/cobib/cobib/-/tags/v2.5.0
[2.4.1]: https://gitlab.com/cobib/cobib/-/tags/v2.4.1
[2.4.0]: https://gitlab.com/cobib/cobib/-/tags/v2.4.0
[2.3.4]: https://gitlab.com/cobib/cobib/-/tags/v2.3.4
[2.3.3]: https://gitlab.com/cobib/cobib/-/tags/v2.3.3
[2.3.2]: https://gitlab.com/cobib/cobib/-/tags/v2.3.2
[2.3.1]: https://gitlab.com/cobib/cobib/-/tags/v2.3.1
[2.3.0]: https://gitlab.com/cobib/cobib/-/tags/v2.3.0
[2.2.2]: https://gitlab.com/cobib/cobib/-/tags/v2.2.2
[2.2.1]: https://gitlab.com/cobib/cobib/-/tags/v2.2.1
[2.2.0]: https://gitlab.com/cobib/cobib/-/tags/v2.2.0
[2.1.0]: https://gitlab.com/cobib/cobib/-/tags/v2.1.0
[2.0.0]: https://gitlab.com/cobib/cobib/-/tags/v2.0.0
[2.0.0b4]: https://gitlab.com/cobib/cobib/-/tags/v2.0.0b4
[2.0.0b3]: https://gitlab.com/cobib/cobib/-/tags/v2.0.0b3
[2.0.0b2]: https://gitlab.com/cobib/cobib/-/tags/v2.0.0b2
[2.0.0b1]: https://gitlab.com/cobib/cobib/-/tags/v2.0.0b1
[2.0.0b0]: https://gitlab.com/cobib/cobib/-/tags/v2.0.0b0
[2.0.0a2]: https://gitlab.com/cobib/cobib/-/tags/v2.0.0a2
[2.0.0a1]: https://gitlab.com/cobib/cobib/-/tags/v2.0.0a1
[1.1.0]: https://gitlab.com/cobib/cobib/-/tags/v1.1.0
[1.0.2]: https://gitlab.com/cobib/cobib/-/tags/v1.0.2
[1.0.1]: https://gitlab.com/cobib/cobib/-/tags/v1.0.1
[1.0.0]: https://gitlab.com/cobib/cobib/-/tags/v1.0.0
[0.2]: https://gitlab.com/cobib/cobib/-/tags/v0.2
[0.1]: https://gitlab.com/cobib/cobib/-/tags/v0.1

            

Raw data

            {
    "_id": null,
    "home_page": null,
    "name": "cobib",
    "maintainer": null,
    "docs_url": null,
    "requires_python": ">=3.9",
    "maintainer_email": null,
    "keywords": "reference-manager, citation-manager, bibliography, cli, tui, command-line, terminal, console, bibtex, doi, arxiv, isbn",
    "author": null,
    "author_email": "Max Rossmannek <max@rossmannek.de>",
    "download_url": "https://files.pythonhosted.org/packages/72/bd/9149c71bf3b2ce42dc59302893db2b0cefbff2f5e52fe7b08ec051e330d4/cobib-5.2.3.tar.gz",
    "platform": null,
    "description": "[![coBib](https://gitlab.com/cobib/cobib/-/raw/master/logo/cobib_logo.svg)](https://cobib.gitlab.io/cobib/cobib.html)\n\n# coBib\n\n[![pipeline](https://gitlab.com/cobib/cobib/badges/master/pipeline.svg)](https://gitlab.com/cobib/cobib/-/pipelines)\n[![coverage](https://gitlab.com/cobib/cobib/badges/master/coverage.svg)](https://gitlab.com/cobib/cobib/-/graphs/master/charts)\n[![PyPI](https://img.shields.io/pypi/v/cobib)](https://pypi.org/project/cobib/)\n\ncoBib is a simple, command-line based bibliography management tool.\nIt is the result of the need for an easy-to-use alternative to full-blown reference managers like Mendeley or Zotero.\nAs such it follows some basic design goals:\n\n* **plain-text database**: which means you get full access and control over the database.\n* **git-integration**: as a benefit of the above, you can keep track of your database through version control.\n* **centralized database, location-independent library**: this means, that coBib *only* manages the\n  database file in a centralized fashion but allows you to spread the actual contents of your\n  library across the entire file system (this is the major different to\n  [papis](https://papis.readthedocs.io/en/latest/library_structure.html)).\n* **command-line and TUI support**: all features are available through the command-line as well as a\n  [textual](https://textual.textualize.io/)-based TUI\n\n\n## Installation\n\nFor all common purposes you can install coBib via `pip`:\n\n```\npip install cobib\n```\n\nNote: Use `pip3` if you still have Python 2 installed.\n\nIf you would also like to install the man-page, you need to download the source\ncode and do the following:\n\n```\ngit clone https://gitlab.com/cobib/cobib\ncd cobib\nmake install_extras\n```\n\n### Arch Linux\n\ncoBib is packaged in the AUR.\n* [cobib](https://aur.archlinux.org/packages/cobib/)\n* [cobib-git](https://aur.archlinux.org/packages/cobib-git/)\n\n### Windows\n\ncoBib _might_ work on Windows as is, but it is not being tested so no guarantees are given.\nIf you are using Windows 10 or later and are running into issues, you should be able to install and\nuse coBib's full functionality within the Linux subsystem.\n\n\n## Getting started\n\nTo get started, you must initialize the database:\n\n```\ncobib init\n```\n\nIf you would like to enable the git-integration, you should run:\n\n```\ncobib init --git\n```\n\n*and* enable `config.database.git` (see also [configuration](#configuration)).\n\nBe sure to check out my [Quickstart blog post](https://mrossinek.gitlab.io/programming/introducing-cobib/)\nfor a more guided introduction compared to the following section!\n\n### Importing your library\n\ncoBib provides an `import` command through which you can easily import your library\nfrom another bibliography manager. For more details check out:\n\n```\ncobib import --help\n```\n\nSo far, coBib knows how to import your library from Zotero by simply running:\n\n```\ncobib import --zotero\n```\n\nCheck out the following command, the man page or the online documentation for more details:\n\n```\ncobib import --zotero -- --help\n```\n\n## Usage\n\n### Adding new entries\n\nYou can now add new entries to your database (see also `cobib.commands.add`[^1]):\n\n```\ncobib add --bibtex some_biblatex_file.bib\ncobib add --arxiv <some arXiv ID>\ncobib add --doi <some DOI>\ncobib add --isbn <some ISBN>\n```\n\n**Note**: when adding data from a `.bib` file, make sure that it is in the Bib**La**Tex format!\n\n### Viewing your database and entries\n\nYou can view the contents of your database with (see also `cobib.commands.list_`):\n\n```\ncobib list\n```\n\nYou can show a specific entry with (see also `cobib.commands.show`):\n\n```\ncobib show <some entry label>\n```\n\nYou can open an associated file of an entry with (see also `cobib.commands.open`):\n\n```\ncobib open <some entry label>\n```\n\nYou can even search through your database with (see also `cobib.commands.search`):\n\n```\ncobib search \"some text\"\n```\n\n### Editing your database\n\nYou can delete an entry with (see also `cobib.commands.delete`):\n\n```\ncobib delete <some entry label>\n```\n\nYou can edit an entry manually with (see also `cobib.commands.edit`):\n\n```\ncobib edit <some entry label>\n```\n\nYou can also apply simple modifications to multiple entries at once with (see also\n`cobib.commands.modify`):\n\n```\ncobib modify tags:private -- <some entry label> <another entry label> ...\n```\n\n### Exporting your database\n\nYou can export your database with (see also `cobib.commands.export`):\n\n```\ncobib export --bibtex my_bibliography.bib\ncobib export --zip my_library.zip\n```\n\n### Integrated version control\n\nIf you have enabled the git-integration, you can undo and re-apply changes to your database with\n(see also `cobib.commands.undo` and `cobib.commands.redo`):\n\n```\ncobib undo\ncobib redo\n```\n\n### Getting help\n\nEach subcommand provides additional help via:\n\n```\ncobib <subcommand> --help\n```\n\nand you can find extensive information in the online documentation (linked above) and the man-page:\n\n```\nman cobib\n```\n\n### TUI\n\nFinally, you can also use coBib's TUI for a more interactive experience (see also `cobib.ui.tui`),\nby simply typing\n```\ncobib\n```\n\nHere is an example screenshot of the TUI when listing the entries in your database:\n\n![coBib TUI List](https://gitlab.com/cobib/cobib/-/raw/master/html/cobib_tui_list.svg)\n\nAnd here is an example screenshot for listing search results:\n\n![coBib TUI Search](https://gitlab.com/cobib/cobib/-/raw/master/html/cobib_tui_search.svg)\n\n\n## Configuration\n\nYou can overwrite the default configuration by placing a `config.py` file in `~/.config/cobib/`.\nThe easiest way to get started with this file is by copying [`example.py`](https://gitlab.com/cobib/cobib/-/blob/master/src/cobib/config/example.py)\nor by using:\n\n```\ncobib _example_config > ~/.config/cobib/config.py\n```\n\nYou can then modify it to your liking.\n\nYou may also specify a different config file at runtime by using the `-c` or `--config` command line argument or by specifying a custom path in the `COBIB_CONFIG` environment variable.\nYou can also disable loading of _any_ configuration file be setting this environment variable to one of the following values: `\"\", 0, \"f\", \"false\", \"nil\", \"none\"`.\n\nFinally, be sure to take a look at the man page (`man cobib`) and/or the online documentation for more information.\n\n\n## Plugins\n\ncoBib supports the implementation of plugins!\nYou can find an example plugin in [this folder](./plugin) or read the docs of\n`cobib_dummy` (when viewing the hosted documentation online).\n\n\n## Documentation\n\ncoBib's documentation is hosted [here](https://cobib.gitlab.io/cobib/cobib.html).\n\nIf you would like to generate a local version during development, you need to clone the source code, and install [`pdoc`](https://github.com/mitmproxy/pdoc) in order to generate it:\n\n```\ngit clone https://gitlab.com/cobib/cobib.git\ncd cobib\npip install pdoc\npdoc -d google -e cobib=https://gitlab.com/cobib/cobib/-/blob/master/src/cobib/ -t html -o docs src/cobib tests\n```\n\nYou can then browse the documentation from `docs/cobib.html`.\n\n\n## History\n\nI have started this project when I was looking into alternatives to popular reference managers such as Mendeley,\nwhich has more features than I use on a regular basis and does not allow me to work from the command line which is where I spent most of the time that I spent on the computer.\n\nHence, I have decided to make it my own task of implementing a simple, yet fast, reference manager.\ncoBib is written in Python and uses a YAML file to store its bibliography in a plain text format.\n\n### Changelog\n\nYou can find the detailed changes throughout coBib's history in [the Changelog](https://gitlab.com/cobib/cobib/-/blob/master/CHANGELOG.md).\n\n\n## License\n\ncoBib is licensed under the [MIT License](https://gitlab.com/cobib/cobib/-/blob/master/LICENSE.txt).\n\n[^1]: References like this one get interpreted by the documentation generator. If you are reading this as the README page, you may find the [online documentation](https://cobib.gitlab.io/cobib/cobib.html) more enjoyable.\n\n[//]: # ( vim: set ft=markdown: )\n\n# Changelog\nAll notable changes to this project will be documented in this file.\n\nThe format is based on [Keep a Changelog](https://keepachangelog.com/),\nand this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).\n\n## [Unreleased]\n\n\n## [5.2.3] - 2024-12-15\n\nPypi: https://pypi.org/project/cobib/5.2.3/\n\n### Fixed\n\n- the interactive handling of notes inside the TUI (#148,!288)\n\n\n## [5.2.2] - 2024-12-06\n\nPypi: https://pypi.org/project/cobib/5.2.2/\n\n### **Breaking Change**\n\n- The `config.theme.dark` and `config.theme.design` settings have been replaced\n  by the new `config.theme.theme` setting, which can be either the name of one\n  of textual's builtin themes, or a custom `textual.theme.Theme` instance\n  (#147,!279). Due to how recent these settings have been introduced (as part of\n  5.2.0), I am opting for a quick removal in this bugfix release rather than a\n  proper version bump (in the sense that they have likely not been adopted, yet)\n  and the severness of the bug that this is causing outweighs the needs here.\n\n### Fixed\n\n- compatibility with `textual>=0.86`\n\n\n## [5.2.1] - 2024-10-30\n\nPypi: https://pypi.org/project/cobib/5.2.1/\n\n### Fixed\n\n- compatibility with `textual>=0.80`\n\n\n## [5.2.0] - 2024-10-30\n\nPypi: https://pypi.org/project/cobib/5.2.0/\n\n### Prelude\n\nWith the addition of the new `note` command, the database entry fields called\n`\"note\"` have obtained a special meaning. Use the `lint` command to check\nwhether your database is affected by this. If it is, you should rename those\nfields.\n\n### Added\n- new configuration settings to customize the appearance of coBib (!222):\n  - `cobib.config.theme.dark`: to specify whether a dark or light theme is used\n  - `cobib.config.theme.design`: to customize the colors themselves\n  - the following settings to customize the appearance of `rich.Syntax` displays:\n    - `cobib.config.theme.syntax.theme`\n    - `cobib.config.theme.syntax.background_color`\n    - `cobib.config.theme.syntax.line_numbers`\n- the `note` command (#139,!206).\n  Please refer to its online documentation or the man-page for more details on\n  how to use it.\n  This new command comes with:\n  - the `cobib.config.commands.note.default_filetype` setting\n  - the `PreNoteCommand` and `PostNoteCommand` event hooks\n- (DEV) the `add_files` argument to the `BaseCommand.git` function\n- Python 3.13 is now officially tested and supported\n- new configuration settings for the search command (#146,!269)\n  - For dealing with skipping/including associated files during searches:\n    - `cobib.config.commands.search.skip_files` sets the default\n    - `--skip-files` overwrites this at runtime (this is not actually new)\n    - `--include-files` overwrites this at runtime (the opposite)\n  - For dealing with skipping/including associated notes during searches:\n    - `cobib.config.commands.search.skip_notes` sets the default\n    - `--skip-notes` overwrites this at runtime (this is not actually new)\n    - `--include-notes` overwrites this at runtime (the opposite)\n\n### Changed\n- the keybinding to recursively toggle all folds in the TUI's search result view\n  was changed from `ENTER` to `BACKSPACE` (!218)\n- (DEV) `cobib.ui.components.entry_points` was moved to `cobib.utils.entry_points`\n- replaced the custom help screen with textual's new builtin help panel (!240)\n\n### Fixed\n- the behavior of the `Home` and `End` keybindings in the TUI's list view (!217)\n- gracefully handles Zotero imported entries without a `journal` field (#145)\n\n\n## [5.1.3] - 2024-08-23\n\nPypi: https://pypi.org/project/cobib/5.1.3/\n\n### Fixed\n- the behavior of the `Home` and `End` keybindings in the TUI's list view (!217)\n\n\n## [5.1.2] - 2024-06-23\n\nPypi: https://pypi.org/project/cobib/5.1.2/\n\n### Fixed\n- support database locations in nested folders of a git repository (!204)\n\n\n## [5.1.1] - 2024-05-28\n\nPypi: https://pypi.org/project/cobib/5.1.1/\n\n### Fixed\n\n- when printing the changelog, do not remove list indents\n\n\n## [5.1.0] - 2024-05-28\n\nPypi: https://pypi.org/project/cobib/5.1.0/\n\n### Prelude\n\nCheck out my blog post to learn more about the features of this new release:\nhttps://mrossinek.gitlab.io/programming/cobib-becomes-fuzzy/\n\n### Added\n- approximate (or fuzzy) filter matching and search functionality (#107,#130,!177)\n  - the `list` and `search` commands now support the following features to\n    perform approximate filter matching and searching, respectively:\n    - LaTeX sequences can be decoded to Unicode characters:\n      - using `--decode-latex` from the command-line\n      - setting `config.commands.list_.decode_latex = True`\n      - setting `config.commands.search.decode_latex = True`\n    - Unicode characters can be converted to a close ASCII equivalent:\n      - using `--decode-unicode` from the command-line\n      - setting `config.commands.list_.decode_unicode = True`\n      - setting `config.commands.search.decode_unicode = True`\n    - a number of fuzzy errors can be set (this requires the optional dependency\n      [`regex`](https://pypi.org/project/regex/) to be installed):\n      - using `--fuzziness <int>` from the command-line\n      - setting `config.commands.list_.fuzzines` to some integer\n      - setting `config.commands.search.fuzzines` to some integer\n- (DEV) the following method arguments have been converted to be accepted only\n  as keyword arguments:\n  - in `cobib.database.Entry.matches`: `ignore_case`\n  - in `cobib.database.Entry.search`: `context`, `ignore_case`, and `skip_files`\n- (DEV) the return-type of `cobib.database.Entry.search` has been changed\n\n\n## [5.0.1] - 2024-05-01\n\nPypi: https://pypi.org/project/cobib/5.0.1/\n\n### Fixed\n- the ability to use an empty string as the separator in `config.database.format.label_suffix` (#138)\n\n\n## [5.0.0] - 2024-04-28\n\nPypi: https://pypi.org/project/cobib/5.0.0/\n\n### Added\n\n- the ability to add custom `commands`, `importers`, and `parsers` through entry points (#135, !139)\n  - (DEV) a dummy plugin show-casing these extensions\n\n### Changed\n- the entire `shell_helper` module has been replaced as follows (!139):\n  - the following deprecated helper methods were removed without replacement:\n    - `_list_commands`\n    - `_list_filters`\n    - `_list_labels`\n  - the following secondary commands have been refactored:\n    - `_lint_database` is now `cobib.commands.lint.LintCommand`\n    - `_unify_labels` is now `cobib.commands.unify_labels.UnifyLabelsCommand`\n    - `_example_config` is now `cobib.config.command.ExampleConfigCommand`\n- the interactive disambiguation mechanism during the `add` command now handles\n  multiple matching related entries (#121,!168)\n  - this includes the ability to `cancel` the disambiguation and entry addition\n\n### Removed\n\n- the previously deprecated `console` attribute of all commands has been removed (!139)\n- the previously deprecated `prompt` attribute of all commands has been removed (!139)\n- the `cobib.ui.shell_helper` and `cobib.utils.shell_helper` modules have been removed (!139)\n- the previously deprecated `--update` argument of the `add` command (!168)\n- the previously deprecated `--skip-existing` argument of the `add` command (!168)\n- the previously deprecated `LabelSuffix.CAPTIAL` attribute (!168)\n- Python 3.8 is no longer supported (!173)\n\n\n## [4.5.0] - 2024-03-17\n\nPypi: https://pypi.org/project/cobib/4.5.0/\n\n### Added\n- the new `cobib.utils.context.get_active_app` method which returns any running\n  textual App and replaces the need for the `cobib.utils.prompt.Prompt.console`\n  and `cobib.utils.progress.Progress.console` (which have been removed) (!137)\n- `cobib.parsers.YAMLParser.parse` can now also parse strings directly (rather\n  than always interpreting the argument as the path to a file) (!137)\n- the `review` command (#131,!137).\n  Please refer to its online documentation or the man-page for more details on\n  how to use it.\n- the `cobib.database.Entry.merge` method (!137)\n\n### Changed\n- log messages will now be displayed in the `LogPanel` of the TUI (which can be\n  toggled with the `z` keybinding) (#132,!133)\n- the `cobib.ui.components.prompt` module has been refactored into `cobib.utils.prompt` (!133)\n\n### Deprecated\n- the `console` argument to all commands has been deprecated since it no longer\n  has any effect (!133)\n- the `prompt` argument to all commands has been deprecated since it no longer\n  has any effect (!133)\n- access to the following `shell_helper` commands will change in the next release:\n  - `cobib _lint_database` will become `cobib lint`\n  - `cobib _unify_labels` will become `cobib unify_labels`\n  - `cobib _example_config` will become `cobib example_config`\n\n### Fixed\n- loading a cached database will be bypassed during `_lint_database` (#133)\n  - to support this the `bypass_cache` keyword-argument was added to the\n    `Database.read` method\n\n### Removed\n- official Windows support label. It _might_ work but no guarantees are made (#136)\n\n\n## [4.4.0] - 2023-12-15\n\nPypi: https://pypi.org/project/cobib/4.4.0/\n\n### Added\n- a primitive caching mechanism to speed up the database loading. This feature\n  is enabled by default and will store its cache at `~/.cache/cobib/databases/`.\n  You can configure the location via `config.database.cache` or even disable\n  caching entirely by changing this setting to `None`. (see also #129 and !108)\n- added the `-r/--remove` option to the `modify` command (#128)\n  - this can achieve the opposite of `-a/--add` in the sense that it will try to\n    remove the specified modification from a list or subtract a number from\n    numeric values\n  - other field types than lists or numbers are not supported by this option\n- added the `-l/--limit` option to the `list` command (#127)\n  - exposed the `ListCommand.sort_entries` method in the public API\n  - added the `ListCommand.execute_dull` method in the public API\n- the `search`, `export`, and `modify` commands now also support sorting and limiting options to be\n  passed onto the `list` command (along with the already existing filtering options)\n- the `config.tui.tree_folding` setting which allows you to configure the\n  default folding state of the tree nodes in the TUI's search result view\n- the `ENTER` binding in the TUI's search result view to recursively toggle all\n  folds of the current node\n\n### Changed\n- when using the TUI you may now use the `:show <label>` command to jump to the\n  specified label (#126,!116)\n- the `search` command now reports its progress live (!117)\n\n### Fixed\n- unblocked the vertical scrollbar of the TUI's list view from the scroll offset\n\n\n## [4.3.1] - 2023-11-12\n\nPypi: https://pypi.org/project/cobib/4.3.1/\n\n### **Breaking Change**\nNote, that the introduction of the detailed author information parsing in v4.3.0\nresulted in possible breaking of a custom `config.database.format.label_default`\nsetup. This bugfix release is meant to emphasize this breaking change and\nupdates the documented example in the example configuration file. For the sake\nof verbosity, here is the change applied to the example:\n\n- old: `\"{unidecode(author.split(' and ')[0].split()[-1])}{year}\"`\n- new: `\"{unidecode(author[0].last)}{year}\"`\n\n\n## [4.3.0] - 2023-11-12\n\nPypi: https://pypi.org/project/cobib/4.3.0/\n\n### Prelude\n\n#### Detailed Authors\ncoBib now has the ability to store more detailed author information (see #92 and\n!88). This means, that the `author` field of an entry is analyzed in more detail\nand coBib will separate out the first and last names as well as name pre- and\nsuffixes. The new setting `config.database.format.author_format` determines,\nwhether this detailed information is kept directly in the database (the\n`AuthorFormat.YAML` setting; the **new default**) or is only constructed at\nruntime and the author field is still simply saved in BibLaTeX form\n(`AuthorFormat.BIBLATEX`).\n\nNote, that the `YAML` format also implies, that Unicode characters are allowed\nand will *not* be encoded in LaTeX form. This has an effect on how you may need\nto format your searches. See also #130 for some more insights on this.\n\nIf you have company names or any author name which you want to have treated\nverbatim, you can simply wrap it in curly braces (e.g. `{My Company}`).\nRefer to the online documentation of `cobib.database.Author` and the above\nsetting for more details.\n\n#### Wiki\ncoBib now has a [Wiki](https://gitlab.com/cobib/cobib/-/wikis/home) where we can\ngather useful configuration resources and other details which may not make it\ninto the full documentation.\n\nFor example, if you are interested in the tracking more metadata of your\ndatabase (as suggested in #123), be sure to check out\n[this wiki page](https://gitlab.com/cobib/cobib/-/wikis/Useful-Event-Hooks)!\n\n### Added\n- the `-f` short-hand alias for the `--field` argument of the `open` command\n- the `opened_entries` attribute of the `OpenCommand` (which is accessible during the `PostOpenCommand` hook)\n- the new `git` command to simplify running git operations on the database (#124)\n- new bindings for `Home`, `End`, `PageUp`, and `PageDown` in the TUI\n- (DEV) added a new `DEPRECATED` logging level which has value 45\n- Python 3.12 is now officially tested and supported\n- the `config.commands.show.encode_latex` setting\n- the `encode_latex` attribute to the `BibtexParser`\n- the `config.database.format.verbatim_fields` setting\n- the `config.database.format.author_format` setting. The new default behavior\n  is to store detailed author information in YAML form.\n- the `encode_latex` keyword-argument to the `Entry.stringify` method\n- the `Entry.formatted` method. This replaces the `Entry.escape_special_chars` method.\n\n### Changed\n- an error will be logged when a file is not found during the `open` command\n- the following commands are now treated specially when run via the `:` prompt of the TUI:\n  - `init`: will log an error\n  - `git`: will log an error\n  - `show`: will log a warning\n\n### Deprecated\n- The `LabelSuffix.CAPTIAL` value because it was misspelled. Please use `LabelSuffix.CAPITAL` instead.\n\n### Fixed\n- non-asynchronous commands triggered via the `:` prompt of the TUI will no longer break it (#125)\n- ensure UTF-8 encoding is used for downloaded data (this fixes many odd encounters w.r.t. special characters)\n- the spelling of the `LabelSuffix.CAPITAL` value (it used to be spelled `LabelSuffix.CAPTIAL`)\n\n### Removed\n- the `Entry.escape_special_chars` method. Use `Entry.formatted` instead.\n\n\n## [4.2.0] - 2023-08-08\n\nPypi: https://pypi.org/project/cobib/4.2.0/\n\n### Added\n- added the `config.tui.scroll_offset` setting\n- added the `--field` command line option to the `open` command\n- (DEV) added a new `HINT` logging level which has value 35 and thus allows to\n  provide information to the user with a higher priority than `WARNING`\n- added the new `config.tui.preset_filters` (#114)\n  - preset filters can be selected from the TUI via the `p` key binding\n  - the first 9 filters can be selected directly by pressing the respective number\n  - pressing `0` resets any applied filter\n- implemented special tags (#63,!83)\n  - adds new builtin tags which will trigger special highlights of entries: `new`, `high`, `medium`, `low`\n  - adds the new `config.theme` settings section for configuring these settings\n  - you can also add more special tags via `config.theme.tags.user_tags`\n- added the `--skip-files` command line option to the `search` command\n\n### Changed\n- unicode symbols in entry labels will now be replaced with ascii ones (#119,#120)\n  - this is configured via the `config.database.format.default_label` setting, so if you are using a\n    custom value for this, be sure to update your config to make use of this feature\n- some user-visible logging messages around label disambiguation have been added (see also #121)\n- a warning has been added when the YAML parser encounters identical labels (which normally should\n  not occur in the database but if it does, coBib does not really know how to resolve this)\n- DOI redirect links are now followed recursively (up to 3 times), improving PDF\n  download link detection in the process (#97)\n\n### Deprecated\n- the `config.commands.search.highlights` section is deprecated in favor of `config.theme.search`\n\n### Fixed\n- retain scroll position in the TUI's list view\n\n\n## [4.1.0] - 2023-06-11\n\nPypi: https://pypi.org/project/cobib/4.1.0/\n\n### Added\n- added the following settings which specify whether or not to preserve\n  associated files during the respective commands being run:\n  - `config.commands.delete.preserve_files`\n  - `config.commands.edit.preserve_files`\n  - `config.commands.modify.preserve_files`\n- added a confirmation prompt before deleting an entry (#110)\n  - this prompt can be disabled by setting `config.commands.delete.confirm` to `False`\n- added the `--no-ignore-case` (`-I` for short) command line options to the\n  `list` and `search` command (#116)\n- added the `--no-preserve-files` command line options to the `delete`, `edit`\n  and `modify` command (#116)\n- added the `config.commands.search.context` setting which configures the\n  default number of context lines to be provided for search query matches\n- added more options to configure the automatic download behavior:\n  - the new `config.commands.add.skip_download` setting\n  - the new `--force-download` option of the `add` command\n  - the new `config.commands.import_.skip_download` setting\n  - the new `--force-download` option of the `import` command\n- the user is asked for confirmation when quitting the TUI (!71)\n\n### Changed\n- refactored the TUI by leveraging textual's `Screen` concept (#111,!71)\n  - this means the TUI will look slightly different but no real functional change has occurred\n  - the view of an `Entry` can now be scrolled when the output exceeds the available space\n- switched from the `BeautifulSoup` HTML parser to `lxml`\n  - this is supposed to give more accurate results but adds an extra dependency\n\n### Deprecated\n- The following shell helpers are no longer used with the zsh completion being\n  removed. Thus, these methods will be removed in the future:\n  - `cobib _list_commands`\n  - `cobib _list_filters`\n  - `cobib _list_labels`\n  - If you see warnings because of this while you are using the CLI, you\n    probably still have the (now removed) zsh completion script installed. You\n    should remove the `_cobib` file which will be located in one of the\n    directories listed in your `$FPATH` environment variable.\n\n### Fixed\n- the proper pre-population of the TUI prompt during the sorting action (#117)\n- preserves the value of `config.commands.list_.default_columns` and\n  properly removes a field if it is no longer sorted by in the TUI (#117)\n- properly updates the list of entries in the TUI after changing the database contents;\n  for example via `add` (#113) or `delete` (#113) or `edit` (#118)\n- an issue where file-accessing operations performed on a newly added entry within\n  the same TUI session would fail because the path would not be iterated correctly\n- the live updating of the download progress bar inside the TUI (#112)\n\n### Removed\n- the crude and very slow zsh completion script\n\n\n## [4.0.0] - 2023-05-20\n\nPypi: https://pypi.org/project/cobib/4.0.0/\n\n### **Breaking Changes**\n- Configuration settings can no longer be set by item access and instead must\n  use attribute syntax. For example you need to change:\n  ```python\n  config[\"database\"][\"git\"] = True\n  ```\n  to\n  ```python\n  config.database.git = True\n  ```\n  - the `config.commands.list` section had to be renamed to `config.commands.list_`\n  - the `config.tui` section has been entirely removed\n- The `cobib.commands.list` module was moved to `cobib.commands.list_`.\n- The function signature of all command- and importer-related events has changed!\n  For more details please refer to the\n  [online documentation](https://cobib.gitlab.io/cobib/cobib/config/event.html).\n\n### Added\n- Python 3.11 is now officially tested and supported\n- Full rewrite of all commands to use `rich` for a nicer CLI (#78,!51)\n- Full rewrite of the TUI based on `textual` (#78,!51)\n- the `--disambiguation` argument of the `add` command (#99,!58)\n- the `--ignore-case` argument of the `list` command (#105)\n  - this also comes with the new `config.commands.list_.ignore_case` setting\n- the `search` command now accepts multiple query strings at once which will be\n  searched over independently (#106)\n\n### Changed\n- the new default value of `config.parsers.yaml.use_c_lib_yaml` is now `True` as announced in version [3.4.0]\n- refactored the entire config as a dataclass (!63)\n  - this implies that settings can only be set via attributes\n  - but as a benefit the maintainability and documentation have improved significantly\n- The function signature of all command-related events has changed! Please refer to the\n  [online documentation](https://cobib.gitlab.io/cobib/cobib/config/event.html)\n  for more details. (!63)\n- The function signature of all importer-related events has changed! Please refer to the\n  [online documentation](https://cobib.gitlab.io/cobib/cobib/config/event.html)\n  for more details. (!66)\n- the API of the `cobib.commands` and `cobib.importers` module has been improved (!64)\n  - this should not have any end-user facing effects\n- the `cobib.commands.list` module was moved to `cobib.commands.list_`\n\n### Deprecated\n- the `--update` argument of the `add` command is deprecated in favor of `--disambiguation update`\n- the `--skip-existing` argument of the `add` command is deprecated in favor of `--disambiguation keep`\n\n### Fixed\n- the detection whether an entry already exists broke when label disambiguation was added in [3.3.0]\n  and is now fixed by means of an interactive prompt during the `add` command\n\n### Removed\n- the warning triggered upon setting `config.database.format.month` which got removed in [3.1.0]\n- Python 3.7 is no longer supported\n\n\n## [3.5.5] - 2023-04-11\n\nPypi: https://pypi.org/project/cobib/3.5.5/\n\n### Fixed\n- opening of non-list type fields (#100)\n\n\n## [3.5.4] - 2022-12-26\n\nPypi: https://pypi.org/project/cobib/3.5.4/\n\n### Fixed\n- missing files encountered during searching will log warnings gracefully instead of harshly\n- handle newline characters in the TUI (#98)\n\n\n## [3.5.3] - 2022-11-16\n\nPypi: https://pypi.org/project/cobib/3.5.3/\n\n### Fixed\n- incorrect author concatenation in ISBN Parser\n- using the disambiguated label for the names of downloaded files (#96)\n\n\n## [3.5.2] - 2022-05-22\n\nPypi: https://pypi.org/project/cobib/3.5.2/\n\n### Fixed\n- run TUI on BSD platforms (!52)\n\n\n## [3.5.1] - 2022-04-25\n\nPypi: https://pypi.org/project/cobib/3.5.1/\n\n### Fixed\n- safely check cache existence before attempting to write (#94)\n\n\n## [3.5.0] - 2022-01-13\n\nPypi: https://pypi.org/project/cobib/3.5.0/\n\n### **News:** coBib v4.0 will come with a new UI!\nThe plan is to switch to [rich][rich] and [textual][textual] instead of the current curses TUI.\nThis will open up some great possibilities for a much more modern UI.\n\nHowever, this change will require some *major* refactoring including breaking changes of the API\nand some of the user configuration options. It will also be a rather drastic change in style.\nThus, I will attempt to support v3.5 with bugfix releases until 1.1.2023\n\nIt will likely take a few months until v4.0 gets released but I am starting development on it now.\nYou can follow the progress here: <https://gitlab.com/cobib/cobib/-/issues/78>\n\n[rich]: https://github.com/Textualize/rich\n[textual]: https://github.com/Textualize/textual\n\n### Added\n- the configuration loading can be disabled via the environment variable `COBIB_CONFIG`\n    - values which disable the loading entirely are: `\"\", 0, f, false, nil, none`\n    - you can also specify a custom path to a configuration file in this variable\n\n### Removed\n- the `INI`-style configuration got fully removed (as deprecated in [3.0.0] - 2021-04-10)\n\n\n## [3.4.0] - 2021-12-01\n\nPypi: https://pypi.org/project/cobib/3.4.0/\n\n- coBib now requires the `requests-oauthlib` package\n    - technically this is an optional dependency for now, but it will likely become a requirement soon\n\n### Added\n- the new `config.parsers.yaml.use_c_lib_yaml` setting which significantly improves loading performance\n    - this setting will change its default value to `True` in version 4.0.0\n* the `Import` command (#86,!49):\n    - can be used to import libraries from other bibliography managers (see next bullet)\n    - see `cobib import --help` for more information\n- the `cobib.importers` module:\n    - provides importer classes for various other bibliography managers\n    - these get registered at runtime under the `cobib import` command\n    - this release provides the `--zotero` importer\n    - see `cobib import --zotero -- --help` for more information\n- the `config.logging.cache` option, specifying the location of a simple json cache\n- the `config.commands.open.fields` option, specifying the names of the data fields which are checked for openable URLs (#89)\n\n### Changed\n- the `PreFileDownload` event now takes an additional argument: `headers: Optional[Dict[str, str]]`\n\n### Fixed\n- downloaded file names will not duplicate the `.pdf` suffix\n\n\n## [3.3.2] - 2021-11-17\n\nPypi: https://pypi.org/project/cobib/3.3.2/\n\n### Fixed\n- re-enable the terminal keypad during resize event\n    - this ensures proper arrow-key behavior after returning from an external editor\n- clear screen after closing TUI to remove all screen artifacts\n\n### Security\n- remove warning when using the DOI parser because the upstream issue related to #91 got fixed\n\n\n## [3.3.1] - 2021-10-19\n\nPypi: https://pypi.org/project/cobib/3.3.1/\n\n### Fixed\n- erroneous label disambiguation of Entry labels which already conform with `config.database.format.default_label_format` (#87,!47)\n- do not add empty file list when unifying database\n\n### Security\n- log warning when using the DOI parser because of (#91)\n\n\n## [3.3.0] - 2021-10-04\n\nPypi: https://pypi.org/project/cobib/3.3.0/\n\n### Added\n- print Changelog since the last run version (cached in `config.logging.version`) (#82)\n- the `AddCommand` now has a new `--update` option (#79,!41)\n- the `_lint_database` utility now takes the `--format` argument, which automatically resolves all lint messages (#81,!42)\n- the new `URLParser` (available via `cobib add --url <URL>` (#84,!44)\n    - it attempts importing from a plain URL\n    - simultaneously the arXiv, DOI, and ISBN parsers now also support URL containing a matching identifier directly\n- the `--dry` argument of the `ModifyCommand` to prevent errors during large bulk modifications\n* the `config.database.format.label_default` and `config.database.format.label_suffix` options (#85,!45)\n    - labels will automatically be formatted according to the default option\n    - if labels conflict with existing ones, the suffix option will be used for disambiguation\n    - the `AddCommand` has a new `--skip-existing` option which disables automatic label disambiguation\n    - use `cobib _unify_labels --apply` to unify all labels in your database\n- subscribable events (#71,!46)\n    - allows registering of hooks to be executed in certain situation\n    - more information is provided at the [online documentation](https://cobib.gitlab.io/cobib/cobib/config/event.html)\n\n### Changed\n- when an unknown variable is encountered in the modification of the `modify` command it falls back to an empty string rather than the name of the attempted variable\n\n### Removed\n- the `-s` option of the `AddCommand` is no longer available. You need to write out `--skip-download`\n- the `ID` filter argument on the `list` command (deprecated in v3.2.0 in favor of the `label` filter)\n\n\n## [3.2.1] - 2021-07-15\n\nPypi: https://pypi.org/project/cobib/3.2.1/\n\n### Fixed\n- when adding multiple entries at once, continue adding after encountering a single duplicate (#83)\n\n\n## [3.2.0] - 2021-06-26\n\nPypi: https://pypi.org/project/cobib/3.2.0/\n\n### Added\n- basic auto-downloading of PDF files for arXiv IDs and configured DOIs (#25,!35,!39):\n    - the default download location can be configured via `config.utils.file_downloader.default_location`\n    - on a per addition basis, this default can be overwritten via the `--path` keyword option of the `AddCommand`\n    - if a file already exists in this location of the file system, the download will be skipped\n    - download for DOI entries must configure URL patterns in `config.utils.file_downloader.url_map`\n    - on a per addition basis, the entire automatic download can be skipped with `--skip-download`\n- automatic journal abbreviations (#62,!36):\n    - users can configure a list of journal abbreviations via `config.utils.journal_abbreviations`\n    - if present, coBib will store the journal in its elongated form\n    - a user can then automatically convert to abbreviated forms during exporting (see the new `--abbreviate` and `--dotless` arguments)\n- Tentative Windows support by disabling the TUI\n- a `--preserve-files` argument was added to the following commands. Unless it is given, these will delete/rename associated files of affected entries:\n    - `DeleteCommand`\n    - `EditCommand`\n    - `ModifyCommand`\n\n### Changed\n- the `modifications` of a `ModifyCommand` get interpreted as f-strings (#77,!37):\n    - available variables are the entry's label and data fields\n- any `ListCommand` filter gets interpreted as a regex pattern (#76)\n\n### Deprecated\n- the `ID` filter argument was fully replaced by `label`, unifying the CLI API. Support will be dropped in v3.3.0\n\n### Fixed\n- Removed (most) duplication of log messages\n\n\n## [3.1.1] - 2021-05-25\n\nPypi: https://pypi.org/project/cobib/3.1.1/\n\n### Fixed\n- Pypi package metadata\n\n\n## [3.1.0] - 2021-05-24\n\nPypi: https://pypi.org/project/cobib/3.1.0/\n\n### Added\n- the YAML format of the database has been extended to support the following: (#55)\n    - numbers can be stored as integers\n    - the `ID` field is no longer required and will be properly inferred from the label\n    - the following fields can be stored as lists: `file`, `tags`, `url`\n- three new configuration options were added to complement the above list format options:\n    - `config.database.stringify.list_separator.file`\n    - `config.database.stringify.list_separator.tags`\n    - `config.database.stringify.list_separator.url`\n- the `_lint_database` shell utility has been added which can be used to detect possible improvements for the database\n- the append-mode of the `ModifyCommand` was implemented (#60):\n    - specifying `-a`/`--add` will add the modification value to the field of the entries rather than overwrite it\n    - this can be used for string or list concatenation and even number addition on numeric fields\n\n### Changed\n- use file paths relative to user-home (achieved by replacing `os.path` with `pathlib`) (#69)\n- the shell helper `_list_tags` has been renamed to `_list_labels`\n- (DEV): the `logging` and `zsh_helper` modules have been relocated to the `cobib.utils` package\n- `+` symbols will no longer be stripped from tags (this was a left-over artifact from pre-v1.0.0)\n\n### Deprecated\n- the `config.database.format.month` setting is deprecated in favor of proper three-letter code encoding to support common citation style macros (!34)\n\n### Fixed\n- renaming the label during the `edit` command does not leave the previous label entry behind:\n    - a followup also ensured that renaming entries happens in-place (#75)\n- the sorting of the `list` command\n\n\n## [3.0.0] - 2021-04-10\n\nPypi: https://pypi.org/project/cobib/3.0.0/\n\n- From now on, `coBib` is the official way of spelling!\n\n### Added\n- coBib's documentation is now generated by [`pdoc`](https://pdoc.dev/) and hosted at https://cobib.gitlab.io/cobib/cobib.html\n- (DEV): the `cobib.database.Database`-Singleton has been added to centrally manage the bibliographic runtime data (!28)\n- the new option `config.database.format.suppress_latex_warnings`\n- the new option `config.commands.edit.editor` which takes precedence over the `$EDITOR` variable\n\n### Changed\n- the `INI`-style configuration is replaced with a `Python`-based configuration (#54,!25)\n    - for guidance on how to migrate an existing configuration please read https://mrossinek.gitlab.io/programming/cobibs-new-configuration/\n- (DEV): `cobib.parser.Entry` has been moved to `cobib.database.Entry`\n- the `cobib.parsers` module has been extracted (prep for #49, !28)\n- the filenames of the associated files are preserved when exporting to a Zip file\n- when trying to add an entry with an existing label, the database is not written to and a warning is raised early\n- month conversion and special character escaping are only done upon saving entries to the database\n- the path to the default logfile can now be configured via `config.logging.logfile` and defaults to `~/.cache/cobib/cobib.log`\n\n### Deprecated\n- the `INI`-style configuration is deprecated\n    - new configuration options will not be added to this style\n    - only bugs which fully break usability will be fixed with regards to this configuration style\n    - legacy-support will be fully removed on 1.1.2022\n\n### Fixed\n- the ZSH helper utilities now respect the `-c`, `-l`, and `-v` command line options\n- the `RedoCommand` should only revert a previously `UndoCommand` operation (#65)\n- the `SearchCommand` got some contexts improvements and correctly splits grep results\n- unwrapping does not crash the TUI if the cursor was multiple lines below the new buffer height\n- line continuation guides are not swallowed by current line highlighting\n- ensure the TUI's top line does not become negative\n- the TUI's handler for resizing events\n- `JSONDecodeError`s thrown by the `ISBNParser` are caught and handled gracefully\n\n### Removed\n- the functions `read_database()` and `write_database()` are no longer available (!28)\n\n\n## [2.6.1] - 2021-02-05\n\nPypi: https://pypi.org/project/cobib/2.6.1/\n\nNote: [2.6.1] was not released from the `master`-branch, which resulted in a non-linear development.\n\n### Changed\n- `init --git` will not initialize a repository unless git has configured both, `name` and `email`\n\n### Fixed\n- TUI no longer crashes when aborting to quit (#64)\n\n\n## [2.6.0] - 2020-12-31\n\nPypi: https://pypi.org/project/cobib/2.6.0/\n\n### Added\n- Git integration (#44, !20):\n    - will automatically track any changes done to the database file with git\n    - must be enabled by setting the `DATABASE/git` option to `True` **and** running `cobib init --git`\n    - Note, that you must have at least set a `name` and `email` in the git config!\n- Undo/Redo commands to operate on git history of the database (#59,!23)\n    - for obvious reasons these commands require the Git integration (see above) to be enabled\n- the `Prompt` command inside of the TUI:\n    - allows executing arbitrary CoBib CLI commands\n    - the default key binding is `:`\n- the `Modify` command: (#60,!24)\n    - allows bulk modification of multiple entries in a `<field>:<value>` format\n    - for now, this will **always** overwrite the field with the new value!\n    - an extension to appending values is planned for a later release\n    - the set of entries to be modified can be specified just like with the `export` command through `list`-command filters or manual selection (by setting the `--selection` flag)\n\n### Changed\n- the viewport history is preserved correctly (#21,!22)\n    - this allows performing a search while showing an entry and reverts back to the correct view after quitting the search\n    - the changes mainly involved refactoring of the `cobib/tui` module\n- the **positional** argument of the `modify` and `search` has been renamed internally from `list_arg` to `filter`\n    - this should not have any visible effect to an end-user but may be relevant to developers\n\n### Fixed\n- gracefully handle multiple terminal sizing issues with regards to popups (#58)\n- catch messages on `stdout` during deletion from TUI\n- added missing help strings to the TUI help menu\n\n### Removed\n- The `--force` argument to the `init` command has now been removed (after being deprecated in v2.5.0).\n\n\n## [2.5.0] - 2020-12-08\n\nPypi: https://pypi.org/project/cobib/2.5.0/\n\n### Added\n- support for multiple associated files (#42,!19)\n- interactive menu when opening an entry with multiple associated files (!19)\n\n### Deprecated\n- The `--force` argument to the `init` command has been deprecated. I don't think there is any\n  benefit to providing the user the option to nuke their database file from the CLI. Instead,\n  they can simply edit the file manually.\n\n### Fixed\n- always store years as strings to be compatible with bibtexparser\n- handle invalid arXiv or DOI IDs gracefully (#57)\n\n\n## [2.4.1] - 2020-11-01\n\nPypi: https://pypi.org/project/cobib/2.4.1/\n\n### Fixed\n- ISBN parser was missing the ENTRYTYPE and did not use strings for number fields\n- the ISBN parser can now handle empty entries (#53)\n- the TUI will not crash on stdout/stderr messages exceeding the window width\n- the TUI respects quoted strings in the prompt handler (#52)\n\n\n## [2.4.0] - 2020-10-14\n\nPypi: https://pypi.org/project/cobib/2.4.0/\n\n### Added\n- the `FORMAT/default_entry_type` option used for manual entry addition\n- a **manual** insertion mode available through `edit -a new_label` and `add -l new_label`\n- a ISBN-based parser for adding new entries (#45)\n- the TUI-based `select` command (and corresponding settings) (#8,!18)\n- the `--selection` argument for the `export` command (!18)\n\n### Changed\n- TUI color highlighting is now prioritized (!17)\n\n### Fixed\n- support URLs in file field during `open` command (#47)\n- the TUI no longer crashes when encountering long prompt inputs (#48)\n- the `edit` command can handle labels which start with common substrings (#46)\n- support multiple ANSI colors on a single line (#50)\n\n\n## [2.3.4] - 2020-09-14\n\nPypi: https://pypi.org/project/cobib/2.3.4/\n\n### Fixed\n- another AUR package installation error\n\n\n## [2.3.3] - 2020-09-14\n\nPypi: https://pypi.org/project/cobib/2.3.3/\n\n### Fixed\n- AUR package installation error\n\n## [2.3.2] - 2020-09-10\n\nPypi: https://pypi.org/project/cobib/2.3.2/\n\n### Added\n- option to default to case-insensitive searching (`DATABASE/search_ignore_case`)\n\n### Changed\n- clearing the prompt, aborts the command execution\n\n### Fixed\n- search command correctly handles missing arguments in TUI (#43)\n\n## [2.3.1] - 2020-09-10\n\nPypi: https://pypi.org/project/cobib/2.3.1/\n\n### Fixed\n- faulty Pypi package\n\n## [2.3.0] - 2020-09-10\n\nPypi: https://pypi.org/project/cobib/2.3.0/\n\n### Added\n- Logging functionality has been added. The verbosity level can be controlled via `-v` (INFO) and `-vv` (DEBUG).\n  As soon as the TUI starts, all logging output is redirected to `/tmp/cobib.log`.\n- Command line argument `-l` or `--logfile` can be used to specify the output path of the log. This will overwrite the `/tmp/cobib.log` location.\n- the `TUI/scroll_offset` setting was added. It defaults to `3` and behaves similar to Vim's `scrolloff` setting.\n- Configuration validation has been added. This extends the logging functionality to support more runtime debug information.\n- popup window support: stdout and stderr messages are presented in a popup similarly to the help window\n\n### Changed\n- `-v` command line argument now refers to `--verbose` rather than `--version`\n- Performance of the `add` command has been improved by not refreshing the database when outside of the TUI.\n\n### Fixed\n- bug when resizing causes the window width to become greater than the buffer width (#39)\n- do not escape special characters in labels (#40)\n- avoid special character encoding in file paths\n\n## [2.2.2] - 2020-08-13\n\nPypi: https://pypi.org/project/cobib/2.2.2/\n\n### Fixed\n- current line highlight if viewport is wider than buffer was not correctly reset\n- the `ignore_non_standard_types` setting had no effect\n\n## [2.2.1] - 2020-08-10\n\nPypi: https://pypi.org/project/cobib/2.2.1/\n\n### Changed\n- when wrapping the TUI lines, indent until after the label column (#26)\n- renamed `default.ini` to `example.ini` in the documentation folder\n\n### Fixed\n- current line highlight after viewport width was not correctly reset\n- correctly convert boolean configuration options (#34)\n- fix crash of TUI in wrap command when viewport is empty (#37)\n- default configuration settings are managed centrally and consistently (#35)\n\n\n## [2.2.0] - 2020-07-12\n\nPypi: https://pypi.org/project/cobib/2.2.0/\n\n### Added\n- allow configuring the program used to `open` associated files\n- prompt user before actually quitting CoBib (#33)\n- implements the Search command (#7, !12)\n\n### Fixed\n- the default value of the `open` command was not set correctly\n\n\n## [2.1.0] - 2020-06-14\n\nPypi: https://pypi.org/project/cobib/2.1.0/\n\n### Added\n- added half- and full-page scrolling (#22)\n\n### Changed\n- importing from `bibtex` data defaults to **not** ignored non-standard entry types (#28)\n- suppress LaTex encoding warnings except when adding entries (#29)\n- `Search` and `Select` print warnings to the prompt while not implemented\n\n### Fixed\n- `init` command ensures directory of database file exists\n- remove window artifacts after `help` menu is closed (#20)\n- configuration file detection was missing a user home expansion (#31)\n\n## [2.0.0] - 2020-06-06\n\nPypi: https://pypi.org/project/cobib/2.0.0/\n\n### Fixed\n- respect sort order reversing and filter `XOR`ing from the TUI (#18)\n- `edit` command on Mac OS (#19)\n\n### Changed\n- made `init` command safe against database overwriting\n- TUI: list entries in reverse order by default (config: TUI/reverse_order)\n\n\n## [2.0.0b4] - 2020-05-16\n\nPypi: https://pypi.org/project/cobib/2.0.0b4/\n\n### Fixed\n- reset viewport position when updating buffer\n\n\n## [2.0.0b3] - 2020-05-16\n\nPypi: https://pypi.org/project/cobib/2.0.0b3/\n\n### Fixed\n- properly assert valid current line number\n\n\n## [2.0.0b2] - 2020-05-16\n\nPypi: https://pypi.org/project/cobib/2.0.0b2/\n\n### Fixed\n- fixed TUI startup\n\n\n## [2.0.0b1] - 2020-05-16\n\n**Warning**: do NOT use! The TUI is broken in this release!\n\nPypi: https://pypi.org/project/cobib/2.0.0b1/\n\n### Fixed\n- TUI does not crash when opening an entry with no associated file\n- correctly reset current line positions after filtering and editing\n\n\n## [2.0.0b0] - 2020-04-28\n\nPypi: https://pypi.org/project/cobib/2.0.0b0/\n\n### Changed\n- _internal_: refactored the config into a class\n- centralized the database handling to improve performance (#12,!9)\n\n### Fixed\n- the `Show` command does not break after scrolling the viewport (#13)\n\n\n## [2.0.0a2] - 2020-04-27\n\nPypi: https://pypi.org/project/cobib/2.0.0a2/\n\n### Added\n- user configuration options for:\n    - TUI colors\n    - TUI key bindings\n    - TUI default list arguments\n- help window highlighting\n\n### Changed\n- sorting and filtering commands remain persistent when updating the list view\n\n\n## [2.0.0a1] - 2020-04-23\n\nPypi: https://pypi.org/project/cobib/2.0.0a1/\n\n### Added\n- Added a basic curses-based TUI (#5,!7)\n\n### Changed\n- _internal_: refactored commands into separate module\n\n\n## [1.1.0] - 2020-03-28\n\nPypi: https://pypi.org/project/cobib/1.1.0/\n\n### Added\n- add `FORMAT.month` configuration option to configure the default type for\n    month fields (defaults to `int`) (#3,!4)\n- escape special LaTeX characters (#2,!5)\n\n### Fixed\n- `list` no longer breaks with a `KeyError` when a queried field does not exist\n    in any bibliography entry (!2)\n- `--label` can now correctly overwrite the ID (#4,!3)\n\n### Changed\n- `set_config()` and global `CONFIG` exported to separate module\n\n\n## [1.0.2] - 2020-01-12\n\nPypi: https://pypi.org/project/cobib/1.0.2/\n\nNote: this removal is not seen as a MINOR version bump because this is\n      essentially a long out-standing bug fix\n\n### Removed/Fixed\n- doi extraction from pdf files (476efc4f)\n  - also removes the ability to add entries directly via pdf files\n\n\n## [1.0.1] - 2020-01-12\n\nPypi: https://pypi.org/project/cobib/1.0.1/\n\n### Changed\n- metadata for pypi\n\n\n## [1.0.0] - 2020-01-12\n\nFirst MAJOR release. Also available via Pypi: https://pypi.org/project/cobib/1.0.0/\nThe project was renamed from `CReMa` to `CoBib`\n\n### Added\n- allow sorting the list output (2a5a94f1)\n- crude and slow (!!!) zsh completion (9f28f441)\n- support Darwin's `open` command\n\n### Changed\n- suppress list output when exporting\n- add used tags to columns when listing\n- sort YAML database entries by keys (d2af42d2)\n\n### Fixed\n- fixed arxiv parser (7ce3726f)\n\n\n## [0.2] - 2019-09-02\n\nNote: this release was not marked MAJOR because this is still a WIP and early\n      alpha release.\n\n### Added\n- complete rewrite to use a plain-text `yaml` database instead of `sqlite3` !1\n\n### Removed\n- `sqlite3` database\n\n\n## [0.1] - 2019-04-29\n\n### Added\n- initial version with a basic `sqlite3`-based database\n\n\n[Unreleased]: https://gitlab.com/cobib/cobib/-/compare/v5.2.3...master\n[5.2.3]: https://gitlab.com/cobib/cobib/-/tags/v5.2.3\n[5.2.2]: https://gitlab.com/cobib/cobib/-/tags/v5.2.2\n[5.2.1]: https://gitlab.com/cobib/cobib/-/tags/v5.2.1\n[5.2.0]: https://gitlab.com/cobib/cobib/-/tags/v5.2.0\n[5.1.3]: https://gitlab.com/cobib/cobib/-/tags/v5.1.3\n[5.1.2]: https://gitlab.com/cobib/cobib/-/tags/v5.1.2\n[5.1.1]: https://gitlab.com/cobib/cobib/-/tags/v5.1.1\n[5.1.0]: https://gitlab.com/cobib/cobib/-/tags/v5.1.0\n[5.0.1]: https://gitlab.com/cobib/cobib/-/tags/v5.0.1\n[5.0.0]: https://gitlab.com/cobib/cobib/-/tags/v5.0.0\n[4.5.0]: https://gitlab.com/cobib/cobib/-/tags/v4.5.0\n[4.4.0]: https://gitlab.com/cobib/cobib/-/tags/v4.4.0\n[4.3.1]: https://gitlab.com/cobib/cobib/-/tags/v4.3.1\n[4.3.0]: https://gitlab.com/cobib/cobib/-/tags/v4.3.0\n[4.2.0]: https://gitlab.com/cobib/cobib/-/tags/v4.2.0\n[4.1.0]: https://gitlab.com/cobib/cobib/-/tags/v4.1.0\n[4.0.0]: https://gitlab.com/cobib/cobib/-/tags/v4.0.0\n[3.5.5]: https://gitlab.com/cobib/cobib/-/tags/v3.5.5\n[3.5.4]: https://gitlab.com/cobib/cobib/-/tags/v3.5.4\n[3.5.3]: https://gitlab.com/cobib/cobib/-/tags/v3.5.3\n[3.5.2]: https://gitlab.com/cobib/cobib/-/tags/v3.5.2\n[3.5.1]: https://gitlab.com/cobib/cobib/-/tags/v3.5.1\n[3.5.0]: https://gitlab.com/cobib/cobib/-/tags/v3.5.0\n[3.4.0]: https://gitlab.com/cobib/cobib/-/tags/v3.4.0\n[3.3.2]: https://gitlab.com/cobib/cobib/-/tags/v3.3.2\n[3.3.1]: https://gitlab.com/cobib/cobib/-/tags/v3.3.1\n[3.3.0]: https://gitlab.com/cobib/cobib/-/tags/v3.3.0\n[3.2.1]: https://gitlab.com/cobib/cobib/-/tags/v3.2.1\n[3.2.0]: https://gitlab.com/cobib/cobib/-/tags/v3.2.0\n[3.1.1]: https://gitlab.com/cobib/cobib/-/tags/v3.1.1\n[3.1.0]: https://gitlab.com/cobib/cobib/-/tags/v3.1.0\n[3.0.0]: https://gitlab.com/cobib/cobib/-/tags/v3.0.0\n[2.6.1]: https://gitlab.com/cobib/cobib/-/tags/v2.6.1\n[2.6.0]: https://gitlab.com/cobib/cobib/-/tags/v2.6.0\n[2.5.0]: https://gitlab.com/cobib/cobib/-/tags/v2.5.0\n[2.4.1]: https://gitlab.com/cobib/cobib/-/tags/v2.4.1\n[2.4.0]: https://gitlab.com/cobib/cobib/-/tags/v2.4.0\n[2.3.4]: https://gitlab.com/cobib/cobib/-/tags/v2.3.4\n[2.3.3]: https://gitlab.com/cobib/cobib/-/tags/v2.3.3\n[2.3.2]: https://gitlab.com/cobib/cobib/-/tags/v2.3.2\n[2.3.1]: https://gitlab.com/cobib/cobib/-/tags/v2.3.1\n[2.3.0]: https://gitlab.com/cobib/cobib/-/tags/v2.3.0\n[2.2.2]: https://gitlab.com/cobib/cobib/-/tags/v2.2.2\n[2.2.1]: https://gitlab.com/cobib/cobib/-/tags/v2.2.1\n[2.2.0]: https://gitlab.com/cobib/cobib/-/tags/v2.2.0\n[2.1.0]: https://gitlab.com/cobib/cobib/-/tags/v2.1.0\n[2.0.0]: https://gitlab.com/cobib/cobib/-/tags/v2.0.0\n[2.0.0b4]: https://gitlab.com/cobib/cobib/-/tags/v2.0.0b4\n[2.0.0b3]: https://gitlab.com/cobib/cobib/-/tags/v2.0.0b3\n[2.0.0b2]: https://gitlab.com/cobib/cobib/-/tags/v2.0.0b2\n[2.0.0b1]: https://gitlab.com/cobib/cobib/-/tags/v2.0.0b1\n[2.0.0b0]: https://gitlab.com/cobib/cobib/-/tags/v2.0.0b0\n[2.0.0a2]: https://gitlab.com/cobib/cobib/-/tags/v2.0.0a2\n[2.0.0a1]: https://gitlab.com/cobib/cobib/-/tags/v2.0.0a1\n[1.1.0]: https://gitlab.com/cobib/cobib/-/tags/v1.1.0\n[1.0.2]: https://gitlab.com/cobib/cobib/-/tags/v1.0.2\n[1.0.1]: https://gitlab.com/cobib/cobib/-/tags/v1.0.1\n[1.0.0]: https://gitlab.com/cobib/cobib/-/tags/v1.0.0\n[0.2]: https://gitlab.com/cobib/cobib/-/tags/v0.2\n[0.1]: https://gitlab.com/cobib/cobib/-/tags/v0.1\n",
    "bugtrack_url": null,
    "license": "MIT License",
    "summary": "Console Bibliography",
    "version": "5.2.3",
    "project_urls": {
        "Changelog": "https://gitlab.com/cobib/cobib/-/blob/master/CHANGELOG.md",
        "Documentation": "https://cobib.gitlab.io/cobib/cobib.html",
        "Homepage": "https://gitlab.com/cobib/cobib",
        "Issues": "https://gitlab.com/cobib/cobib/-/issues",
        "Repository": "https://gitlab.com/cobib/cobib"
    },
    "split_keywords": [
        "reference-manager",
        " citation-manager",
        " bibliography",
        " cli",
        " tui",
        " command-line",
        " terminal",
        " console",
        " bibtex",
        " doi",
        " arxiv",
        " isbn"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "dc0f513cbf996756ce5eef5c1cf90595487d9b4135dc92daebce8eef035c4bd8",
                "md5": "e3a14598ed7f53d1e6115526a8ad9f86",
                "sha256": "9f7153f5af2d0354bff9a5939291396aa80a92d07bc4297ca39326da8ee45681"
            },
            "downloads": -1,
            "filename": "cobib-5.2.3-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "e3a14598ed7f53d1e6115526a8ad9f86",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.9",
            "size": 181826,
            "upload_time": "2024-12-15T15:19:04",
            "upload_time_iso_8601": "2024-12-15T15:19:04.151639Z",
            "url": "https://files.pythonhosted.org/packages/dc/0f/513cbf996756ce5eef5c1cf90595487d9b4135dc92daebce8eef035c4bd8/cobib-5.2.3-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "72bd9149c71bf3b2ce42dc59302893db2b0cefbff2f5e52fe7b08ec051e330d4",
                "md5": "90f2d7b41d1529c3b117e78ee4e2f9b0",
                "sha256": "ff7c19ccf66500705a1bff38389858fd4b6f6e4a97da40a4f4b9e3baa6e981bc"
            },
            "downloads": -1,
            "filename": "cobib-5.2.3.tar.gz",
            "has_sig": false,
            "md5_digest": "90f2d7b41d1529c3b117e78ee4e2f9b0",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.9",
            "size": 189696,
            "upload_time": "2024-12-15T15:19:07",
            "upload_time_iso_8601": "2024-12-15T15:19:07.334664Z",
            "url": "https://files.pythonhosted.org/packages/72/bd/9149c71bf3b2ce42dc59302893db2b0cefbff2f5e52fe7b08ec051e330d4/cobib-5.2.3.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-12-15 15:19:07",
    "github": false,
    "gitlab": true,
    "bitbucket": false,
    "codeberg": false,
    "gitlab_user": "cobib",
    "gitlab_project": "cobib",
    "lcname": "cobib"
}
        
Elapsed time: 2.21349s