- Fix a regression which stopped certain error types from appearing in the UI
- Check Notebook read permission when loading a notebook.
- New experimental Dark Mode (feedback welcome!)
- Ability to directly paste images into text cells (image button on toolbar still doesn't do anything, but at least now it's possible to insert an image without it having to already have a URL)
- Notebooks are loaded incrementally (better responsiveness for large notebook files)
- Some tweaks/fixes for Scala completions and signature help
- Handle case when the browser generates continuation frames over the websocket
- Replaces
0.3.8
, which was retracted after we found a few issues in it that weren't caught. - Stability A bug that could cause data loss has been fixed in this release.
- Backups Polynote now writes a write-ahead-log (WAL) whenever it gets updates to a notebook. This WAL can be recovered using
polynote.py recover /path/to/wal-file.wal
. This is currently experimental. - Backups Polynote now saves a copy of opened notebooks into the browser's local database. This can be used in case of catastrophic server-side data loss (but where the client has been working).
- New Added a "notebook runner", invoked with
polynote.py run [OPTIONS] input-file input-files*
that can run notebooks in headless mode - Lots of fixes to the Plot UI (Thanks @JD557!)
- Handle naming collisions between Java and Python package imports. Python packages with JVM-like names no longer get swallowed by the Jep importer.
- Fixed bug: saving plots doesn't work because websocket connection dies for no apparent reason
- Fixed bug: Value of zero or
false
causes[object Object]
in table view... sigh javascript - Fixed issue: Plotting pandas DataFrame fails when column identifiers have non-string type (thanks @Baoqi!)
- Configurable port range for remote kernel comms (thanks @hadrienk!)
- Parallel downloads of JVM dependencies
- Allow complex data structure display in table view
- Fixed some edge cases in Scala code that defines classes/types/methods and uses them in later cells
- Fixed regressions:
- Cancel button not working
- Rename active notebook causes bad state / data loss
- Configured
listen
interface was ignored - Crash in SQL interpreter
- JavaScript error when attempting parameter hints
- Fix issue with launcher script
- Fix multiple series in bar chart (Thanks @JD557!)
- Surface error if kernel dies before finishing startup
- Fixed plugin script
- Fixed avatar images in commenting UI (when identity supports them)
- Added configuration for a "default" spark props template
- Reverted bug in remote kernel logging
- Switch HTTP server to https://github.com/polynote/uzhttp (this affects the
IdentityProvider.Service
interface) - Update to ZIO 1.0.0-RC18-2 (this deprecates the
Enrich
macro) - Front-end static files were moved out of the application JAR, so they can be served directly on disk. This changes the directory structure of the polynote installation by adding a
static
directory which contains the (gzipped) static files. These static files can now be served directly by a dedicated webserver if so desired. - Write
language_info
metadata to ipynb files (improves interop with notebook tools)
- Automatic conversion of PySpark <-> Spark DataFrames - it no longer matters which language you used to create the DataFrame!
- Comment support Code cells only for now. Highlight some text in a code cell and you'll be able to add a comment, similar to Google Docs.
- Environment Variable Configuration Requires isolated kernels. Can now set environment variables to be passed to the notebook process.
- Improvements to Pandas DataFrame support.
- Add new
Run to cursor
hotkey - it'sCtrl + Alt + F9
. Thanks @kuckjwi0928 ! - Added support for more IPython repr formats: Polynote now understands
_repr_svg_
,_repr_jpeg_
,_repr_png_
, and_repr_mimebundle_
- Improvement to autocomplete - it should now be higher quality and won't trigger for weird characters like
:
- Python completion improvements: Function parameter hints should now have types, dictionaries now have key completions,
and
jedi
has been updated for even more goodies - Fixed some more bugs in the Python interpreter
- Fix config number format issue. Thanks @bgparkerdev !
- A bunch of other fixes and improvements!
- Fix issue where kernel hangs trying to find
ReprsOf
something that hasvar
s in it - Make
kernel
variable implicit so it can be threaded into functions
- Remove deprecated
polynote
shell script (usepython.py
instead) - Disable notebook if writing fails repeatedly
- Unmangle package name for Spark 2.4.4 compatibility
- Validate config on server startup
- Respect language from imported Jupyter notebook
- Don't save stdout to the notebook if it's subsequently been erased
- Fix docker build for Scala 2.12/Spark 2.4
- Misc UI and backend fixes
- Better handling of unexpected kernel shutdowns
- Presence
- Add copy notebook
- Use index for import
- Use class indexer
- Manually call atexit shutdown hooks
- Fix Py4j version handling
- Added browser notifications for completed cells of unfocused notebooks
- Fix some websocket issues
- Adds UI x to close error boxes
- Retrieve causes of python exceptions
- Get jars from
SPARK_DIST_CLASSPATH
with config
- Create a websocket for every notebook
- Fixes for configuring pyspark executable locations
- Fixed some plotting and streaming data bugs
- Better completions
- Refactor the way notebook files are encoded/decoded and stored. Also fixes some issues in Zeppelin notebook import.
- Address
serialize-javascript
vulnerability - New hotkey,
Shift+F10
, to run all cells (thanks @kuckjwi0928) - Additional bugfixes and improvements
- Improved completions for Scala
- Fixed regression in python+spark interpreter where
kernel
(and thus matplotlib) isn't available.
<base>
tag can now be configured and works properly- Renaming notebooks works properly
- Fixed plot editor buttons
- Improved docker build (thanks @mathematicalmichael and @JD557)
- Removed
pysparksession
(spark
now works properly in pyspark) - More improvements to python interpreter (stack traces, red squigglies, etc)
- Compiles against JDK11 (thanks @aborg0)
- Lazy vals don't cause errors (but still aren't really lazy)
- Identity provider framework and header-based authentication
- Timeout when searching for
ReprsOf
- Fix resolution of some ivy/maven artifacts (thanks @JD557)
- Fix drag-and-drop events in Firefox (thanks @JD557)
- Support Safari (thanks @calmarj)
- Support ivy/maven credentials as coursier credentials.properties (thanks @JD557)
- Misc bugfixes improvements to remote kernel reliability
- Improve remote kernel error handling
- Make LimitedSharingClassLoader configurable (thanks @ghoto !)
- Remove
sun.misc.Cleaner
which is messes up JDK9+ - Resolve insecure py4j gateway issue (thanks again, @ghoto !)
- Fix bug in handling empty configs
- Add ability to specify multiple storage mounts
- Updated notebook list UI, with ability to rename and delete notebooks (right click), navigate with keyboard, etc
- Fixed classloading bug causing e.g. #588
- Don't override spark.app.name if it's set in the spark config
- Fix bug causing issues importing shared modules installed inside virtual environments
- Publish snapshot artifacts of all modules to sonatype
- Happy Halloween! This spoooooky release includes some minor bugfixes!
- Remove scala from the runtime assembly jars
- Set Python's sys.argv to prevent some libraries from complaining
- Configurable base URI, useful when behind a proxy
- Fix an NPE when trying to encode a null string
- Fix issue with package cells not working at all when Spark is enabled
- Self-host some external resources (font-awesome icons and katex)
- Fix critical issue in plot aggregations for collections-of-case-classes
- Attempt to fit initial plot size into available area in plot editor (fixes axes being cut off when window is too small)
- New Python Runscript which should hopefully help people who have been having trouble linking with Jep
- Improved Security by adding a unique websocket key generated on server start, reducing the chance of attacks on the local websocket by malicious users
- Support for
package
definitions in Scala Cells: users can now define package cells that are independent from other notebook cells, useful for solving serialization issues and other problems. - Update Scala to
2.11.12
fixing the error people were having on JDK 9+ - Fix a bug with numeric aggregations (thanks @JD557 !)
- Fix a bug causing compatibility issues on newer JVMs (thanks @diesalbla)
- Fix a bug causing missing state when new interpreters are started in the middle of a notebook session
- Fix compatibility with Python 3.8
- No longer shadowing Scala SparkSession variable
spark
in Python cells. PySpark users should use thepysparksession
variable to access Pyspark's SparkSession. This is a temporary solution until we have a better one in place.
- Fixes a dependency clash which was causing
NoSuchMethodError
and similar.
- Cross build for Scala 2.12
- Support for LaTeX MIME type output
- Fix some race conditions in Scala compiler
- Fix issue with nondeterministic queueing order
- Fix bug when notebook folder doesn't exist (Polynote now creates a notebook directory for you)
- Fix an issue where failed dependency downloads could cause notebook to be unresponsive until a restart
- Fix regression causing missing ExecutionInfo
- Fix regression causing the python interpreter shutdown to crash the kernel
- Fix regression causing symbol table to be stale after page reload
- Fix regression causing inserted cells not to be focused
- Remove spellcheck on code cells that would sometimes come up
- Always add a StringRepr.
- Some minor cleanup of UI events
- Update fonts to address a bug in Firefox (https://bugzilla.mozilla.org/show_bug.cgi?id=1589156)
- Add some initial docs (more to come!)
- Update the logo (slightly)
- Subtasks!
- Now related tasks are properly grouped together as parent and child tasks for less UI clutter
- Matplotlib backend
- A proper Polynote backend for Matplotlib! Only supports regular old plotting, no interactive or animation support (for now)
- Finally added a license :)
- Fix some bugs that were slowing down some Spark jobs.
- Fix some bugs with Python-Scala interop
- Fix some more data encoding bugs
- Fix some bugs with data encoding
- Surface some error messages better in the UI
- Improve completions
- Add rudimentary auto-importing, kinda
- Better output display for some types
- Two new quick link buttons to go straight to the plot and data inspectors
- Fix race condition leading to the 'double typing issue'
- Fix some data encoding bugs
- Improvements and fixes to plot editor
- Better nullability handling across the board.
- Fixes for some remote kernel sync issues
- Various bugfixes
- Fix bug setting spark output path
- Fix bug preventing download of dependencies
- Fix more completion bugs
- Fix more classloader bugs
- Fix more remote kernel bugs
- Fix cell queuing order bug
- add map types to schema view
- fix spark executors ui error
- fix remote kernel crash
- fix some bugs in Configuration UI
- fix case where some completions weren't working
- Significant rewrite of most backend code, switching over to ZIO!
- Frontend ported to Typescript!
- Fix bug preventing jar dependencies with
+
in their name from working - Fix broken restart of PySpark kernels.
- minor UI fixes
- Support for being served under HTTPS
- Fix for
Shift+Enter
creating a newline rather than executing the cell - Show tasks in Welcome screen
- Focus previous cell when last cell is deleted
- Remove formatting when converting text cells to code cells (e.g., if you copy/pasted some code and it has colors and such)
- New About modal:
- Replaced barely used View Settings ugliness with fancy new modal with a bunch of info
About
section has server version infoPreferences
section has are for setting preferences and viewing/clearing storage (can be accessed directly by clicking thegear
button.- The vim mode setting has been moved here
Hotkeys
section has all available hotkeys (can be accessed directly by clicking the?
button)Kernels
section shows all notebooks currently open by the server, with the ability to start/stop their kernel.
- Fix hidden output off-by-one error
- Stability improvements for remote kernels
- Fix error causing failure to display inspector for certain types of Dataframes
- Fix error causing compilation failure when users define variable names that look like scala's generated synthetic members
(e.g., a variable starting with
eq_
) - Add version to app name
- minor refactoring to remove some
unsafeRun*
s.
- Some minor UI improvements like
- Collapse config when save button is pressed
- Make it more obvious that output has been hidden
- Fix some cases where the vim statusline disappeared
- New Repr for Maps, show type in the data table, add Reprs for SparkSession and Runtime.
- Reload the UI upon reconnecting if it detects versions are out of whack.
- Fix cell anchor link regression
- Make step execution favicon bubble green :)
- Only create venv when python dependencies have been provided
- Overhaul python stack traces - get the actual error from py4j (e.g., pyspark) exceptions, clean up regular python stack traces.
- Improve completions in the middle of a line by truncating it when sending to the presentation compiler
- Fix a bug preventing classes extending something imported in the same cell from working properly
- Display python docstrings and types (if possible) in Parameter hints
- Force spark session shutdown to run on the right thread
- Load the default.yml config even if config.yml itself is empty (normal case upon first installation)
- Add number of queued cells to favicon
- Disable running / editing cells upon disconnect. Attempt to reconnect when window is focused.
- bust browser cache on release (hopefully you won't need to force-reload after upgrading any more!)
- Fix cyclic reference error
- Fix issue preventing vega interpreter from working properly if a string-typed variable was defined earlier
- Create a virtual environment every time.
- Lazy vals no longer cause compile errors (they still have some problems though as detailed here)
- Fix compile error preventing definition of functions with default values.
- Python Dependency support!
- You can now specify Python dependencies (there's a little drop-down you can choose from in the Configuration panel).
- When you specify these dependencies, Polynote will create a notebook-specific virtual environment and install those dependencies inside it.
- The virtual environment is configured to delegate to the system python environment so packages that already exist won't be installed again. It's persisted as well so it won't be recreated every time you restart polynote.
- Support for base
default.yml
to be provided in distributions - no more clobbering people's configs! - Fix for broken VIM mode
- Improvements to data display:
- Add chrome-inspector-style display of structures and arrays
- Add Schema tab to inspector UI for table data
- Some refactoring/removal of duplicate stuff
- Add encoding of array fields to spark table data
- Create notebooks directory if it doesn't exist
- Move cell controls to top of cell, horizontally
- Each cell has lang selector
- Buttons to show/hide code and output
- Add new Vega spec interpreter for generating plots
- Add new inspection UI
- Inspection comes up in a modal
- Remove value column from symbol table
- Upgraded plot editor
- Can save plot to a Vega spec cell
- Better UI, can edit size and titles, functioning scatter plot
- Editor size adjusts after code folding
- Remove annoying jep uninstall message #328
- Overhaul Scala compilation for better serializability and stability. #330
- Lift user-defined classes to package namespace (no more inner classes!)
- Only import necessary values from previous cells (rather than everything in that cell). Use proxy values rather than imports to avoid closing over the entire cell.
- Fix regression causing wide output to stretch cell too far #333
- Improvements to completions #335
- Install jep globally rather than locally #324
- Fix lingering positioning bugs (completions should work better now; no
OuterScopes
stuff) - Fix spark serializer issue
- Minor style fixes
- Add support for simple references to
globals()
#19 - Fix Python scoping issue causing NameErrors for imports references inside inner scopes (e.g., in a function) #315
- Add
@transient
annotation topolynote.runtime.Runtime.externalValues
, preventing Spark from serializing it. #316
- Fix Python output folding issue #295
- Duplicate notebook names now handled gracefully, we'll just increment the filename until there's no conflict #296
- Python
SyntaxError
s raised by parsing cell contents now raised asCompileErrors
rather than Runtime Errors. #301 - Fix regression which broke implicits #313
- Improve performance of UI pane resizing, other minor UI improvements
- Fix positioning regression introduced in 0.1.10
- Only close over cells that are referenced in the current cell
- Can now bust cache of URL dependencies (e.g.,
file:///
,s3://
, etc) by adding URL parameter?nocache
to the end of the path #292 - Support
s3n
ands3a
URLs as well (just a config change on our end). - Fix bug in how we were assigning Python cell expressions to
Out
#291 - Fix Spark serialization issues #300
- Fix error when printing empty lines in python
- Fix data streaming on remote kernels
- Add table operations for sequences of case classes (supports plotting)
- Clear error squigglies when cell is run
- Save cell language into metadata field of ipynb
- Improved support for terminal output
- Fix some bugs that caused cell execution to hang
- Fix regression which caused repr display not to show up
- Fix some scala interpreter bugs, including one that prevented case classes (and other things) defined in a class from being visible to other cells
- Better numpy support, fix for
Message class can only inherit from Message
error
- Fix an embarrassingly bad bug in #241
- Update coursier, giving an order-of-magnitude performance boost to dependency resolution (especially for deep dependency trees)
- Hotkey revamp #241
- Share implementation across monaco and text cells
- Added new hotkeys: Delete cell (ctrl-option-D), add cell above (ctrl-option-A), add cell below (ctrl-option-B)
- Up and Down arrows now transition to neighboring cells if cursor is at start/end of cell text
- Display cell execution time while it is running #253
- Fix RuntimeError when using a numpy array.
- Support for importing Zeppelin notebooks #185
- Just drag and drop your
note.json
onto the tree view. - Notebook creation and URL import are now two separate buttons.
- Just drag and drop your
- Can now click between cells to create a new cell #235
- New clear output button - deletes all results/outputs of a notebook from UI and underlying file #237
- Fix scrolling behavior for selected cell #240
-
Import and Export of Notebooks #215
- New download button in Notebook toolbar downloads the ipynb representation of the notebook
- Can import ipynb files by drag and drop onto the notebooks sidebar UI
- Additionaly, can import notebooks directly from another Polynote instance when creating a notebook. Just specify a URL instead of a name for the new notebook.
-
UI cleanup #224
- drag borders always visible
- some fixes for notebook panel view
-
Vim mode no longer swallows Shift+Enter #226
-
Fix bug preventing selection of leftmost tab when notebook panel was collapsed #228
-
Fix bug causing output doubling #227
-
Fix bug causing run script to fail when certain values were present in the config file #232
-
Logging and Error visibility improvements #218
- Kernel Error task message now includes stack trace
- Log kernel errors to Polynote output instead of just UI.
- Run script by default tees logs to file to help debugging later
- Run scripts included in HTML Output #205
- Add UI support for warnings
- Warn (rather than error) if eta-expansion fails #216
- Collapsible sidebars #11
- Cells now show execution progress of top-level statements (scala cells only) #221
- Add VIM mode #220
- Additional bug fixes and UI tweaks (#212, #222)
- Initial release of Polynote! :)