All notable changes to this project will be documented in this file.
The format is based on Keep a Changelog, and this project adheres to Semantic Versioning.
- the ability to remove fields entirely via the
modify
command (#142,!299) - a hint in the documentation how to filter for (non-)existence of fields (#141)
- the
Escape
key during an input prompt triggered after aConfirm
prompt (e.g. a cancelledquit
)
5.2.3 - 2024-12-15
Pypi: https://pypi.org/project/cobib/5.2.3/
- 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/
- The
config.theme.dark
andconfig.theme.design
settings have been replaced by the newconfig.theme.theme
setting, which can be either the name of one of textual's builtin themes, or a customtextual.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.
- compatibility with
textual>=0.86
5.2.1 - 2024-10-30
Pypi: https://pypi.org/project/cobib/5.2.1/
- compatibility with
textual>=0.80
5.2.0 - 2024-10-30
Pypi: https://pypi.org/project/cobib/5.2.0/
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.
- new configuration settings to customize the appearance of coBib (!222):
cobib.config.theme.dark
: to specify whether a dark or light theme is usedcobib.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
andPostNoteCommand
event hooks
- the
- (DEV) the
add_files
argument to theBaseCommand.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)
- For dealing with skipping/including associated files during searches:
- the keybinding to recursively toggle all folds in the TUI's search result view
was changed from
ENTER
toBACKSPACE
(!218) - (DEV)
cobib.ui.components.entry_points
was moved tocobib.utils.entry_points
- replaced the custom help screen with textual's new builtin help panel (!240)
- the behavior of the
Home
andEnd
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/
- the behavior of the
Home
andEnd
keybindings in the TUI's list view (!217)
5.1.2 - 2024-06-23
Pypi: https://pypi.org/project/cobib/5.1.2/
- 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/
- when printing the changelog, do not remove list indents
5.1.0 - 2024-05-28
Pypi: https://pypi.org/project/cobib/5.1.0/
Check out my blog post to learn more about the features of this new release: https://mrossinek.gitlab.io/programming/cobib-becomes-fuzzy/
- approximate (or fuzzy) filter matching and search functionality (#107,#130,!177)
- the
list
andsearch
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
- using
- 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
- using
- a number of fuzzy errors can be set (this requires the optional dependency
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
- using
- LaTeX sequences can be decoded to Unicode characters:
- the
- (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
, andskip_files
- in
- (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/
- 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/
- the ability to add custom
commands
,importers
, andparsers
through entry points (#135, !139)- (DEV) a dummy plugin show-casing these extensions
- 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 nowcobib.commands.lint.LintCommand
_unify_labels
is nowcobib.commands.unify_labels.UnifyLabelsCommand
_example_config
is nowcobib.config.command.ExampleConfigCommand
- the following deprecated helper methods were removed without replacement:
- 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
- this includes the ability to
- 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
andcobib.utils.shell_helper
modules have been removed (!139) - the previously deprecated
--update
argument of theadd
command (!168) - the previously deprecated
--skip-existing
argument of theadd
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/
- the new
cobib.utils.context.get_active_app
method which returns any running textual App and replaces the need for thecobib.utils.prompt.Prompt.console
andcobib.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)
- log messages will now be displayed in the
LogPanel
of the TUI (which can be toggled with thez
keybinding) (#132,!133) - the
cobib.ui.components.prompt
module has been refactored intocobib.utils.prompt
(!133)
- 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 becomecobib lint
cobib _unify_labels
will becomecobib unify_labels
cobib _example_config
will becomecobib example_config
- loading a cached database will be bypassed during
_lint_database
(#133)- to support this the
bypass_cache
keyword-argument was added to theDatabase.read
method
- to support this the
- 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/
- 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 viaconfig.database.cache
or even disable caching entirely by changing this setting toNone
. (see also #129 and !108) - added the
-r/--remove
option to themodify
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
- this can achieve the opposite of
- added the
-l/--limit
option to thelist
command (#127)- exposed the
ListCommand.sort_entries
method in the public API - added the
ListCommand.execute_dull
method in the public API
- exposed the
- the
search
,export
, andmodify
commands now also support sorting and limiting options to be passed onto thelist
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
- 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)
- 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/
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/
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.
coBib now has a Wiki 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!
- the
-f
short-hand alias for the--field
argument of theopen
command - the
opened_entries
attribute of theOpenCommand
(which is accessible during thePostOpenCommand
hook) - the new
git
command to simplify running git operations on the database (#124) - new bindings for
Home
,End
,PageUp
, andPageDown
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 theBibtexParser
- 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 theEntry.stringify
method - the
Entry.formatted
method. This replaces theEntry.escape_special_chars
method.
- 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 errorgit
: will log an errorshow
: will log a warning
- The
LabelSuffix.CAPTIAL
value because it was misspelled. Please useLabelSuffix.CAPITAL
instead.
- 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 spelledLabelSuffix.CAPTIAL
)
- the
Entry.escape_special_chars
method. UseEntry.formatted
instead.
4.2.0 - 2023-08-08
Pypi: https://pypi.org/project/cobib/4.2.0/
- added the
config.tui.scroll_offset
setting - added the
--field
command line option to theopen
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 thanWARNING
- 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
- preset filters can be selected from the TUI via the
- 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
- adds new builtin tags which will trigger special highlights of entries:
- added the
--skip-files
command line option to thesearch
command
- 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
- this is configured via the
- 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)
- the
config.commands.search.highlights
section is deprecated in favor ofconfig.theme.search
- 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 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
toFalse
- this prompt can be disabled by setting
- added the
--no-ignore-case
(-I
for short) command line options to thelist
andsearch
command (#116) - added the
--no-preserve-files
command line options to thedelete
,edit
andmodify
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 theadd
command - the new
config.commands.import_.skip_download
setting - the new
--force-download
option of theimport
command
- the new
- the user is asked for confirmation when quitting the TUI (!71)
- 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 tolxml
- this is supposed to give more accurate results but adds an extra dependency
- 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.
- 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) ordelete
(#113) oredit
(#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)
- the crude and very slow zsh completion script
4.0.0 - 2023-05-20
Pypi: https://pypi.org/project/cobib/4.0.0/
- Configuration settings can no longer be set by item access and instead must
use attribute syntax. For example you need to change:
to
config["database"]["git"] = True
config.database.git = True
- the
config.commands.list
section had to be renamed toconfig.commands.list_
- the
config.tui
section has been entirely removed
- the
- The
cobib.commands.list
module was moved tocobib.commands.list_
. - The function signature of all command- and importer-related events has changed! For more details please refer to the online documentation.
- 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 theadd
command (#99,!58) - the
--ignore-case
argument of thelist
command (#105)- this also comes with the new
config.commands.list_.ignore_case
setting
- this also comes with the new
- the
search
command now accepts multiple query strings at once which will be searched over independently (#106)
- the new default value of
config.parsers.yaml.use_c_lib_yaml
is nowTrue
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 for more details. (!63)
- The function signature of all importer-related events has changed! Please refer to the online documentation for more details. (!66)
- the API of the
cobib.commands
andcobib.importers
module has been improved (!64)- this should not have any end-user facing effects
- the
cobib.commands.list
module was moved tocobib.commands.list_
- the
--update
argument of theadd
command is deprecated in favor of--disambiguation update
- the
--skip-existing
argument of theadd
command is deprecated in favor of--disambiguation keep
- 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
- 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/
- opening of non-list type fields (#100)
3.5.4 - 2022-12-26
Pypi: https://pypi.org/project/cobib/3.5.4/
- 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/
- 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/
- run TUI on BSD platforms (!52)
3.5.1 - 2022-04-25
Pypi: https://pypi.org/project/cobib/3.5.1/
- safely check cache existence before attempting to write (#94)
3.5.0 - 2022-01-13
Pypi: https://pypi.org/project/cobib/3.5.0/
The plan is to switch to rich and 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
- 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
- values which disable the loading entirely are:
- 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
- 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
- this setting will change its default value to
- 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)
- the
PreFileDownload
event now takes an additional argument:headers: Optional[Dict[str, str]]
- downloaded file names will not duplicate the
.pdf
suffix
3.3.2 - 2021-11-17
Pypi: https://pypi.org/project/cobib/3.3.2/
- 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
- 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/
- 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
- 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/
- 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 viacobib 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 theModifyCommand
to prevent errors during large bulk modifications
- the
config.database.format.label_default
andconfig.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
- 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
- the
-s
option of theAddCommand
is no longer available. You need to write out--skip-download
- the
ID
filter argument on thelist
command (deprecated in v3.2.0 in favor of thelabel
filter)
3.2.1 - 2021-07-15
Pypi: https://pypi.org/project/cobib/3.2.1/
- 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/
- 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 theAddCommand
- 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
- the default download location can be configured via
- 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)
- users can configure a list of journal abbreviations via
- 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
- the
modifications
of aModifyCommand
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)
- the
ID
filter argument was fully replaced bylabel
, unifying the CLI API. Support will be dropped in v3.3.0
- Removed (most) duplication of log messages
3.1.1 - 2021-05-25
Pypi: https://pypi.org/project/cobib/3.1.1/
- Pypi package metadata
3.1.0 - 2021-05-24
Pypi: https://pypi.org/project/cobib/3.1.0/
- 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
- specifying
- use file paths relative to user-home (achieved by replacing
os.path
withpathlib
) (#69) - the shell helper
_list_tags
has been renamed to_list_labels
- (DEV): the
logging
andzsh_helper
modules have been relocated to thecobib.utils
package +
symbols will no longer be stripped from tags (this was a left-over artifact from pre-v1.0.0)
- the
config.database.format.month
setting is deprecated in favor of proper three-letter code encoding to support common citation style macros (!34)
- 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!
- coBib's documentation is now generated by
pdoc
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
- the
INI
-style configuration is replaced with aPython
-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 tocobib.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
- 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
- the ZSH helper utilities now respect the
-c
,-l
, and-v
command line options - the
RedoCommand
should only revert a previouslyUndoCommand
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 theISBNParser
are caught and handled gracefully
- the functions
read_database()
andwrite_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.
init --git
will not initialize a repository unless git has configured both,name
andemail
- TUI no longer crashes when aborting to quit (#64)
2.6.0 - 2020-12-31
Pypi: https://pypi.org/project/cobib/2.6.0/
- 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 toTrue
and runningcobib init --git
- Note, that you must have at least set a
name
andemail
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 throughlist
-command filters or manual selection (by setting the--selection
flag)
- allows bulk modification of multiple entries in a
- 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
andsearch
has been renamed internally fromlist_arg
tofilter
- this should not have any visible effect to an end-user but may be relevant to developers
- 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
- The
--force
argument to theinit
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/
- support for multiple associated files (#42,!19)
- interactive menu when opening an entry with multiple associated files (!19)
- The
--force
argument to theinit
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.
- 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/
- 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/
- the
FORMAT/default_entry_type
option used for manual entry addition - a manual insertion mode available through
edit -a new_label
andadd -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 theexport
command (!18)
- TUI color highlighting is now prioritized (!17)
- 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/
- another AUR package installation error
2.3.3 - 2020-09-14
Pypi: https://pypi.org/project/cobib/2.3.3/
- AUR package installation error
2.3.2 - 2020-09-10
Pypi: https://pypi.org/project/cobib/2.3.2/
- option to default to case-insensitive searching (
DATABASE/search_ignore_case
)
- clearing the prompt, aborts the command execution
- search command correctly handles missing arguments in TUI (#43)
2.3.1 - 2020-09-10
Pypi: https://pypi.org/project/cobib/2.3.1/
- faulty Pypi package
2.3.0 - 2020-09-10
Pypi: https://pypi.org/project/cobib/2.3.0/
- 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 to3
and behaves similar to Vim'sscrolloff
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
-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.
- 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/
- 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/
- when wrapping the TUI lines, indent until after the label column (#26)
- renamed
default.ini
toexample.ini
in the documentation folder
- 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/
- allow configuring the program used to
open
associated files - prompt user before actually quitting CoBib (#33)
- implements the Search command (#7, !12)
- 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 half- and full-page scrolling (#22)
- importing from
bibtex
data defaults to not ignored non-standard entry types (#28) - suppress LaTex encoding warnings except when adding entries (#29)
Search
andSelect
print warnings to the prompt while not implemented
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/
- respect sort order reversing and filter
XOR
ing from the TUI (#18) edit
command on Mac OS (#19)
- 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/
- reset viewport position when updating buffer
2.0.0b3 - 2020-05-16
Pypi: https://pypi.org/project/cobib/2.0.0b3/
- properly assert valid current line number
2.0.0b2 - 2020-05-16
Pypi: https://pypi.org/project/cobib/2.0.0b2/
- 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/
- 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/
- internal: refactored the config into a class
- centralized the database handling to improve performance (#12,!9)
- 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/
- user configuration options for:
- TUI colors
- TUI key bindings
- TUI default list arguments
- help window highlighting
- 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 a basic curses-based TUI (#5,!7)
- internal: refactored commands into separate module
1.1.0 - 2020-03-28
Pypi: https://pypi.org/project/cobib/1.1.0/
- add
FORMAT.month
configuration option to configure the default type for month fields (defaults toint
) (#3,!4) - escape special LaTeX characters (#2,!5)
list
no longer breaks with aKeyError
when a queried field does not exist in any bibliography entry (!2)--label
can now correctly overwrite the ID (#4,!3)
set_config()
and globalCONFIG
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
- 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/
- 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
- allow sorting the list output (2a5a94f1)
- crude and slow (!!!) zsh completion (9f28f441)
- support Darwin's
open
command
- suppress list output when exporting
- add used tags to columns when listing
- sort YAML database entries by keys (d2af42d2)
- 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.
- complete rewrite to use a plain-text
yaml
database instead ofsqlite3
!1
sqlite3
database
0.1 - 2019-04-29
- initial version with a basic
sqlite3
-based database