|
|
"""Base classes and utilities for readers and writers.
|
|
|
|
|
|
Authors:
|
|
|
|
|
|
* Brian Granger
|
|
|
"""
|
|
|
|
|
|
#-----------------------------------------------------------------------------
|
|
|
# Copyright (C) 2008-2011 The IPython Development Team
|
|
|
#
|
|
|
# Distributed under the terms of the BSD License. The full license is in
|
|
|
# the file COPYING, distributed as part of this software.
|
|
|
#-----------------------------------------------------------------------------
|
|
|
|
|
|
#-----------------------------------------------------------------------------
|
|
|
# Imports
|
|
|
#-----------------------------------------------------------------------------
|
|
|
|
|
|
from base64 import encodestring, decodestring
|
|
|
import pprint
|
|
|
|
|
|
from IPython.utils.py3compat import str_to_bytes
|
|
|
|
|
|
#-----------------------------------------------------------------------------
|
|
|
# Code
|
|
|
#-----------------------------------------------------------------------------
|
|
|
|
|
|
def restore_bytes(nb):
|
|
|
"""Restore bytes of image data from unicode-only formats.
|
|
|
|
|
|
Base64 encoding is handled elsewhere. Bytes objects in the notebook are
|
|
|
always b64-encoded. We DO NOT encode/decode around file formats.
|
|
|
"""
|
|
|
for ws in nb.worksheets:
|
|
|
for cell in ws.cells:
|
|
|
if cell.cell_type == 'code':
|
|
|
for output in cell.outputs:
|
|
|
if 'png' in output:
|
|
|
output.png = str_to_bytes(output.png, 'ascii')
|
|
|
if 'jpeg' in output:
|
|
|
output.jpeg = str_to_bytes(output.jpeg, 'ascii')
|
|
|
return nb
|
|
|
|
|
|
|
|
|
# b64 encode/decode are never actually used, because all bytes objects in
|
|
|
# the notebook are already b64-encoded, and we don't need/want to double-encode
|
|
|
|
|
|
def base64_decode(nb):
|
|
|
"""Restore all bytes objects in the notebook from base64-encoded strings.
|
|
|
|
|
|
Note: This is never used
|
|
|
"""
|
|
|
for ws in nb.worksheets:
|
|
|
for cell in ws.cells:
|
|
|
if cell.cell_type == 'code':
|
|
|
for output in cell.outputs:
|
|
|
if 'png' in output:
|
|
|
if isinstance(output.png, unicode):
|
|
|
output.png = output.png.encode('ascii')
|
|
|
output.png = decodestring(output.png)
|
|
|
if 'jpeg' in output:
|
|
|
if isinstance(output.jpeg, unicode):
|
|
|
output.jpeg = output.jpeg.encode('ascii')
|
|
|
output.jpeg = decodestring(output.jpeg)
|
|
|
return nb
|
|
|
|
|
|
|
|
|
def base64_encode(nb):
|
|
|
"""Base64 encode all bytes objects in the notebook.
|
|
|
|
|
|
These will be b64-encoded unicode strings
|
|
|
|
|
|
Note: This is never used
|
|
|
"""
|
|
|
for ws in nb.worksheets:
|
|
|
for cell in ws.cells:
|
|
|
if cell.cell_type == 'code':
|
|
|
for output in cell.outputs:
|
|
|
if 'png' in output:
|
|
|
output.png = encodestring(output.png).decode('ascii')
|
|
|
if 'jpeg' in output:
|
|
|
output.jpeg = encodestring(output.jpeg).decode('ascii')
|
|
|
return nb
|
|
|
|
|
|
|
|
|
class NotebookReader(object):
|
|
|
"""A class for reading notebooks."""
|
|
|
|
|
|
def reads(self, s, **kwargs):
|
|
|
"""Read a notebook from a string."""
|
|
|
raise NotImplementedError("loads must be implemented in a subclass")
|
|
|
|
|
|
def read(self, fp, **kwargs):
|
|
|
"""Read a notebook from a file like object"""
|
|
|
return self.read(fp.read(), **kwargs)
|
|
|
|
|
|
|
|
|
class NotebookWriter(object):
|
|
|
"""A class for writing notebooks."""
|
|
|
|
|
|
def writes(self, nb, **kwargs):
|
|
|
"""Write a notebook to a string."""
|
|
|
raise NotImplementedError("loads must be implemented in a subclass")
|
|
|
|
|
|
def write(self, nb, fp, **kwargs):
|
|
|
"""Write a notebook to a file like object"""
|
|
|
return fp.write(self.writes(nb,**kwargs))
|
|
|
|
|
|
|
|
|
|
|
|
|