(changelog)=
- Set all min deps #399 (@blink1073)
- chore: update pre-commit hooks #398 (@pre-commit-ci)
(GitHub contributors page for this release)
- Revert PR #378 (Simplify NotebookNotary._data_dir_default) #397 (@krassowski)
(GitHub contributors page for this release)
- Restore usage of npm token #395 (@blink1073)
(GitHub contributors page for this release)
No merged PRs
- Update Release Scripts #394 (@blink1073)
- chore: update pre-commit hooks #391 (@pre-commit-ci)
- chore: update pre-commit hooks #390 (@pre-commit-ci)
- Update ruff and typings #388 (@blink1073)
- update incorrect warning text #386 (@Carreau)
- chore: update pre-commit hooks #385 (@pre-commit-ci)
- Clean up lint handling #384 (@blink1073)
- Adopt ruff format #383 (@blink1073)
- Update typings for mypy 1.6 #381 (@blink1073)
- chore: update pre-commit hooks #380 (@pre-commit-ci)
- Fix typing error #379 (@blink1073)
- Simplify NotebookNotary._data_dir_default #378 (@cmd-ntrf)
- Adopt sp-repo-review #377 (@blink1073)
- Bump actions/checkout from 3 to 4 #375 (@dependabot)
- update incorrect warning text #386 (@Carreau)
- Improve project URLs that display on PyPI #374 (@pydanny)
(GitHub contributors page for this release)
@blink1073 | @Carreau | @cmd-ntrf | @dependabot | @pre-commit-ci | @pydanny
- Fix version handling #372 (@blink1073)
- Fix encoding warnings #371 (@blink1073)
- Update link to notebook security #370 (@blink1073)
- Update link to notebook security #370 (@blink1073)
(GitHub contributors page for this release)
(GitHub contributors page for this release)
- Support Python 3.12 #363 (@blink1073)
- Use local coverage #360 (@blink1073)
- Bump actions/checkout from 2 to 3 #350 (@dependabot)
(GitHub contributors page for this release)
@blink1073 | @dependabot | @pre-commit-ci
- Fix codecov badge #352 (@blink1073)
- Add license #348 (@dcsaba89)
- Add more linting #345 (@blink1073)
- Only add ellipsis to NotJSONError message if message is truncated #344 (@rschroll)
- DOC: README: capitalization, title #346 (@westurner)
(GitHub contributors page for this release)
@blink1073 | @dcsaba89 | @jonabc | @pre-commit-ci | @rschroll | @westurner
(GitHub contributors page for this release)
- Fix check release #341 (@blink1073)
- Add spell checker and enforce docstrings #339 (@blink1073)
- Fix docs build #338 (@blink1073)
(GitHub contributors page for this release)
@blink1073 | @minrk | @pre-commit-ci
- Expose more attributes for typing #337 (@blink1073)
- Fix lint #336 (@blink1073)
- Adopt ruff and address lint #333 (@blink1073)
- Use base setup dependency type #329 (@blink1073)
- Switch to using Jupyter Releaser #326 (@blink1073)
- More maintenance cleanup #325 (@blink1073)
- Handle warning from jupyter client #322 (@blink1073)
- Add dependabot #320 (@blink1073)
- Clean up docs and maintenance #314 (@blink1073)
- Fix changelog target #321 (@chrisjsewell)
- Clean up docs and maintenance #314 (@blink1073)
(GitHub contributors page for this release)
@blink1073 | @chrisjsewell | @pre-commit-ci
- Always use jsonschema to handle error reporting.
- Fix deprecation warning suggestion.
- Fix handling of
__version__
on Python 3.7.
- Fix docs and type annotations for
validator.normalize
. - Switch to hatch build backend.
The biggest change in nbformat
5.5.0 is the deprecation of arguments
to validate()
that try to fix notebooks errors during validation.
validate()
is a function that is core to the security model of
Jupyter, and is assumed in a number of places to not mutate it's
argument, or try to fix notebooks passed to it.
Auto fixing of notebook in validate can also hide subtle bugs, and will therefore be updated in a near future to not take any of the argument related to auto-fixing, and fail instead of silently modifying its parameters on invalid notebooks.
nbformat
now contain a normalize
function that will return a
normalized copy of a notebook that is suitable for validation. While
offered as a convenience we discourage its use and suggest library make
sure to generate valid notebooks.
nbformat
is now built with flit, and usespyproject.toml
- Documentation and Deprecations have been updated with version number and stack levels.
- Add project URLs to
setup.py
- Fix import in
nbformat.current
- Add
mypy
and typings support - Improve CI
- Use
fastjsonschema
by default - Adopt
pre-commit
and auto-formatters - Increase minimum
jsonschema
to 2.6, handle warnings
- Add ability to capture validation errors
- Update supported python versions
- Ensure nbformat minor version is present when upgrading
- Only fix cell ID validation issues if asked
- Return the notebook when no conversion is needed
- Catch AttributeErrors stemming from ipython_genutils as ValidationErrors on read
- Don't list pytest-cov as a test dependency
- Remove dependency on IPython genutils
- Include tests in sdist but not wheel
- Change id generation to be hash based to avoid problematic word combinations
- Added tests for python 3.9
- Fixed setup.py build operations to include package data
- Fixed missing file in manifest
- Changes convert.upgrade to upgrade minor 4.x versions to 4.5
- Implemented CellIds from JEP-62
- Fixed a regression introduced when using fastjsonschema, which does not directly support to validate a "reference"/"subschema"
- Removed unreachable/unneeded code
- Added CI workflow for package release on tag push
- Add optional support for using [fastjsonschema]{.title-ref} as the JSON validation library. To enable fast validation, install [fastjsonschema]{.title-ref} and set the environment variable [NBFORMAT_VALIDATOR]{.title-ref} to the value [fastjsonschema]{.title-ref}.
- Fixed a bug where default values for validator.get_validator() failed with an import error
- nbformat.read() function has a better duck-type interface and will raise more meaningful error messages if it can't parse a notebook document.
- Allow notebook format 4.0 and 4.1 to have the arbitrary JSON mimebundles from format 4.2 for pragmatic purposes.
- Support reading/writing path-like objects has been added to read operations.
- Fixed issue causing python 2 to pick up 5.0.x releases.
- Removed debug print statements from project.
- Added schema validation files for older versions. This was breaking notebook generation.
- Starting with 5.0,
nbformat
is now Python 3 only (>= 3.5) - Add execution timings in code cell metadata for v4 spec.
"metadata": { "execution": {...}}
should be populated with kernel-specific timing information. - Documentation for how markup is used in notebooks added
- Link to json schema docs from format page added
- Documented the editable metadata flag
- Update description for collapsed field
- Documented notebook format versions 4.0-4.3 with accurate json schema specification files
- Clarified info about name's meaning for cells
- Added a default execution_count of None for new_output_cell('execute_result')
- Added support for handling nbjson kwargs
- Wheels now correctly have a LICENSE file
- Travis builds now have a few more execution environments
- Explicitly state that metadata fields can be ignored.
- Introduce official jupyter namespace inside metadata
(
metadata.jupyter
). - Introduce
source_hidden
andoutputs_hidden
as official front-end metadata fields to indicate hiding source and outputs areas. NB: These fields should not be used to hide elements in exported formats. - Fix ending the redundant storage of signatures in the signature database.
nbformat.validate
can be set to not raise a ValidationError if additional properties are included.- Fix for errors with connecting and backing up the signature database.
- Dict-like objects added to NotebookNode attributes are now transformed to be NotebookNode objects; transformation also works for [.update()]{.title-ref}.
- A new pluggable
SignatureStore
class allows specifying different ways to record the signatures of trusted notebooks. The default is still an SQLite database. Seepluggable_signature_store
for more information. nbformat.read
andnbformat.write
accept file paths as bytes as well as unicode.- Fix for calling
nbformat.validate
on an empty dictionary. - Fix for running the tests where the locale makes ASCII the default encoding.
- Include nbformat-schema files (v3 and v4) in nbformat-schema npm package.
- Include configuration for appveyor's continuous integration service.
- Update nbformat spec version to 4.2, allowing JSON outputs to have
any JSONable type, not just
object
, and mime-types of the formapplication/anything+json
. - Define basics of
authors
in notebook metadata.nb.metadata.authors
shall be a list of objects with the propertyname
, a string of each author's full name. - Update use of traitlets API to require traitlets 4.1.
- Support trusting notebooks on stdin with
cat notebook | jupyter trust
- Update nbformat spec version to 4.1, adding support for attachments on markdown and raw cells.
- Catch errors opening trust database, falling back on
:memory:
if the database cannot be opened.
The first release of nbformat as its own package.