##// END OF EJS Templates
Merge pull request #3556 from minrk/no_margv...
Matthias Bussonnier -
r11217:279d3b80 merge
parent child Browse files
Show More
@@ -1,59 +1,57
1 """Support for interactive macros in IPython"""
1 """Support for interactive macros in IPython"""
2
2
3 #*****************************************************************************
3 #*****************************************************************************
4 # Copyright (C) 2001-2005 Fernando Perez <fperez@colorado.edu>
4 # Copyright (C) 2001-2005 Fernando Perez <fperez@colorado.edu>
5 #
5 #
6 # Distributed under the terms of the BSD License. The full license is in
6 # Distributed under the terms of the BSD License. The full license is in
7 # the file COPYING, distributed as part of this software.
7 # the file COPYING, distributed as part of this software.
8 #*****************************************************************************
8 #*****************************************************************************
9
9
10 import re
10 import re
11
11
12 from IPython.utils import py3compat
12 from IPython.utils import py3compat
13 from IPython.utils.encoding import DEFAULT_ENCODING
13 from IPython.utils.encoding import DEFAULT_ENCODING
14
14
15 coding_declaration = re.compile(r"#\s*coding[:=]\s*([-\w.]+)")
15 coding_declaration = re.compile(r"#\s*coding[:=]\s*([-\w.]+)")
16
16
17 class Macro(object):
17 class Macro(object):
18 """Simple class to store the value of macros as strings.
18 """Simple class to store the value of macros as strings.
19
19
20 Macro is just a callable that executes a string of IPython
20 Macro is just a callable that executes a string of IPython
21 input when called.
21 input when called.
22
23 Args to macro are available in _margv list if you need them.
24 """
22 """
25
23
26 def __init__(self,code):
24 def __init__(self,code):
27 """store the macro value, as a single string which can be executed"""
25 """store the macro value, as a single string which can be executed"""
28 lines = []
26 lines = []
29 enc = None
27 enc = None
30 for line in code.splitlines():
28 for line in code.splitlines():
31 coding_match = coding_declaration.match(line)
29 coding_match = coding_declaration.match(line)
32 if coding_match:
30 if coding_match:
33 enc = coding_match.group(1)
31 enc = coding_match.group(1)
34 else:
32 else:
35 lines.append(line)
33 lines.append(line)
36 code = "\n".join(lines)
34 code = "\n".join(lines)
37 if isinstance(code, bytes):
35 if isinstance(code, bytes):
38 code = code.decode(enc or DEFAULT_ENCODING)
36 code = code.decode(enc or DEFAULT_ENCODING)
39 self.value = code + '\n'
37 self.value = code + '\n'
40
38
41 def __str__(self):
39 def __str__(self):
42 return py3compat.unicode_to_str(self.value)
40 return py3compat.unicode_to_str(self.value)
43
41
44 def __unicode__(self):
42 def __unicode__(self):
45 return self.value
43 return self.value
46
44
47 def __repr__(self):
45 def __repr__(self):
48 return 'IPython.macro.Macro(%s)' % repr(self.value)
46 return 'IPython.macro.Macro(%s)' % repr(self.value)
49
47
50 def __getstate__(self):
48 def __getstate__(self):
51 """ needed for safe pickling via %store """
49 """ needed for safe pickling via %store """
52 return {'value': self.value}
50 return {'value': self.value}
53
51
54 def __add__(self, other):
52 def __add__(self, other):
55 if isinstance(other, Macro):
53 if isinstance(other, Macro):
56 return Macro(self.value + other.value)
54 return Macro(self.value + other.value)
57 elif isinstance(other, basestring):
55 elif isinstance(other, basestring):
58 return Macro(self.value + other)
56 return Macro(self.value + other)
59 raise TypeError
57 raise TypeError
General Comments 0
You need to be logged in to leave comments. Login now