##// END OF EJS Templates
Merge pull request #3863 from damianavila/speaker_notes...
Merge pull request #3863 from damianavila/speaker_notes Added working speaker notes for slides. To resume, I fetch the cdn containing the files we need to make speaker notes works. Then I pass this info using the resources dict to the write which output the files in the correct path... I make some other additions to make this feature an option from the command line, ie: if you want a simple slideshow: ipython nbconvert your_slides.ipynb --to slides if you want a simple served slideshow: ipython nbconvert your_slides.ipynb --to slides --post serve if you want to use a local copy of the reveal.js library: ipython nbconvert your_slides.ipynb --to slides --post serve --local reveal.js and if you want to use speaker notes: ipython nbconvert your_slides.ipynb --to slides --post serve --notes True or ipython nbconvert your_slides.ipynb --to slides --post serve --notes True --local reveal.js but this last one is redundant because if you are using a local reveal.js library the speaker notes are functional by default.

File last commit:

r11210:4702832e
r12197:4565b731 merge
Show More
macro.py
57 lines | 1.8 KiB | text/x-python | PythonLexer
"""Support for interactive macros in IPython"""
#*****************************************************************************
# Copyright (C) 2001-2005 Fernando Perez <fperez@colorado.edu>
#
# Distributed under the terms of the BSD License. The full license is in
# the file COPYING, distributed as part of this software.
#*****************************************************************************
import re
from IPython.utils import py3compat
from IPython.utils.encoding import DEFAULT_ENCODING
coding_declaration = re.compile(r"#\s*coding[:=]\s*([-\w.]+)")
class Macro(object):
"""Simple class to store the value of macros as strings.
Macro is just a callable that executes a string of IPython
input when called.
"""
def __init__(self,code):
"""store the macro value, as a single string which can be executed"""
lines = []
enc = None
for line in code.splitlines():
coding_match = coding_declaration.match(line)
if coding_match:
enc = coding_match.group(1)
else:
lines.append(line)
code = "\n".join(lines)
if isinstance(code, bytes):
code = code.decode(enc or DEFAULT_ENCODING)
self.value = code + '\n'
def __str__(self):
return py3compat.unicode_to_str(self.value)
def __unicode__(self):
return self.value
def __repr__(self):
return 'IPython.macro.Macro(%s)' % repr(self.value)
def __getstate__(self):
""" needed for safe pickling via %store """
return {'value': self.value}
def __add__(self, other):
if isinstance(other, Macro):
return Macro(self.value + other.value)
elif isinstance(other, basestring):
return Macro(self.value + other)
raise TypeError