Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(110)

Side by Side Diff: third_party/markdown/extensions/__init__.py

Issue 133433002: Docserver: Support markdown for HTML content. Request thirdparty submission review. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: change the version of app & cron.yaml Created 6 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « third_party/markdown/blockprocessors.py ('k') | third_party/markdown/extensions/abbr.py » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
(Empty)
1 # markdown is released under the BSD license
2 # Copyright 2007, 2008 The Python Markdown Project (v. 1.7 and later)
3 # Copyright 2004, 2005, 2006 Yuri Takhteyev (v. 0.2-1.6b)
4 # Copyright 2004 Manfred Stienstra (the original version)
5 #
6 # All rights reserved.
7 #
8 # Redistribution and use in source and binary forms, with or without
9 # modification, are permitted provided that the following conditions are met:
10 #
11 # * Redistributions of source code must retain the above copyright
12 # notice, this list of conditions and the following disclaimer.
13 # * Redistributions in binary form must reproduce the above copyright
14 # notice, this list of conditions and the following disclaimer in the
15 # documentation and/or other materials provided with the distribution.
16 # * Neither the name of the <organization> nor the
17 # names of its contributors may be used to endorse or promote products
18 # derived from this software without specific prior written permission.
19 #
20 # THIS SOFTWARE IS PROVIDED BY THE PYTHON MARKDOWN PROJECT ''AS IS'' AND ANY
21 # EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
22 # WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
23 # DISCLAIMED. IN NO EVENT SHALL ANY CONTRIBUTORS TO THE PYTHON MARKDOWN PROJECT
24 # BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
25 # CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
26 # SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
27 # INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
28 # CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
29 # ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
30 # POSSIBILITY OF SUCH DAMAGE.
31
32
33 """
34 Extensions
35 -----------------------------------------------------------------------------
36 """
37
38 from __future__ import unicode_literals
39
40 class Extension(object):
41 """ Base class for extensions to subclass. """
42 def __init__(self, configs = {}):
43 """Create an instance of an Extention.
44
45 Keyword arguments:
46
47 * configs: A dict of configuration setting used by an Extension.
48 """
49 self.config = configs
50
51 def getConfig(self, key, default=''):
52 """ Return a setting for the given key or an empty string. """
53 if key in self.config:
54 return self.config[key][0]
55 else:
56 return default
57
58 def getConfigs(self):
59 """ Return all configs settings as a dict. """
60 return dict([(key, self.getConfig(key)) for key in self.config.keys()])
61
62 def getConfigInfo(self):
63 """ Return all config descriptions as a list of tuples. """
64 return [(key, self.config[key][1]) for key in self.config.keys()]
65
66 def setConfig(self, key, value):
67 """ Set a config setting for `key` with the given `value`. """
68 self.config[key][0] = value
69
70 def extendMarkdown(self, md, md_globals):
71 """
72 Add the various proccesors and patterns to the Markdown Instance.
73
74 This method must be overriden by every extension.
75
76 Keyword arguments:
77
78 * md: The Markdown instance.
79
80 * md_globals: Global variables in the markdown module namespace.
81
82 """
83 raise NotImplementedError('Extension "%s.%s" must define an "extendMarkd own"' \
84 'method.' % (self.__class__.__module__, self.__class__.__name__))
85
OLDNEW
« no previous file with comments | « third_party/markdown/blockprocessors.py ('k') | third_party/markdown/extensions/abbr.py » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698