<?xml version="1.0" encoding="ascii"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en"> <head> <title>epydoc.docwriter.html_colorize</title> <link rel="stylesheet" href="epydoc.css" type="text/css" /> <script type="text/javascript" src="epydoc.js"></script> </head> <body bgcolor="white" text="black" link="blue" vlink="#204080" alink="#204080"> <!-- ==================== NAVIGATION BAR ==================== --> <table class="navbar" border="0" width="100%" cellpadding="0" bgcolor="#a0c0ff" cellspacing="0"> <tr valign="middle"> <!-- Home link --> <th> <a href="epydoc-module.html">Home</a> </th> <!-- Tree link --> <th> <a href="module-tree.html">Trees</a> </th> <!-- Index link --> <th> <a href="identifier-index.html">Indices</a> </th> <!-- Help link --> <th> <a href="help.html">Help</a> </th> <!-- Project homepage --> <th class="navbar" align="right" width="100%"> <table border="0" cellpadding="0" cellspacing="0"> <tr><th class="navbar" align="center" ><a class="navbar" target="_top" href="http://epydoc.sourceforge.net">epydoc 3.0.1</a></th> </tr></table></th> </tr> </table> <table width="100%" cellpadding="0" cellspacing="0"> <tr valign="top"> <td width="100%"> <span class="breadcrumbs"> <a href="epydoc-module.html">Package epydoc</a> :: <a href="epydoc.docwriter-module.html">Package docwriter</a> :: Module html_colorize </span> </td> <td> <table cellpadding="0" cellspacing="0"> <!-- hide/show private --> <tr><td align="right"><span class="options">[<a href="javascript:void(0);" class="privatelink" onclick="toggle_private();">hide private</a>]</span></td></tr> <tr><td align="right"><span class="options" >[<a href="frames.html" target="_top">frames</a >] | <a href="epydoc.docwriter.html_colorize-pysrc.html" target="_top">no frames</a>]</span></td></tr> </table> </td> </tr> </table> <h1 class="epydoc">Source Code for <a href="epydoc.docwriter.html_colorize-module.html">Module epydoc.docwriter.html_colorize</a></h1> <pre class="py-src"> <a name="L1"></a><tt class="py-lineno"> 1</tt> <tt class="py-line"><tt class="py-comment">#</tt> </tt> <a name="L2"></a><tt class="py-lineno"> 2</tt> <tt class="py-line"><tt class="py-comment"></tt><tt class="py-comment"># epydoc.html: HTML colorizers</tt> </tt> <a name="L3"></a><tt class="py-lineno"> 3</tt> <tt class="py-line"><tt class="py-comment"></tt><tt class="py-comment"># Edward Loper</tt> </tt> <a name="L4"></a><tt class="py-lineno"> 4</tt> <tt class="py-line"><tt class="py-comment"></tt><tt class="py-comment">#</tt> </tt> <a name="L5"></a><tt class="py-lineno"> 5</tt> <tt class="py-line"><tt class="py-comment"></tt><tt class="py-comment"># Created [10/16/02 09:49 PM]</tt> </tt> <a name="L6"></a><tt class="py-lineno"> 6</tt> <tt class="py-line"><tt class="py-comment"></tt><tt class="py-comment"># $Id: html_colorize.py 1674 2008-01-29 06:03:36Z edloper $</tt> </tt> <a name="L7"></a><tt class="py-lineno"> 7</tt> <tt class="py-line"><tt class="py-comment"></tt><tt class="py-comment">#</tt> </tt> <a name="L8"></a><tt class="py-lineno"> 8</tt> <tt class="py-line"><tt class="py-comment"></tt> </tt> <a name="L9"></a><tt class="py-lineno"> 9</tt> <tt class="py-line"><tt class="py-docstring">"""</tt> </tt> <a name="L10"></a><tt class="py-lineno"> 10</tt> <tt class="py-line"><tt class="py-docstring">Functions to produce colorized HTML code for various objects.</tt> </tt> <a name="L11"></a><tt class="py-lineno"> 11</tt> <tt class="py-line"><tt class="py-docstring">Currently, C{html_colorize} defines functions to colorize</tt> </tt> <a name="L12"></a><tt class="py-lineno"> 12</tt> <tt class="py-line"><tt class="py-docstring">Python source code.</tt> </tt> <a name="L13"></a><tt class="py-lineno"> 13</tt> <tt class="py-line"><tt class="py-docstring">"""</tt> </tt> <a name="L14"></a><tt class="py-lineno"> 14</tt> <tt class="py-line"><tt class="py-name">__docformat__</tt> <tt class="py-op">=</tt> <tt class="py-string">'epytext en'</tt> </tt> <a name="L15"></a><tt class="py-lineno"> 15</tt> <tt class="py-line"> </tt> <a name="L16"></a><tt class="py-lineno"> 16</tt> <tt class="py-line"><tt class="py-keyword">import</tt> <tt class="py-name">re</tt><tt class="py-op">,</tt> <tt class="py-name">codecs</tt> </tt> <a name="L17"></a><tt class="py-lineno"> 17</tt> <tt class="py-line"><tt class="py-keyword">from</tt> <tt id="link-0" class="py-name" targets="Package epydoc=epydoc-module.html"><a title="epydoc" class="py-name" href="#" onclick="return doclink('link-0', 'epydoc', 'link-0');">epydoc</a></tt> <tt class="py-keyword">import</tt> <tt id="link-1" class="py-name" targets="Method epydoc.cli.ConsoleLogger.log()=epydoc.cli.ConsoleLogger-class.html#log,Method epydoc.cli.HTMLLogger.log()=epydoc.cli.HTMLLogger-class.html#log,Method epydoc.gui.GUILogger.log()=epydoc.gui.GUILogger-class.html#log,Module epydoc.log=epydoc.log-module.html,Method epydoc.log.Logger.log()=epydoc.log.Logger-class.html#log,Method epydoc.log.SimpleLogger.log()=epydoc.log.SimpleLogger-class.html#log"><a title="epydoc.cli.ConsoleLogger.log epydoc.cli.HTMLLogger.log epydoc.gui.GUILogger.log epydoc.log epydoc.log.Logger.log epydoc.log.SimpleLogger.log" class="py-name" href="#" onclick="return doclink('link-1', 'log', 'link-1');">log</a></tt> </tt> <a name="L18"></a><tt class="py-lineno"> 18</tt> <tt class="py-line"><tt class="py-keyword">from</tt> <tt id="link-2" class="py-name"><a title="epydoc" class="py-name" href="#" onclick="return doclink('link-2', 'epydoc', 'link-0');">epydoc</a></tt><tt class="py-op">.</tt><tt id="link-3" class="py-name" targets="Module epydoc.test.util=epydoc.test.util-module.html,Module epydoc.util=epydoc.util-module.html"><a title="epydoc.test.util epydoc.util" class="py-name" href="#" onclick="return doclink('link-3', 'util', 'link-3');">util</a></tt> <tt class="py-keyword">import</tt> <tt id="link-4" class="py-name" targets="Function epydoc.util.py_src_filename()=epydoc.util-module.html#py_src_filename"><a title="epydoc.util.py_src_filename" class="py-name" href="#" onclick="return doclink('link-4', 'py_src_filename', 'link-4');">py_src_filename</a></tt> </tt> <a name="L19"></a><tt class="py-lineno"> 19</tt> <tt class="py-line"><tt class="py-keyword">from</tt> <tt id="link-5" class="py-name"><a title="epydoc" class="py-name" href="#" onclick="return doclink('link-5', 'epydoc', 'link-0');">epydoc</a></tt><tt class="py-op">.</tt><tt id="link-6" class="py-name" targets="Module epydoc.apidoc=epydoc.apidoc-module.html"><a title="epydoc.apidoc" class="py-name" href="#" onclick="return doclink('link-6', 'apidoc', 'link-6');">apidoc</a></tt> <tt class="py-keyword">import</tt> <tt class="py-op">*</tt> </tt> <a name="L20"></a><tt class="py-lineno"> 20</tt> <tt class="py-line"><tt class="py-keyword">import</tt> <tt class="py-name">tokenize</tt><tt class="py-op">,</tt> <tt class="py-name">token</tt><tt class="py-op">,</tt> <tt class="py-name">cgi</tt><tt class="py-op">,</tt> <tt class="py-name">keyword</tt> </tt> <a name="L21"></a><tt class="py-lineno"> 21</tt> <tt class="py-line"><tt class="py-keyword">try</tt><tt class="py-op">:</tt> <tt class="py-keyword">from</tt> <tt class="py-name">cStringIO</tt> <tt class="py-keyword">import</tt> <tt class="py-name">StringIO</tt> </tt> <a name="L22"></a><tt class="py-lineno"> 22</tt> <tt class="py-line"><tt class="py-keyword">except</tt><tt class="py-op">:</tt> <tt class="py-keyword">from</tt> <tt class="py-name">StringIO</tt> <tt class="py-keyword">import</tt> <tt class="py-name">StringIO</tt> </tt> <a name="L23"></a><tt class="py-lineno"> 23</tt> <tt class="py-line"> </tt> <a name="L24"></a><tt class="py-lineno"> 24</tt> <tt class="py-line"><tt class="py-comment">######################################################################</tt> </tt> <a name="L25"></a><tt class="py-lineno"> 25</tt> <tt class="py-line"><tt class="py-comment"></tt><tt class="py-comment">## Python source colorizer</tt> </tt> <a name="L26"></a><tt class="py-lineno"> 26</tt> <tt class="py-line"><tt class="py-comment"></tt><tt class="py-comment">######################################################################</tt> </tt> <a name="L27"></a><tt class="py-lineno"> 27</tt> <tt class="py-line"><tt class="py-comment"></tt><tt class="py-string">"""</tt> </tt> <a name="L28"></a><tt class="py-lineno"> 28</tt> <tt class="py-line"><tt class="py-string">Goals:</tt> </tt> <a name="L29"></a><tt class="py-lineno"> 29</tt> <tt class="py-line"><tt class="py-string"> - colorize tokens appropriately (using css)</tt> </tt> <a name="L30"></a><tt class="py-lineno"> 30</tt> <tt class="py-line"><tt class="py-string"> - optionally add line numbers</tt> </tt> <a name="L31"></a><tt class="py-lineno"> 31</tt> <tt class="py-line"><tt class="py-string"> - </tt> </tt> <a name="L32"></a><tt class="py-lineno"> 32</tt> <tt class="py-line"><tt class="py-string">"""</tt> </tt> <a name="L33"></a><tt class="py-lineno"> 33</tt> <tt class="py-line"> </tt> <a name="L34"></a><tt class="py-lineno"> 34</tt> <tt class="py-line"><tt class="py-comment">#: Javascript code for the PythonSourceColorizer</tt> </tt> <a name="L35"></a><tt class="py-lineno"> 35</tt> <tt class="py-line"><tt class="py-comment"></tt><tt id="link-7" class="py-name" targets="Variable epydoc.docwriter.html_colorize.PYSRC_JAVASCRIPTS=epydoc.docwriter.html_colorize-module.html#PYSRC_JAVASCRIPTS"><a title="epydoc.docwriter.html_colorize.PYSRC_JAVASCRIPTS" class="py-name" href="#" onclick="return doclink('link-7', 'PYSRC_JAVASCRIPTS', 'link-7');">PYSRC_JAVASCRIPTS</a></tt> <tt class="py-op">=</tt> <tt class="py-string">'''\</tt> </tt> <a name="L36"></a><tt class="py-lineno"> 36</tt> <tt class="py-line"><tt class="py-string">function expand(id) {</tt> </tt> <a name="L37"></a><tt class="py-lineno"> 37</tt> <tt class="py-line"><tt class="py-string"> var elt = document.getElementById(id+"-expanded");</tt> </tt> <a name="L38"></a><tt class="py-lineno"> 38</tt> <tt class="py-line"><tt class="py-string"> if (elt) elt.style.display = "block";</tt> </tt> <a name="L39"></a><tt class="py-lineno"> 39</tt> <tt class="py-line"><tt class="py-string"> var elt = document.getElementById(id+"-expanded-linenums");</tt> </tt> <a name="L40"></a><tt class="py-lineno"> 40</tt> <tt class="py-line"><tt class="py-string"> if (elt) elt.style.display = "block";</tt> </tt> <a name="L41"></a><tt class="py-lineno"> 41</tt> <tt class="py-line"><tt class="py-string"> var elt = document.getElementById(id+"-collapsed");</tt> </tt> <a name="L42"></a><tt class="py-lineno"> 42</tt> <tt class="py-line"><tt class="py-string"> if (elt) { elt.innerHTML = ""; elt.style.display = "none"; }</tt> </tt> <a name="L43"></a><tt class="py-lineno"> 43</tt> <tt class="py-line"><tt class="py-string"> var elt = document.getElementById(id+"-collapsed-linenums");</tt> </tt> <a name="L44"></a><tt class="py-lineno"> 44</tt> <tt class="py-line"><tt class="py-string"> if (elt) { elt.innerHTML = ""; elt.style.display = "none"; }</tt> </tt> <a name="L45"></a><tt class="py-lineno"> 45</tt> <tt class="py-line"><tt class="py-string"> var elt = document.getElementById(id+"-toggle");</tt> </tt> <a name="L46"></a><tt class="py-lineno"> 46</tt> <tt class="py-line"><tt class="py-string"> if (elt) { elt.innerHTML = "-"; }</tt> </tt> <a name="L47"></a><tt class="py-lineno"> 47</tt> <tt class="py-line"><tt class="py-string">}</tt> </tt> <a name="L48"></a><tt class="py-lineno"> 48</tt> <tt class="py-line"><tt class="py-string"></tt> </tt> <a name="L49"></a><tt class="py-lineno"> 49</tt> <tt class="py-line"><tt class="py-string">function collapse(id) {</tt> </tt> <a name="L50"></a><tt class="py-lineno"> 50</tt> <tt class="py-line"><tt class="py-string"> var elt = document.getElementById(id+"-expanded");</tt> </tt> <a name="L51"></a><tt class="py-lineno"> 51</tt> <tt class="py-line"><tt class="py-string"> if (elt) elt.style.display = "none";</tt> </tt> <a name="L52"></a><tt class="py-lineno"> 52</tt> <tt class="py-line"><tt class="py-string"> var elt = document.getElementById(id+"-expanded-linenums");</tt> </tt> <a name="L53"></a><tt class="py-lineno"> 53</tt> <tt class="py-line"><tt class="py-string"> if (elt) elt.style.display = "none";</tt> </tt> <a name="L54"></a><tt class="py-lineno"> 54</tt> <tt class="py-line"><tt class="py-string"> var elt = document.getElementById(id+"-collapsed-linenums");</tt> </tt> <a name="L55"></a><tt class="py-lineno"> 55</tt> <tt class="py-line"><tt class="py-string"> if (elt) { elt.innerHTML = "<br />"; elt.style.display="block"; }</tt> </tt> <a name="L56"></a><tt class="py-lineno"> 56</tt> <tt class="py-line"><tt class="py-string"> var elt = document.getElementById(id+"-toggle");</tt> </tt> <a name="L57"></a><tt class="py-lineno"> 57</tt> <tt class="py-line"><tt class="py-string"> if (elt) { elt.innerHTML = "+"; }</tt> </tt> <a name="L58"></a><tt class="py-lineno"> 58</tt> <tt class="py-line"><tt class="py-string"> var elt = document.getElementById(id+"-collapsed");</tt> </tt> <a name="L59"></a><tt class="py-lineno"> 59</tt> <tt class="py-line"><tt class="py-string"> if (elt) {</tt> </tt> <a name="L60"></a><tt class="py-lineno"> 60</tt> <tt class="py-line"><tt class="py-string"> elt.style.display = "block";</tt> </tt> <a name="L61"></a><tt class="py-lineno"> 61</tt> <tt class="py-line"><tt class="py-string"> </tt> </tt> <a name="L62"></a><tt class="py-lineno"> 62</tt> <tt class="py-line"><tt class="py-string"> var indent = elt.getAttribute("indent");</tt> </tt> <a name="L63"></a><tt class="py-lineno"> 63</tt> <tt class="py-line"><tt class="py-string"> var pad = elt.getAttribute("pad");</tt> </tt> <a name="L64"></a><tt class="py-lineno"> 64</tt> <tt class="py-line"><tt class="py-string"> var s = "<tt class=\'py-lineno\'>";</tt> </tt> <a name="L65"></a><tt class="py-lineno"> 65</tt> <tt class="py-line"><tt class="py-string"> for (var i=0; i<pad.length; i++) { s += "&nbsp;" }</tt> </tt> <a name="L66"></a><tt class="py-lineno"> 66</tt> <tt class="py-line"><tt class="py-string"> s += "</tt>";</tt> </tt> <a name="L67"></a><tt class="py-lineno"> 67</tt> <tt class="py-line"><tt class="py-string"> s += "&nbsp;&nbsp;<tt class=\'py-line\'>";</tt> </tt> <a name="L68"></a><tt class="py-lineno"> 68</tt> <tt class="py-line"><tt class="py-string"> for (var i=0; i<indent.length; i++) { s += "&nbsp;" }</tt> </tt> <a name="L69"></a><tt class="py-lineno"> 69</tt> <tt class="py-line"><tt class="py-string"> s += "<a href=\'#\' onclick=\'expand(\\"" + id;</tt> </tt> <a name="L70"></a><tt class="py-lineno"> 70</tt> <tt class="py-line"><tt class="py-string"> s += "\\");return false\'>...</a></tt><br />";</tt> </tt> <a name="L71"></a><tt class="py-lineno"> 71</tt> <tt class="py-line"><tt class="py-string"> elt.innerHTML = s;</tt> </tt> <a name="L72"></a><tt class="py-lineno"> 72</tt> <tt class="py-line"><tt class="py-string"> }</tt> </tt> <a name="L73"></a><tt class="py-lineno"> 73</tt> <tt class="py-line"><tt class="py-string">}</tt> </tt> <a name="L74"></a><tt class="py-lineno"> 74</tt> <tt class="py-line"><tt class="py-string"></tt> </tt> <a name="L75"></a><tt class="py-lineno"> 75</tt> <tt class="py-line"><tt class="py-string">function toggle(id) {</tt> </tt> <a name="L76"></a><tt class="py-lineno"> 76</tt> <tt class="py-line"><tt class="py-string"> elt = document.getElementById(id+"-toggle");</tt> </tt> <a name="L77"></a><tt class="py-lineno"> 77</tt> <tt class="py-line"><tt class="py-string"> if (elt.innerHTML == "-")</tt> </tt> <a name="L78"></a><tt class="py-lineno"> 78</tt> <tt class="py-line"><tt class="py-string"> collapse(id); </tt> </tt> <a name="L79"></a><tt class="py-lineno"> 79</tt> <tt class="py-line"><tt class="py-string"> else</tt> </tt> <a name="L80"></a><tt class="py-lineno"> 80</tt> <tt class="py-line"><tt class="py-string"> expand(id);</tt> </tt> <a name="L81"></a><tt class="py-lineno"> 81</tt> <tt class="py-line"><tt class="py-string"> return false;</tt> </tt> <a name="L82"></a><tt class="py-lineno"> 82</tt> <tt class="py-line"><tt class="py-string">}</tt> </tt> <a name="L83"></a><tt class="py-lineno"> 83</tt> <tt class="py-line"><tt class="py-string"></tt> </tt> <a name="L84"></a><tt class="py-lineno"> 84</tt> <tt class="py-line"><tt class="py-string">function highlight(id) {</tt> </tt> <a name="L85"></a><tt class="py-lineno"> 85</tt> <tt class="py-line"><tt class="py-string"> var elt = document.getElementById(id+"-def");</tt> </tt> <a name="L86"></a><tt class="py-lineno"> 86</tt> <tt class="py-line"><tt class="py-string"> if (elt) elt.className = "py-highlight-hdr";</tt> </tt> <a name="L87"></a><tt class="py-lineno"> 87</tt> <tt class="py-line"><tt class="py-string"> var elt = document.getElementById(id+"-expanded");</tt> </tt> <a name="L88"></a><tt class="py-lineno"> 88</tt> <tt class="py-line"><tt class="py-string"> if (elt) elt.className = "py-highlight";</tt> </tt> <a name="L89"></a><tt class="py-lineno"> 89</tt> <tt class="py-line"><tt class="py-string"> var elt = document.getElementById(id+"-collapsed");</tt> </tt> <a name="L90"></a><tt class="py-lineno"> 90</tt> <tt class="py-line"><tt class="py-string"> if (elt) elt.className = "py-highlight";</tt> </tt> <a name="L91"></a><tt class="py-lineno"> 91</tt> <tt class="py-line"><tt class="py-string">}</tt> </tt> <a name="L92"></a><tt class="py-lineno"> 92</tt> <tt class="py-line"><tt class="py-string"></tt> </tt> <a name="L93"></a><tt class="py-lineno"> 93</tt> <tt class="py-line"><tt class="py-string">function num_lines(s) {</tt> </tt> <a name="L94"></a><tt class="py-lineno"> 94</tt> <tt class="py-line"><tt class="py-string"> var n = 1;</tt> </tt> <a name="L95"></a><tt class="py-lineno"> 95</tt> <tt class="py-line"><tt class="py-string"> var pos = s.indexOf("\\n");</tt> </tt> <a name="L96"></a><tt class="py-lineno"> 96</tt> <tt class="py-line"><tt class="py-string"> while ( pos > 0) {</tt> </tt> <a name="L97"></a><tt class="py-lineno"> 97</tt> <tt class="py-line"><tt class="py-string"> n += 1;</tt> </tt> <a name="L98"></a><tt class="py-lineno"> 98</tt> <tt class="py-line"><tt class="py-string"> pos = s.indexOf("\\n", pos+1);</tt> </tt> <a name="L99"></a><tt class="py-lineno"> 99</tt> <tt class="py-line"><tt class="py-string"> }</tt> </tt> <a name="L100"></a><tt class="py-lineno">100</tt> <tt class="py-line"><tt class="py-string"> return n;</tt> </tt> <a name="L101"></a><tt class="py-lineno">101</tt> <tt class="py-line"><tt class="py-string">}</tt> </tt> <a name="L102"></a><tt class="py-lineno">102</tt> <tt class="py-line"><tt class="py-string"></tt> </tt> <a name="L103"></a><tt class="py-lineno">103</tt> <tt class="py-line"><tt class="py-string">// Collapse all blocks that mave more than `min_lines` lines.</tt> </tt> <a name="L104"></a><tt class="py-lineno">104</tt> <tt class="py-line"><tt class="py-string">function collapse_all(min_lines) {</tt> </tt> <a name="L105"></a><tt class="py-lineno">105</tt> <tt class="py-line"><tt class="py-string"> var elts = document.getElementsByTagName("div");</tt> </tt> <a name="L106"></a><tt class="py-lineno">106</tt> <tt class="py-line"><tt class="py-string"> for (var i=0; i<elts.length; i++) {</tt> </tt> <a name="L107"></a><tt class="py-lineno">107</tt> <tt class="py-line"><tt class="py-string"> var elt = elts[i];</tt> </tt> <a name="L108"></a><tt class="py-lineno">108</tt> <tt class="py-line"><tt class="py-string"> var split = elt.id.indexOf("-");</tt> </tt> <a name="L109"></a><tt class="py-lineno">109</tt> <tt class="py-line"><tt class="py-string"> if (split > 0)</tt> </tt> <a name="L110"></a><tt class="py-lineno">110</tt> <tt class="py-line"><tt class="py-string"> if (elt.id.substring(split, elt.id.length) == "-expanded")</tt> </tt> <a name="L111"></a><tt class="py-lineno">111</tt> <tt class="py-line"><tt class="py-string"> if (num_lines(elt.innerHTML) > min_lines)</tt> </tt> <a name="L112"></a><tt class="py-lineno">112</tt> <tt class="py-line"><tt class="py-string"> collapse(elt.id.substring(0, split));</tt> </tt> <a name="L113"></a><tt class="py-lineno">113</tt> <tt class="py-line"><tt class="py-string"> }</tt> </tt> <a name="L114"></a><tt class="py-lineno">114</tt> <tt class="py-line"><tt class="py-string">}</tt> </tt> <a name="L115"></a><tt class="py-lineno">115</tt> <tt class="py-line"><tt class="py-string"></tt> </tt> <a name="L116"></a><tt class="py-lineno">116</tt> <tt class="py-line"><tt class="py-string">function expandto(href) {</tt> </tt> <a name="L117"></a><tt class="py-lineno">117</tt> <tt class="py-line"><tt class="py-string"> var start = href.indexOf("#")+1;</tt> </tt> <a name="L118"></a><tt class="py-lineno">118</tt> <tt class="py-line"><tt class="py-string"> if (start != 0 && start != href.length) {</tt> </tt> <a name="L119"></a><tt class="py-lineno">119</tt> <tt class="py-line"><tt class="py-string"> if (href.substring(start, href.length) != "-") {</tt> </tt> <a name="L120"></a><tt class="py-lineno">120</tt> <tt class="py-line"><tt class="py-string"> collapse_all(4);</tt> </tt> <a name="L121"></a><tt class="py-lineno">121</tt> <tt class="py-line"><tt class="py-string"> pos = href.indexOf(".", start);</tt> </tt> <a name="L122"></a><tt class="py-lineno">122</tt> <tt class="py-line"><tt class="py-string"> while (pos != -1) {</tt> </tt> <a name="L123"></a><tt class="py-lineno">123</tt> <tt class="py-line"><tt class="py-string"> var id = href.substring(start, pos);</tt> </tt> <a name="L124"></a><tt class="py-lineno">124</tt> <tt class="py-line"><tt class="py-string"> expand(id);</tt> </tt> <a name="L125"></a><tt class="py-lineno">125</tt> <tt class="py-line"><tt class="py-string"> pos = href.indexOf(".", pos+1);</tt> </tt> <a name="L126"></a><tt class="py-lineno">126</tt> <tt class="py-line"><tt class="py-string"> }</tt> </tt> <a name="L127"></a><tt class="py-lineno">127</tt> <tt class="py-line"><tt class="py-string"> var id = href.substring(start, href.length);</tt> </tt> <a name="L128"></a><tt class="py-lineno">128</tt> <tt class="py-line"><tt class="py-string"> expand(id);</tt> </tt> <a name="L129"></a><tt class="py-lineno">129</tt> <tt class="py-line"><tt class="py-string"> highlight(id);</tt> </tt> <a name="L130"></a><tt class="py-lineno">130</tt> <tt class="py-line"><tt class="py-string"> }</tt> </tt> <a name="L131"></a><tt class="py-lineno">131</tt> <tt class="py-line"><tt class="py-string"> }</tt> </tt> <a name="L132"></a><tt class="py-lineno">132</tt> <tt class="py-line"><tt class="py-string">}</tt> </tt> <a name="L133"></a><tt class="py-lineno">133</tt> <tt class="py-line"><tt class="py-string"></tt> </tt> <a name="L134"></a><tt class="py-lineno">134</tt> <tt class="py-line"><tt class="py-string">function kill_doclink(id) {</tt> </tt> <a name="L135"></a><tt class="py-lineno">135</tt> <tt class="py-line"><tt class="py-string"> var parent = document.getElementById(id);</tt> </tt> <a name="L136"></a><tt class="py-lineno">136</tt> <tt class="py-line"><tt class="py-string"> parent.removeChild(parent.childNodes.item(0));</tt> </tt> <a name="L137"></a><tt class="py-lineno">137</tt> <tt class="py-line"><tt class="py-string">}</tt> </tt> <a name="L138"></a><tt class="py-lineno">138</tt> <tt class="py-line"><tt class="py-string">function auto_kill_doclink(ev) {</tt> </tt> <a name="L139"></a><tt class="py-lineno">139</tt> <tt class="py-line"><tt class="py-string"> if (!ev) var ev = window.event;</tt> </tt> <a name="L140"></a><tt class="py-lineno">140</tt> <tt class="py-line"><tt class="py-string"> if (!this.contains(ev.toElement)) {</tt> </tt> <a name="L141"></a><tt class="py-lineno">141</tt> <tt class="py-line"><tt class="py-string"> var parent = document.getElementById(this.parentID);</tt> </tt> <a name="L142"></a><tt class="py-lineno">142</tt> <tt class="py-line"><tt class="py-string"> parent.removeChild(parent.childNodes.item(0));</tt> </tt> <a name="L143"></a><tt class="py-lineno">143</tt> <tt class="py-line"><tt class="py-string"> }</tt> </tt> <a name="L144"></a><tt class="py-lineno">144</tt> <tt class="py-line"><tt class="py-string">}</tt> </tt> <a name="L145"></a><tt class="py-lineno">145</tt> <tt class="py-line"><tt class="py-string"></tt> </tt> <a name="L146"></a><tt class="py-lineno">146</tt> <tt class="py-line"><tt class="py-string">function doclink(id, name, targets_id) {</tt> </tt> <a name="L147"></a><tt class="py-lineno">147</tt> <tt class="py-line"><tt class="py-string"> var elt = document.getElementById(id);</tt> </tt> <a name="L148"></a><tt class="py-lineno">148</tt> <tt class="py-line"><tt class="py-string"></tt> </tt> <a name="L149"></a><tt class="py-lineno">149</tt> <tt class="py-line"><tt class="py-string"> // If we already opened the box, then destroy it.</tt> </tt> <a name="L150"></a><tt class="py-lineno">150</tt> <tt class="py-line"><tt class="py-string"> // (This case should never occur, but leave it in just in case.)</tt> </tt> <a name="L151"></a><tt class="py-lineno">151</tt> <tt class="py-line"><tt class="py-string"> if (elt.childNodes.length > 1) {</tt> </tt> <a name="L152"></a><tt class="py-lineno">152</tt> <tt class="py-line"><tt class="py-string"> elt.removeChild(elt.childNodes.item(0));</tt> </tt> <a name="L153"></a><tt class="py-lineno">153</tt> <tt class="py-line"><tt class="py-string"> }</tt> </tt> <a name="L154"></a><tt class="py-lineno">154</tt> <tt class="py-line"><tt class="py-string"> else {</tt> </tt> <a name="L155"></a><tt class="py-lineno">155</tt> <tt class="py-line"><tt class="py-string"> // The outer box: relative + inline positioning.</tt> </tt> <a name="L156"></a><tt class="py-lineno">156</tt> <tt class="py-line"><tt class="py-string"> var box1 = document.createElement("div");</tt> </tt> <a name="L157"></a><tt class="py-lineno">157</tt> <tt class="py-line"><tt class="py-string"> box1.style.position = "relative";</tt> </tt> <a name="L158"></a><tt class="py-lineno">158</tt> <tt class="py-line"><tt class="py-string"> box1.style.display = "inline";</tt> </tt> <a name="L159"></a><tt class="py-lineno">159</tt> <tt class="py-line"><tt class="py-string"> box1.style.top = 0;</tt> </tt> <a name="L160"></a><tt class="py-lineno">160</tt> <tt class="py-line"><tt class="py-string"> box1.style.left = 0;</tt> </tt> <a name="L161"></a><tt class="py-lineno">161</tt> <tt class="py-line"><tt class="py-string"> </tt> </tt> <a name="L162"></a><tt class="py-lineno">162</tt> <tt class="py-line"><tt class="py-string"> // A shadow for fun</tt> </tt> <a name="L163"></a><tt class="py-lineno">163</tt> <tt class="py-line"><tt class="py-string"> var shadow = document.createElement("div");</tt> </tt> <a name="L164"></a><tt class="py-lineno">164</tt> <tt class="py-line"><tt class="py-string"> shadow.style.position = "absolute";</tt> </tt> <a name="L165"></a><tt class="py-lineno">165</tt> <tt class="py-line"><tt class="py-string"> shadow.style.left = "-1.3em";</tt> </tt> <a name="L166"></a><tt class="py-lineno">166</tt> <tt class="py-line"><tt class="py-string"> shadow.style.top = "-1.3em";</tt> </tt> <a name="L167"></a><tt class="py-lineno">167</tt> <tt class="py-line"><tt class="py-string"> shadow.style.background = "#404040";</tt> </tt> <a name="L168"></a><tt class="py-lineno">168</tt> <tt class="py-line"><tt class="py-string"> </tt> </tt> <a name="L169"></a><tt class="py-lineno">169</tt> <tt class="py-line"><tt class="py-string"> // The inner box: absolute positioning.</tt> </tt> <a name="L170"></a><tt class="py-lineno">170</tt> <tt class="py-line"><tt class="py-string"> var box2 = document.createElement("div");</tt> </tt> <a name="L171"></a><tt class="py-lineno">171</tt> <tt class="py-line"><tt class="py-string"> box2.style.position = "relative";</tt> </tt> <a name="L172"></a><tt class="py-lineno">172</tt> <tt class="py-line"><tt class="py-string"> box2.style.border = "1px solid #a0a0a0";</tt> </tt> <a name="L173"></a><tt class="py-lineno">173</tt> <tt class="py-line"><tt class="py-string"> box2.style.left = "-.2em";</tt> </tt> <a name="L174"></a><tt class="py-lineno">174</tt> <tt class="py-line"><tt class="py-string"> box2.style.top = "-.2em";</tt> </tt> <a name="L175"></a><tt class="py-lineno">175</tt> <tt class="py-line"><tt class="py-string"> box2.style.background = "white";</tt> </tt> <a name="L176"></a><tt class="py-lineno">176</tt> <tt class="py-line"><tt class="py-string"> box2.style.padding = ".3em .4em .3em .4em";</tt> </tt> <a name="L177"></a><tt class="py-lineno">177</tt> <tt class="py-line"><tt class="py-string"> box2.style.fontStyle = "normal";</tt> </tt> <a name="L178"></a><tt class="py-lineno">178</tt> <tt class="py-line"><tt class="py-string"> box2.onmouseout=auto_kill_doclink;</tt> </tt> <a name="L179"></a><tt class="py-lineno">179</tt> <tt class="py-line"><tt class="py-string"> box2.parentID = id;</tt> </tt> <a name="L180"></a><tt class="py-lineno">180</tt> <tt class="py-line"><tt class="py-string"></tt> </tt> <a name="L181"></a><tt class="py-lineno">181</tt> <tt class="py-line"><tt class="py-string"> // Get the targets</tt> </tt> <a name="L182"></a><tt class="py-lineno">182</tt> <tt class="py-line"><tt class="py-string"> var targets_elt = document.getElementById(targets_id);</tt> </tt> <a name="L183"></a><tt class="py-lineno">183</tt> <tt class="py-line"><tt class="py-string"> var targets = targets_elt.getAttribute("targets");</tt> </tt> <a name="L184"></a><tt class="py-lineno">184</tt> <tt class="py-line"><tt class="py-string"> var links = "";</tt> </tt> <a name="L185"></a><tt class="py-lineno">185</tt> <tt class="py-line"><tt class="py-string"> target_list = targets.split(",");</tt> </tt> <a name="L186"></a><tt class="py-lineno">186</tt> <tt class="py-line"><tt class="py-string"> for (var i=0; i<target_list.length; i++) {</tt> </tt> <a name="L187"></a><tt class="py-lineno">187</tt> <tt class="py-line"><tt class="py-string"> var target = target_list[i].split("=");</tt> </tt> <a name="L188"></a><tt class="py-lineno">188</tt> <tt class="py-line"><tt class="py-string"> links += "<li><a href=\'" + target[1] + </tt> </tt> <a name="L189"></a><tt class="py-lineno">189</tt> <tt class="py-line"><tt class="py-string"> "\' style=\'text-decoration:none\'>" +</tt> </tt> <a name="L190"></a><tt class="py-lineno">190</tt> <tt class="py-line"><tt class="py-string"> target[0] + "</a></li>";</tt> </tt> <a name="L191"></a><tt class="py-lineno">191</tt> <tt class="py-line"><tt class="py-string"> }</tt> </tt> <a name="L192"></a><tt class="py-lineno">192</tt> <tt class="py-line"><tt class="py-string"> </tt> </tt> <a name="L193"></a><tt class="py-lineno">193</tt> <tt class="py-line"><tt class="py-string"> // Put it all together.</tt> </tt> <a name="L194"></a><tt class="py-lineno">194</tt> <tt class="py-line"><tt class="py-string"> elt.insertBefore(box1, elt.childNodes.item(0));</tt> </tt> <a name="L195"></a><tt class="py-lineno">195</tt> <tt class="py-line"><tt class="py-string"> //box1.appendChild(box2);</tt> </tt> <a name="L196"></a><tt class="py-lineno">196</tt> <tt class="py-line"><tt class="py-string"> box1.appendChild(shadow);</tt> </tt> <a name="L197"></a><tt class="py-lineno">197</tt> <tt class="py-line"><tt class="py-string"> shadow.appendChild(box2);</tt> </tt> <a name="L198"></a><tt class="py-lineno">198</tt> <tt class="py-line"><tt class="py-string"> box2.innerHTML =</tt> </tt> <a name="L199"></a><tt class="py-lineno">199</tt> <tt class="py-line"><tt class="py-string"> "Which <b>"+name+"</b> do you want to see documentation for?" +</tt> </tt> <a name="L200"></a><tt class="py-lineno">200</tt> <tt class="py-line"><tt class="py-string"> "<ul style=\'margin-bottom: 0;\'>" +</tt> </tt> <a name="L201"></a><tt class="py-lineno">201</tt> <tt class="py-line"><tt class="py-string"> links + </tt> </tt> <a name="L202"></a><tt class="py-lineno">202</tt> <tt class="py-line"><tt class="py-string"> "<li><a href=\'#\' style=\'text-decoration:none\' " +</tt> </tt> <a name="L203"></a><tt class="py-lineno">203</tt> <tt class="py-line"><tt class="py-string"> "onclick=\'kill_doclink(\\""+id+"\\");return false;\'>"+</tt> </tt> <a name="L204"></a><tt class="py-lineno">204</tt> <tt class="py-line"><tt class="py-string"> "<i>None of the above</i></a></li></ul>";</tt> </tt> <a name="L205"></a><tt class="py-lineno">205</tt> <tt class="py-line"><tt class="py-string"> }</tt> </tt> <a name="L206"></a><tt class="py-lineno">206</tt> <tt class="py-line"><tt class="py-string"> return false;</tt> </tt> <a name="L207"></a><tt class="py-lineno">207</tt> <tt class="py-line"><tt class="py-string">}</tt> </tt> <a name="L208"></a><tt class="py-lineno">208</tt> <tt class="py-line"><tt class="py-string">'''</tt> </tt> <a name="L209"></a><tt class="py-lineno">209</tt> <tt class="py-line"> </tt> <a name="L210"></a><tt class="py-lineno">210</tt> <tt class="py-line"><tt id="link-8" class="py-name" targets="Variable epydoc.docwriter.html_colorize.PYSRC_EXPANDTO_JAVASCRIPT=epydoc.docwriter.html_colorize-module.html#PYSRC_EXPANDTO_JAVASCRIPT"><a title="epydoc.docwriter.html_colorize.PYSRC_EXPANDTO_JAVASCRIPT" class="py-name" href="#" onclick="return doclink('link-8', 'PYSRC_EXPANDTO_JAVASCRIPT', 'link-8');">PYSRC_EXPANDTO_JAVASCRIPT</a></tt> <tt class="py-op">=</tt> <tt class="py-string">'''\</tt> </tt> <a name="L211"></a><tt class="py-lineno">211</tt> <tt class="py-line"><tt class="py-string"><script type="text/javascript"></tt> </tt> <a name="L212"></a><tt class="py-lineno">212</tt> <tt class="py-line"><tt class="py-string"><!--</tt> </tt> <a name="L213"></a><tt class="py-lineno">213</tt> <tt class="py-line"><tt class="py-string">expandto(location.href);</tt> </tt> <a name="L214"></a><tt class="py-lineno">214</tt> <tt class="py-line"><tt class="py-string">// --></tt> </tt> <a name="L215"></a><tt class="py-lineno">215</tt> <tt class="py-line"><tt class="py-string"></script></tt> </tt> <a name="L216"></a><tt class="py-lineno">216</tt> <tt class="py-line"><tt class="py-string">'''</tt> </tt> <a name="L217"></a><tt class="py-lineno">217</tt> <tt class="py-line"> </tt> <a name="PythonSourceColorizer"></a><div id="PythonSourceColorizer-def"><a name="L218"></a><tt class="py-lineno">218</tt> <a class="py-toggle" href="#" id="PythonSourceColorizer-toggle" onclick="return toggle('PythonSourceColorizer');">-</a><tt class="py-line"><tt class="py-keyword">class</tt> <a class="py-def-name" href="epydoc.docwriter.html_colorize.PythonSourceColorizer-class.html">PythonSourceColorizer</a><tt class="py-op">:</tt> </tt> </div><div id="PythonSourceColorizer-collapsed" style="display:none;" pad="+++" indent="++++"></div><div id="PythonSourceColorizer-expanded"><a name="L219"></a><tt class="py-lineno">219</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt> <a name="L220"></a><tt class="py-lineno">220</tt> <tt class="py-line"><tt class="py-docstring"> A class that renders a python module's source code into HTML</tt> </tt> <a name="L221"></a><tt class="py-lineno">221</tt> <tt class="py-line"><tt class="py-docstring"> pages. These HTML pages are intended to be provided along with</tt> </tt> <a name="L222"></a><tt class="py-lineno">222</tt> <tt class="py-line"><tt class="py-docstring"> the API documentation for a module, in case a user wants to learn</tt> </tt> <a name="L223"></a><tt class="py-lineno">223</tt> <tt class="py-line"><tt class="py-docstring"> more about a particular object by examining its source code.</tt> </tt> <a name="L224"></a><tt class="py-lineno">224</tt> <tt class="py-line"><tt class="py-docstring"> Links are therefore generated from the API documentation to the</tt> </tt> <a name="L225"></a><tt class="py-lineno">225</tt> <tt class="py-line"><tt class="py-docstring"> source code pages, and from the source code pages back into the</tt> </tt> <a name="L226"></a><tt class="py-lineno">226</tt> <tt class="py-line"><tt class="py-docstring"> API documentation.</tt> </tt> <a name="L227"></a><tt class="py-lineno">227</tt> <tt class="py-line"><tt class="py-docstring"></tt> </tt> <a name="L228"></a><tt class="py-lineno">228</tt> <tt class="py-line"><tt class="py-docstring"> The HTML generated by C{PythonSourceColorizer} has several notable</tt> </tt> <a name="L229"></a><tt class="py-lineno">229</tt> <tt class="py-line"><tt class="py-docstring"> features:</tt> </tt> <a name="L230"></a><tt class="py-lineno">230</tt> <tt class="py-line"><tt class="py-docstring"></tt> </tt> <a name="L231"></a><tt class="py-lineno">231</tt> <tt class="py-line"><tt class="py-docstring"> - CSS styles are used to color tokens according to their type.</tt> </tt> <a name="L232"></a><tt class="py-lineno">232</tt> <tt class="py-line"><tt class="py-docstring"> (See L{CSS_CLASSES} for a list of the different token types</tt> </tt> <a name="L233"></a><tt class="py-lineno">233</tt> <tt class="py-line"><tt class="py-docstring"> that are identified).</tt> </tt> <a name="L234"></a><tt class="py-lineno">234</tt> <tt class="py-line"><tt class="py-docstring"> </tt> </tt> <a name="L235"></a><tt class="py-lineno">235</tt> <tt class="py-line"><tt class="py-docstring"> - Line numbers are included to the left of each line.</tt> </tt> <a name="L236"></a><tt class="py-lineno">236</tt> <tt class="py-line"><tt class="py-docstring"></tt> </tt> <a name="L237"></a><tt class="py-lineno">237</tt> <tt class="py-line"><tt class="py-docstring"> - The first line of each class and function definition includes</tt> </tt> <a name="L238"></a><tt class="py-lineno">238</tt> <tt class="py-line"><tt class="py-docstring"> a link to the API source documentation for that object.</tt> </tt> <a name="L239"></a><tt class="py-lineno">239</tt> <tt class="py-line"><tt class="py-docstring"></tt> </tt> <a name="L240"></a><tt class="py-lineno">240</tt> <tt class="py-line"><tt class="py-docstring"> - The first line of each class and function definition includes</tt> </tt> <a name="L241"></a><tt class="py-lineno">241</tt> <tt class="py-line"><tt class="py-docstring"> an anchor that can be used to link directly to that class or</tt> </tt> <a name="L242"></a><tt class="py-lineno">242</tt> <tt class="py-line"><tt class="py-docstring"> function.</tt> </tt> <a name="L243"></a><tt class="py-lineno">243</tt> <tt class="py-line"><tt class="py-docstring"></tt> </tt> <a name="L244"></a><tt class="py-lineno">244</tt> <tt class="py-line"><tt class="py-docstring"> - If javascript is enabled, and the page is loaded using the</tt> </tt> <a name="L245"></a><tt class="py-lineno">245</tt> <tt class="py-line"><tt class="py-docstring"> anchor for a class or function (i.e., if the url ends in</tt> </tt> <a name="L246"></a><tt class="py-lineno">246</tt> <tt class="py-line"><tt class="py-docstring"> C{'#I{<name>}'}), then that class or function will automatically</tt> </tt> <a name="L247"></a><tt class="py-lineno">247</tt> <tt class="py-line"><tt class="py-docstring"> be highlighted; and all other classes and function definition</tt> </tt> <a name="L248"></a><tt class="py-lineno">248</tt> <tt class="py-line"><tt class="py-docstring"> blocks will be 'collapsed'. These collapsed blocks can be</tt> </tt> <a name="L249"></a><tt class="py-lineno">249</tt> <tt class="py-line"><tt class="py-docstring"> expanded by clicking on them.</tt> </tt> <a name="L250"></a><tt class="py-lineno">250</tt> <tt class="py-line"><tt class="py-docstring"></tt> </tt> <a name="L251"></a><tt class="py-lineno">251</tt> <tt class="py-line"><tt class="py-docstring"> - Unicode input is supported (including automatic detection</tt> </tt> <a name="L252"></a><tt class="py-lineno">252</tt> <tt class="py-line"><tt class="py-docstring"> of C{'coding:'} declarations).</tt> </tt> <a name="L253"></a><tt class="py-lineno">253</tt> <tt class="py-line"><tt class="py-docstring"></tt> </tt> <a name="L254"></a><tt class="py-lineno">254</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt> <a name="L255"></a><tt class="py-lineno">255</tt> <tt class="py-line"> <tt class="py-comment">#: A look-up table that is used to determine which CSS class</tt> </tt> <a name="L256"></a><tt class="py-lineno">256</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: should be used to colorize a given token. The following keys</tt> </tt> <a name="L257"></a><tt class="py-lineno">257</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: may be used:</tt> </tt> <a name="L258"></a><tt class="py-lineno">258</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: - Any token name (e.g., C{'STRING'})</tt> </tt> <a name="L259"></a><tt class="py-lineno">259</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: - Any operator token (e.g., C{'='} or C{'@'}).</tt> </tt> <a name="L260"></a><tt class="py-lineno">260</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: - C{'KEYWORD'} -- Python keywords such as C{'for'} and C{'if'}</tt> </tt> <a name="L261"></a><tt class="py-lineno">261</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: - C{'DEFNAME'} -- the name of a class or function at the top</tt> </tt> <a name="L262"></a><tt class="py-lineno">262</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: of its definition statement.</tt> </tt> <a name="L263"></a><tt class="py-lineno">263</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: - C{'BASECLASS'} -- names of base classes at the top of a class</tt> </tt> <a name="L264"></a><tt class="py-lineno">264</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: definition statement.</tt> </tt> <a name="L265"></a><tt class="py-lineno">265</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: - C{'PARAM'} -- function parameters</tt> </tt> <a name="L266"></a><tt class="py-lineno">266</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: - C{'DOCSTRING'} -- docstrings</tt> </tt> <a name="L267"></a><tt class="py-lineno">267</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: - C{'DECORATOR'} -- decorator names</tt> </tt> <a name="L268"></a><tt class="py-lineno">268</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: If no CSS class can be found for a given token, then it won't</tt> </tt> <a name="L269"></a><tt class="py-lineno">269</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: be marked with any CSS class.</tt> </tt> <a name="L270"></a><tt class="py-lineno">270</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt id="link-9" class="py-name" targets="Variable epydoc.docwriter.html_colorize.PythonSourceColorizer.CSS_CLASSES=epydoc.docwriter.html_colorize.PythonSourceColorizer-class.html#CSS_CLASSES"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.CSS_CLASSES" class="py-name" href="#" onclick="return doclink('link-9', 'CSS_CLASSES', 'link-9');">CSS_CLASSES</a></tt> <tt class="py-op">=</tt> <tt class="py-op">{</tt> </tt> <a name="L271"></a><tt class="py-lineno">271</tt> <tt class="py-line"> <tt class="py-string">'NUMBER'</tt><tt class="py-op">:</tt> <tt class="py-string">'py-number'</tt><tt class="py-op">,</tt> </tt> <a name="L272"></a><tt class="py-lineno">272</tt> <tt class="py-line"> <tt class="py-string">'STRING'</tt><tt class="py-op">:</tt> <tt class="py-string">'py-string'</tt><tt class="py-op">,</tt> </tt> <a name="L273"></a><tt class="py-lineno">273</tt> <tt class="py-line"> <tt class="py-string">'COMMENT'</tt><tt class="py-op">:</tt> <tt class="py-string">'py-comment'</tt><tt class="py-op">,</tt> </tt> <a name="L274"></a><tt class="py-lineno">274</tt> <tt class="py-line"> <tt class="py-string">'NAME'</tt><tt class="py-op">:</tt> <tt class="py-string">'py-name'</tt><tt class="py-op">,</tt> </tt> <a name="L275"></a><tt class="py-lineno">275</tt> <tt class="py-line"> <tt class="py-string">'KEYWORD'</tt><tt class="py-op">:</tt> <tt class="py-string">'py-keyword'</tt><tt class="py-op">,</tt> </tt> <a name="L276"></a><tt class="py-lineno">276</tt> <tt class="py-line"> <tt class="py-string">'DEFNAME'</tt><tt class="py-op">:</tt> <tt class="py-string">'py-def-name'</tt><tt class="py-op">,</tt> </tt> <a name="L277"></a><tt class="py-lineno">277</tt> <tt class="py-line"> <tt class="py-string">'BASECLASS'</tt><tt class="py-op">:</tt> <tt class="py-string">'py-base-class'</tt><tt class="py-op">,</tt> </tt> <a name="L278"></a><tt class="py-lineno">278</tt> <tt class="py-line"> <tt class="py-string">'PARAM'</tt><tt class="py-op">:</tt> <tt class="py-string">'py-param'</tt><tt class="py-op">,</tt> </tt> <a name="L279"></a><tt class="py-lineno">279</tt> <tt class="py-line"> <tt class="py-string">'DOCSTRING'</tt><tt class="py-op">:</tt> <tt class="py-string">'py-docstring'</tt><tt class="py-op">,</tt> </tt> <a name="L280"></a><tt class="py-lineno">280</tt> <tt class="py-line"> <tt class="py-string">'DECORATOR'</tt><tt class="py-op">:</tt> <tt class="py-string">'py-decorator'</tt><tt class="py-op">,</tt> </tt> <a name="L281"></a><tt class="py-lineno">281</tt> <tt class="py-line"> <tt class="py-string">'OP'</tt><tt class="py-op">:</tt> <tt class="py-string">'py-op'</tt><tt class="py-op">,</tt> </tt> <a name="L282"></a><tt class="py-lineno">282</tt> <tt class="py-line"> <tt class="py-string">'@'</tt><tt class="py-op">:</tt> <tt class="py-string">'py-decorator'</tt><tt class="py-op">,</tt> </tt> <a name="L283"></a><tt class="py-lineno">283</tt> <tt class="py-line"> <tt class="py-op">}</tt> </tt> <a name="L284"></a><tt class="py-lineno">284</tt> <tt class="py-line"> </tt> <a name="L285"></a><tt class="py-lineno">285</tt> <tt class="py-line"> <tt class="py-comment">#: HTML code for the beginning of a collapsable function or class</tt> </tt> <a name="L286"></a><tt class="py-lineno">286</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: definition block. The block contains two <div>...</div></tt> </tt> <a name="L287"></a><tt class="py-lineno">287</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: elements -- a collapsed version and an expanded version -- and</tt> </tt> <a name="L288"></a><tt class="py-lineno">288</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: only one of these elements is visible at any given time. By</tt> </tt> <a name="L289"></a><tt class="py-lineno">289</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: default, all definition blocks are expanded.</tt> </tt> <a name="L290"></a><tt class="py-lineno">290</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#:</tt> </tt> <a name="L291"></a><tt class="py-lineno">291</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: This string should be interpolated with the following values::</tt> </tt> <a name="L292"></a><tt class="py-lineno">292</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: (name, indentation, name)</tt> </tt> <a name="L293"></a><tt class="py-lineno">293</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: Where C{name} is the anchor name for the function or class; and</tt> </tt> <a name="L294"></a><tt class="py-lineno">294</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: indentation is a string of whitespace used to indent the</tt> </tt> <a name="L295"></a><tt class="py-lineno">295</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: ellipsis marker in the collapsed version.</tt> </tt> <a name="L296"></a><tt class="py-lineno">296</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt id="link-10" class="py-name" targets="Variable epydoc.docwriter.html_colorize.PythonSourceColorizer.START_DEF_BLOCK=epydoc.docwriter.html_colorize.PythonSourceColorizer-class.html#START_DEF_BLOCK"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.START_DEF_BLOCK" class="py-name" href="#" onclick="return doclink('link-10', 'START_DEF_BLOCK', 'link-10');">START_DEF_BLOCK</a></tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt> </tt> <a name="L297"></a><tt class="py-lineno">297</tt> <tt class="py-line"> <tt class="py-string">'<div id="%s-collapsed" style="display:none;" '</tt> </tt> <a name="L298"></a><tt class="py-lineno">298</tt> <tt class="py-line"> <tt class="py-string">'pad="%s" indent="%s"></div>'</tt> </tt> <a name="L299"></a><tt class="py-lineno">299</tt> <tt class="py-line"> <tt class="py-string">'<div id="%s-expanded">'</tt><tt class="py-op">)</tt> </tt> <a name="L300"></a><tt class="py-lineno">300</tt> <tt class="py-line"> </tt> <a name="L301"></a><tt class="py-lineno">301</tt> <tt class="py-line"> <tt class="py-comment">#: HTML code for the end of a collapsable function or class</tt> </tt> <a name="L302"></a><tt class="py-lineno">302</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: definition block.</tt> </tt> <a name="L303"></a><tt class="py-lineno">303</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt id="link-11" class="py-name" targets="Variable epydoc.docwriter.html_colorize.PythonSourceColorizer.END_DEF_BLOCK=epydoc.docwriter.html_colorize.PythonSourceColorizer-class.html#END_DEF_BLOCK"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.END_DEF_BLOCK" class="py-name" href="#" onclick="return doclink('link-11', 'END_DEF_BLOCK', 'link-11');">END_DEF_BLOCK</a></tt> <tt class="py-op">=</tt> <tt class="py-string">'</div>'</tt> </tt> <a name="L304"></a><tt class="py-lineno">304</tt> <tt class="py-line"> </tt> <a name="L305"></a><tt class="py-lineno">305</tt> <tt class="py-line"> <tt class="py-comment">#: A regular expression used to pick out the unicode encoding for</tt> </tt> <a name="L306"></a><tt class="py-lineno">306</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: the source file.</tt> </tt> <a name="L307"></a><tt class="py-lineno">307</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt id="link-12" class="py-name" targets="Variable epydoc.docwriter.html_colorize.PythonSourceColorizer.UNICODE_CODING_RE=epydoc.docwriter.html_colorize.PythonSourceColorizer-class.html#UNICODE_CODING_RE"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.UNICODE_CODING_RE" class="py-name" href="#" onclick="return doclink('link-12', 'UNICODE_CODING_RE', 'link-12');">UNICODE_CODING_RE</a></tt> <tt class="py-op">=</tt> <tt class="py-name">re</tt><tt class="py-op">.</tt><tt class="py-name">compile</tt><tt class="py-op">(</tt><tt class="py-string">r'.*?\n?.*?coding[:=]\s*([-\w.]+)'</tt><tt class="py-op">)</tt> </tt> <a name="L308"></a><tt class="py-lineno">308</tt> <tt class="py-line"> </tt> <a name="L309"></a><tt class="py-lineno">309</tt> <tt class="py-line"> <tt class="py-comment">#: A configuration constant, used to determine whether or not to add</tt> </tt> <a name="L310"></a><tt class="py-lineno">310</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: collapsable <div> elements for definition blocks.</tt> </tt> <a name="L311"></a><tt class="py-lineno">311</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt id="link-13" class="py-name" targets="Variable epydoc.docwriter.html_colorize.PythonSourceColorizer.ADD_DEF_BLOCKS=epydoc.docwriter.html_colorize.PythonSourceColorizer-class.html#ADD_DEF_BLOCKS"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.ADD_DEF_BLOCKS" class="py-name" href="#" onclick="return doclink('link-13', 'ADD_DEF_BLOCKS', 'link-13');">ADD_DEF_BLOCKS</a></tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt> <a name="L312"></a><tt class="py-lineno">312</tt> <tt class="py-line"> </tt> <a name="L313"></a><tt class="py-lineno">313</tt> <tt class="py-line"> <tt class="py-comment">#: A configuration constant, used to determine whether or not to</tt> </tt> <a name="L314"></a><tt class="py-lineno">314</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: add line numbers.</tt> </tt> <a name="L315"></a><tt class="py-lineno">315</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt id="link-14" class="py-name" targets="Variable epydoc.docwriter.html_colorize.PythonSourceColorizer.ADD_LINE_NUMBERS=epydoc.docwriter.html_colorize.PythonSourceColorizer-class.html#ADD_LINE_NUMBERS"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.ADD_LINE_NUMBERS" class="py-name" href="#" onclick="return doclink('link-14', 'ADD_LINE_NUMBERS', 'link-14');">ADD_LINE_NUMBERS</a></tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt> <a name="L316"></a><tt class="py-lineno">316</tt> <tt class="py-line"> </tt> <a name="L317"></a><tt class="py-lineno">317</tt> <tt class="py-line"> <tt class="py-comment">#: A configuration constant, used to determine whether or not to</tt> </tt> <a name="L318"></a><tt class="py-lineno">318</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: add tooltips for linked names.</tt> </tt> <a name="L319"></a><tt class="py-lineno">319</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt id="link-15" class="py-name" targets="Variable epydoc.docwriter.html_colorize.PythonSourceColorizer.ADD_TOOLTIPS=epydoc.docwriter.html_colorize.PythonSourceColorizer-class.html#ADD_TOOLTIPS"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.ADD_TOOLTIPS" class="py-name" href="#" onclick="return doclink('link-15', 'ADD_TOOLTIPS', 'link-15');">ADD_TOOLTIPS</a></tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt> <a name="L320"></a><tt class="py-lineno">320</tt> <tt class="py-line"> </tt> <a name="L321"></a><tt class="py-lineno">321</tt> <tt class="py-line"> <tt class="py-comment">#: If true, then try to guess which target is appropriate for</tt> </tt> <a name="L322"></a><tt class="py-lineno">322</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: linked names; if false, then always open a div asking the</tt> </tt> <a name="L323"></a><tt class="py-lineno">323</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: user which one they want.</tt> </tt> <a name="L324"></a><tt class="py-lineno">324</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt id="link-16" class="py-name" targets="Variable epydoc.docwriter.html_colorize.PythonSourceColorizer.GUESS_LINK_TARGETS=epydoc.docwriter.html_colorize.PythonSourceColorizer-class.html#GUESS_LINK_TARGETS"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.GUESS_LINK_TARGETS" class="py-name" href="#" onclick="return doclink('link-16', 'GUESS_LINK_TARGETS', 'link-16');">GUESS_LINK_TARGETS</a></tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt> <a name="L325"></a><tt class="py-lineno">325</tt> <tt class="py-line"> </tt> <a name="PythonSourceColorizer.__init__"></a><div id="PythonSourceColorizer.__init__-def"><a name="L326"></a><tt class="py-lineno">326</tt> <a class="py-toggle" href="#" id="PythonSourceColorizer.__init__-toggle" onclick="return toggle('PythonSourceColorizer.__init__');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="epydoc.docwriter.html_colorize.PythonSourceColorizer-class.html#__init__">__init__</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">module_filename</tt><tt class="py-op">,</tt> <tt class="py-param">module_name</tt><tt class="py-op">,</tt> </tt> <a name="L327"></a><tt class="py-lineno">327</tt> <tt class="py-line"> <tt class="py-param">docindex</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt> <tt class="py-param">url_func</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt> <tt class="py-param">name_to_docs</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">,</tt> </tt> <a name="L328"></a><tt class="py-lineno">328</tt> <tt class="py-line"> <tt class="py-param">tab_width</tt><tt class="py-op">=</tt><tt class="py-number">8</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> </div><div id="PythonSourceColorizer.__init__-collapsed" style="display:none;" pad="+++" indent="++++++++"></div><div id="PythonSourceColorizer.__init__-expanded"><a name="L329"></a><tt class="py-lineno">329</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt> <a name="L330"></a><tt class="py-lineno">330</tt> <tt class="py-line"><tt class="py-docstring"> Create a new HTML colorizer for the specified module.</tt> </tt> <a name="L331"></a><tt class="py-lineno">331</tt> <tt class="py-line"><tt class="py-docstring"></tt> </tt> <a name="L332"></a><tt class="py-lineno">332</tt> <tt class="py-line"><tt class="py-docstring"> @param module_filename: The name of the file containing the</tt> </tt> <a name="L333"></a><tt class="py-lineno">333</tt> <tt class="py-line"><tt class="py-docstring"> module; its text will be loaded from this file.</tt> </tt> <a name="L334"></a><tt class="py-lineno">334</tt> <tt class="py-line"><tt class="py-docstring"> @param module_name: The dotted name of the module; this will</tt> </tt> <a name="L335"></a><tt class="py-lineno">335</tt> <tt class="py-line"><tt class="py-docstring"> be used to create links back into the API source</tt> </tt> <a name="L336"></a><tt class="py-lineno">336</tt> <tt class="py-line"><tt class="py-docstring"> documentation.</tt> </tt> <a name="L337"></a><tt class="py-lineno">337</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt> <a name="L338"></a><tt class="py-lineno">338</tt> <tt class="py-line"> <tt class="py-comment"># Get the source version, if possible.</tt> </tt> <a name="L339"></a><tt class="py-lineno">339</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> <tt class="py-name">module_filename</tt> <tt class="py-op">=</tt> <tt id="link-17" class="py-name"><a title="epydoc.util.py_src_filename" class="py-name" href="#" onclick="return doclink('link-17', 'py_src_filename', 'link-4');">py_src_filename</a></tt><tt class="py-op">(</tt><tt class="py-name">module_filename</tt><tt class="py-op">)</tt> </tt> <a name="L340"></a><tt class="py-lineno">340</tt> <tt class="py-line"> <tt class="py-keyword">except</tt><tt class="py-op">:</tt> <tt class="py-keyword">pass</tt> </tt> <a name="L341"></a><tt class="py-lineno">341</tt> <tt class="py-line"> </tt> <a name="L342"></a><tt class="py-lineno">342</tt> <tt class="py-line"> <tt class="py-comment">#: The filename of the module we're colorizing.</tt> </tt> <a name="L343"></a><tt class="py-lineno">343</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">module_filename</tt> <tt class="py-op">=</tt> <tt class="py-name">module_filename</tt> </tt> <a name="L344"></a><tt class="py-lineno">344</tt> <tt class="py-line"> </tt> <a name="L345"></a><tt class="py-lineno">345</tt> <tt class="py-line"> <tt class="py-comment">#: The dotted name of the module we're colorizing.</tt> </tt> <a name="L346"></a><tt class="py-lineno">346</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">module_name</tt> <tt class="py-op">=</tt> <tt class="py-name">module_name</tt> </tt> <a name="L347"></a><tt class="py-lineno">347</tt> <tt class="py-line"> </tt> <a name="L348"></a><tt class="py-lineno">348</tt> <tt class="py-line"> <tt class="py-comment">#: A docindex, used to create href links from identifiers to</tt> </tt> <a name="L349"></a><tt class="py-lineno">349</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: the API documentation for their values.</tt> </tt> <a name="L350"></a><tt class="py-lineno">350</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">docindex</tt> <tt class="py-op">=</tt> <tt class="py-name">docindex</tt> </tt> <a name="L351"></a><tt class="py-lineno">351</tt> <tt class="py-line"> </tt> <a name="L352"></a><tt class="py-lineno">352</tt> <tt class="py-line"> <tt class="py-comment">#: A mapping from short names to lists of ValueDoc, used to</tt> </tt> <a name="L353"></a><tt class="py-lineno">353</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: decide which values an identifier might map to when creating</tt> </tt> <a name="L354"></a><tt class="py-lineno">354</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: href links from identifiers to the API docs for their values.</tt> </tt> <a name="L355"></a><tt class="py-lineno">355</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name_to_docs</tt> <tt class="py-op">=</tt> <tt class="py-name">name_to_docs</tt> </tt> <a name="L356"></a><tt class="py-lineno">356</tt> <tt class="py-line"> </tt> <a name="L357"></a><tt class="py-lineno">357</tt> <tt class="py-line"> <tt class="py-comment">#: A function that maps APIDoc -> URL, used to create href</tt> </tt> <a name="L358"></a><tt class="py-lineno">358</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: links from identifiers to the API documentation for their</tt> </tt> <a name="L359"></a><tt class="py-lineno">359</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: values.</tt> </tt> <a name="L360"></a><tt class="py-lineno">360</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">url_func</tt> <tt class="py-op">=</tt> <tt class="py-name">url_func</tt> </tt> <a name="L361"></a><tt class="py-lineno">361</tt> <tt class="py-line"> </tt> <a name="L362"></a><tt class="py-lineno">362</tt> <tt class="py-line"> <tt class="py-comment">#: The index in C{text} of the last character of the last</tt> </tt> <a name="L363"></a><tt class="py-lineno">363</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: token we've processed.</tt> </tt> <a name="L364"></a><tt class="py-lineno">364</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">pos</tt> <tt class="py-op">=</tt> <tt class="py-number">0</tt> </tt> <a name="L365"></a><tt class="py-lineno">365</tt> <tt class="py-line"> </tt> <a name="L366"></a><tt class="py-lineno">366</tt> <tt class="py-line"> <tt class="py-comment">#: A list that maps line numbers to character offsets in</tt> </tt> <a name="L367"></a><tt class="py-lineno">367</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: C{text}. In particular, line C{M{i}} begins at character</tt> </tt> <a name="L368"></a><tt class="py-lineno">368</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: C{line_offset[i]} in C{text}. Since line numbers begin at</tt> </tt> <a name="L369"></a><tt class="py-lineno">369</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: 1, the first element of C{line_offsets} is C{None}.</tt> </tt> <a name="L370"></a><tt class="py-lineno">370</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">line_offsets</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt> <a name="L371"></a><tt class="py-lineno">371</tt> <tt class="py-line"> </tt> <a name="L372"></a><tt class="py-lineno">372</tt> <tt class="py-line"> <tt class="py-comment">#: A list of C{(toktype, toktext)} for all tokens on the</tt> </tt> <a name="L373"></a><tt class="py-lineno">373</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: logical line that we are currently processing. Once a</tt> </tt> <a name="L374"></a><tt class="py-lineno">374</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: complete line of tokens has been collected in C{cur_line},</tt> </tt> <a name="L375"></a><tt class="py-lineno">375</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: it is sent to L{handle_line} for processing.</tt> </tt> <a name="L376"></a><tt class="py-lineno">376</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">cur_line</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt> <a name="L377"></a><tt class="py-lineno">377</tt> <tt class="py-line"> </tt> <a name="L378"></a><tt class="py-lineno">378</tt> <tt class="py-line"> <tt class="py-comment">#: A list of the names of the class or functions that include</tt> </tt> <a name="L379"></a><tt class="py-lineno">379</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: the current block. C{context} has one element for each</tt> </tt> <a name="L380"></a><tt class="py-lineno">380</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: level of indentation; C{context[i]} is the name of the class</tt> </tt> <a name="L381"></a><tt class="py-lineno">381</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: or function defined by the C{i}th level of indentation, or</tt> </tt> <a name="L382"></a><tt class="py-lineno">382</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: C{None} if that level of indentation doesn't correspond to a</tt> </tt> <a name="L383"></a><tt class="py-lineno">383</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: class or function definition.</tt> </tt> <a name="L384"></a><tt class="py-lineno">384</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">context</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt> <a name="L385"></a><tt class="py-lineno">385</tt> <tt class="py-line"> </tt> <a name="L386"></a><tt class="py-lineno">386</tt> <tt class="py-line"> <tt class="py-comment">#: A list, corresponding one-to-one with L{self.context},</tt> </tt> <a name="L387"></a><tt class="py-lineno">387</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: indicating the type of each entry. Each element of</tt> </tt> <a name="L388"></a><tt class="py-lineno">388</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: C{context_types} is one of: C{'func'}, C{'class'}, C{None}.</tt> </tt> <a name="L389"></a><tt class="py-lineno">389</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">context_types</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt> <a name="L390"></a><tt class="py-lineno">390</tt> <tt class="py-line"> </tt> <a name="L391"></a><tt class="py-lineno">391</tt> <tt class="py-line"> <tt class="py-comment">#: A list of indentation strings for each of the current</tt> </tt> <a name="L392"></a><tt class="py-lineno">392</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: block's indents. I.e., the current total indentation can</tt> </tt> <a name="L393"></a><tt class="py-lineno">393</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: be found by taking C{''.join(self.indents)}.</tt> </tt> <a name="L394"></a><tt class="py-lineno">394</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">indents</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt> <a name="L395"></a><tt class="py-lineno">395</tt> <tt class="py-line"> </tt> <a name="L396"></a><tt class="py-lineno">396</tt> <tt class="py-line"> <tt class="py-comment">#: The line number of the line we're currently processing.</tt> </tt> <a name="L397"></a><tt class="py-lineno">397</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-18" class="py-name" targets="Variable epydoc.apidoc.RoutineDoc.lineno=epydoc.apidoc.RoutineDoc-class.html#lineno"><a title="epydoc.apidoc.RoutineDoc.lineno" class="py-name" href="#" onclick="return doclink('link-18', 'lineno', 'link-18');">lineno</a></tt> <tt class="py-op">=</tt> <tt class="py-number">0</tt> </tt> <a name="L398"></a><tt class="py-lineno">398</tt> <tt class="py-line"> </tt> <a name="L399"></a><tt class="py-lineno">399</tt> <tt class="py-line"> <tt class="py-comment">#: The name of the class or function whose definition started</tt> </tt> <a name="L400"></a><tt class="py-lineno">400</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: on the previous logical line, or C{None} if the previous</tt> </tt> <a name="L401"></a><tt class="py-lineno">401</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: logical line was not a class or function definition.</tt> </tt> <a name="L402"></a><tt class="py-lineno">402</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">def_name</tt> <tt class="py-op">=</tt> <tt class="py-name">None</tt> </tt> <a name="L403"></a><tt class="py-lineno">403</tt> <tt class="py-line"> </tt> <a name="L404"></a><tt class="py-lineno">404</tt> <tt class="py-line"> <tt class="py-comment">#: The type of the class or function whose definition started</tt> </tt> <a name="L405"></a><tt class="py-lineno">405</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: on the previous logical line, or C{None} if the previous</tt> </tt> <a name="L406"></a><tt class="py-lineno">406</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: logical line was not a class or function definition.</tt> </tt> <a name="L407"></a><tt class="py-lineno">407</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: Can be C{'func'}, C{'class'}, C{None}.</tt> </tt> <a name="L408"></a><tt class="py-lineno">408</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">def_type</tt> <tt class="py-op">=</tt> <tt class="py-name">None</tt> </tt> <a name="L409"></a><tt class="py-lineno">409</tt> <tt class="py-line"> </tt> <a name="L410"></a><tt class="py-lineno">410</tt> <tt class="py-line"> <tt class="py-comment">#: The number of spaces to replace each tab in source code with</tt> </tt> <a name="L411"></a><tt class="py-lineno">411</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">tab_width</tt> <tt class="py-op">=</tt> <tt class="py-name">tab_width</tt> </tt> </div><a name="L412"></a><tt class="py-lineno">412</tt> <tt class="py-line"> </tt> <a name="L413"></a><tt class="py-lineno">413</tt> <tt class="py-line"> </tt> <a name="PythonSourceColorizer.find_line_offsets"></a><div id="PythonSourceColorizer.find_line_offsets-def"><a name="L414"></a><tt class="py-lineno">414</tt> <a class="py-toggle" href="#" id="PythonSourceColorizer.find_line_offsets-toggle" onclick="return toggle('PythonSourceColorizer.find_line_offsets');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="epydoc.docwriter.html_colorize.PythonSourceColorizer-class.html#find_line_offsets">find_line_offsets</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> </div><div id="PythonSourceColorizer.find_line_offsets-collapsed" style="display:none;" pad="+++" indent="++++++++"></div><div id="PythonSourceColorizer.find_line_offsets-expanded"><a name="L415"></a><tt class="py-lineno">415</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt> <a name="L416"></a><tt class="py-lineno">416</tt> <tt class="py-line"><tt class="py-docstring"> Construct the L{line_offsets} table from C{self.text}.</tt> </tt> <a name="L417"></a><tt class="py-lineno">417</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt> <a name="L418"></a><tt class="py-lineno">418</tt> <tt class="py-line"> <tt class="py-comment"># line 0 doesn't exist; line 1 starts at char offset 0.</tt> </tt> <a name="L419"></a><tt class="py-lineno">419</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">line_offsets</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-name">None</tt><tt class="py-op">,</tt> <tt class="py-number">0</tt><tt class="py-op">]</tt> </tt> <a name="L420"></a><tt class="py-lineno">420</tt> <tt class="py-line"> <tt class="py-comment"># Find all newlines in `text`, and add an entry to</tt> </tt> <a name="L421"></a><tt class="py-lineno">421</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment"># line_offsets for each one.</tt> </tt> <a name="L422"></a><tt class="py-lineno">422</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-name">pos</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">text</tt><tt class="py-op">.</tt><tt id="link-19" class="py-name" targets="Method epydoc.apidoc.DocIndex.find()=epydoc.apidoc.DocIndex-class.html#find"><a title="epydoc.apidoc.DocIndex.find" class="py-name" href="#" onclick="return doclink('link-19', 'find', 'link-19');">find</a></tt><tt class="py-op">(</tt><tt class="py-string">'\n'</tt><tt class="py-op">)</tt> </tt> <a name="L423"></a><tt class="py-lineno">423</tt> <tt class="py-line"> <tt class="py-keyword">while</tt> <tt class="py-name">pos</tt> <tt class="py-op">!=</tt> <tt class="py-op">-</tt><tt class="py-number">1</tt><tt class="py-op">:</tt> </tt> <a name="L424"></a><tt class="py-lineno">424</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">line_offsets</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt><tt class="py-name">pos</tt><tt class="py-op">+</tt><tt class="py-number">1</tt><tt class="py-op">)</tt> </tt> <a name="L425"></a><tt class="py-lineno">425</tt> <tt class="py-line"> <tt class="py-name">pos</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">text</tt><tt class="py-op">.</tt><tt id="link-20" class="py-name"><a title="epydoc.apidoc.DocIndex.find" class="py-name" href="#" onclick="return doclink('link-20', 'find', 'link-19');">find</a></tt><tt class="py-op">(</tt><tt class="py-string">'\n'</tt><tt class="py-op">,</tt> <tt class="py-name">pos</tt><tt class="py-op">+</tt><tt class="py-number">1</tt><tt class="py-op">)</tt> </tt> <a name="L426"></a><tt class="py-lineno">426</tt> <tt class="py-line"> <tt class="py-comment"># Add a final entry, marking the end of the string.</tt> </tt> <a name="L427"></a><tt class="py-lineno">427</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">line_offsets</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt><tt class="py-name">len</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">text</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt> </div><a name="L428"></a><tt class="py-lineno">428</tt> <tt class="py-line"> </tt> <a name="PythonSourceColorizer.lineno_to_html"></a><div id="PythonSourceColorizer.lineno_to_html-def"><a name="L429"></a><tt class="py-lineno">429</tt> <a class="py-toggle" href="#" id="PythonSourceColorizer.lineno_to_html-toggle" onclick="return toggle('PythonSourceColorizer.lineno_to_html');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="epydoc.docwriter.html_colorize.PythonSourceColorizer-class.html#lineno_to_html">lineno_to_html</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> </div><div id="PythonSourceColorizer.lineno_to_html-collapsed" style="display:none;" pad="+++" indent="++++++++"></div><div id="PythonSourceColorizer.lineno_to_html-expanded"><a name="L430"></a><tt class="py-lineno">430</tt> <tt class="py-line"> <tt class="py-name">template</tt> <tt class="py-op">=</tt> <tt class="py-string">'%%%ds'</tt> <tt class="py-op">%</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">linenum_size</tt> </tt> <a name="L431"></a><tt class="py-lineno">431</tt> <tt class="py-line"> <tt class="py-name">n</tt> <tt class="py-op">=</tt> <tt class="py-name">template</tt> <tt class="py-op">%</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-21" class="py-name"><a title="epydoc.apidoc.RoutineDoc.lineno" class="py-name" href="#" onclick="return doclink('link-21', 'lineno', 'link-18');">lineno</a></tt> </tt> <a name="L432"></a><tt class="py-lineno">432</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-string">'<a name="L%s"></a><tt class="py-lineno">%s</tt>'</tt> \ </tt> <a name="L433"></a><tt class="py-lineno">433</tt> <tt class="py-line"> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-22" class="py-name"><a title="epydoc.apidoc.RoutineDoc.lineno" class="py-name" href="#" onclick="return doclink('link-22', 'lineno', 'link-18');">lineno</a></tt><tt class="py-op">,</tt> <tt class="py-name">n</tt><tt class="py-op">)</tt> </tt> </div><a name="L434"></a><tt class="py-lineno">434</tt> <tt class="py-line"> </tt> <a name="PythonSourceColorizer.colorize"></a><div id="PythonSourceColorizer.colorize-def"><a name="L435"></a><tt class="py-lineno">435</tt> <a class="py-toggle" href="#" id="PythonSourceColorizer.colorize-toggle" onclick="return toggle('PythonSourceColorizer.colorize');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="epydoc.docwriter.html_colorize.PythonSourceColorizer-class.html#colorize">colorize</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> </div><div id="PythonSourceColorizer.colorize-collapsed" style="display:none;" pad="+++" indent="++++++++"></div><div id="PythonSourceColorizer.colorize-expanded"><a name="L436"></a><tt class="py-lineno">436</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt> <a name="L437"></a><tt class="py-lineno">437</tt> <tt class="py-line"><tt class="py-docstring"> Return an HTML string that renders the source code for the</tt> </tt> <a name="L438"></a><tt class="py-lineno">438</tt> <tt class="py-line"><tt class="py-docstring"> module that was specified in the constructor.</tt> </tt> <a name="L439"></a><tt class="py-lineno">439</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt> <a name="L440"></a><tt class="py-lineno">440</tt> <tt class="py-line"> <tt class="py-comment"># Initialize all our state variables</tt> </tt> <a name="L441"></a><tt class="py-lineno">441</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">pos</tt> <tt class="py-op">=</tt> <tt class="py-number">0</tt> </tt> <a name="L442"></a><tt class="py-lineno">442</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">cur_line</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt> <a name="L443"></a><tt class="py-lineno">443</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">context</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt> <a name="L444"></a><tt class="py-lineno">444</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">context_types</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt> <a name="L445"></a><tt class="py-lineno">445</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">indents</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt> <a name="L446"></a><tt class="py-lineno">446</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-23" class="py-name"><a title="epydoc.apidoc.RoutineDoc.lineno" class="py-name" href="#" onclick="return doclink('link-23', 'lineno', 'link-18');">lineno</a></tt> <tt class="py-op">=</tt> <tt class="py-number">1</tt> </tt> <a name="L447"></a><tt class="py-lineno">447</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">def_name</tt> <tt class="py-op">=</tt> <tt class="py-name">None</tt> </tt> <a name="L448"></a><tt class="py-lineno">448</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">def_type</tt> <tt class="py-op">=</tt> <tt class="py-name">None</tt> </tt> <a name="L449"></a><tt class="py-lineno">449</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">has_decorators</tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt> <a name="L450"></a><tt class="py-lineno">450</tt> <tt class="py-line"> </tt> <a name="L451"></a><tt class="py-lineno">451</tt> <tt class="py-line"> <tt class="py-comment"># Cache, used so we only need to list the target elements once</tt> </tt> <a name="L452"></a><tt class="py-lineno">452</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment"># for each variable.</tt> </tt> <a name="L453"></a><tt class="py-lineno">453</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">doclink_targets_cache</tt> <tt class="py-op">=</tt> <tt class="py-op">{</tt><tt class="py-op">}</tt> </tt> <a name="L454"></a><tt class="py-lineno">454</tt> <tt class="py-line"> </tt> <a name="L455"></a><tt class="py-lineno">455</tt> <tt class="py-line"> <tt class="py-comment"># Load the module's text.</tt> </tt> <a name="L456"></a><tt class="py-lineno">456</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">text</tt> <tt class="py-op">=</tt> <tt id="link-24" class="py-name" targets="Method epydoc.gui.EpydocGUI.open()=epydoc.gui.EpydocGUI-class.html#open"><a title="epydoc.gui.EpydocGUI.open" class="py-name" href="#" onclick="return doclink('link-24', 'open', 'link-24');">open</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">module_filename</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-25" class="py-name" targets="Method epydoc.docintrospecter._DevNull.read()=epydoc.docintrospecter._DevNull-class.html#read,Method epydoc.docwriter.xlink.ApiLinkReader.read()=epydoc.docwriter.xlink.ApiLinkReader-class.html#read,Method epydoc.gui.GUILogger.read()=epydoc.gui.GUILogger-class.html#read"><a title="epydoc.docintrospecter._DevNull.read epydoc.docwriter.xlink.ApiLinkReader.read epydoc.gui.GUILogger.read" class="py-name" href="#" onclick="return doclink('link-25', 'read', 'link-25');">read</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> <a name="L457"></a><tt class="py-lineno">457</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">text</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">text</tt><tt class="py-op">.</tt><tt class="py-name">expandtabs</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">tab_width</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">rstrip</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">+</tt><tt class="py-string">'\n'</tt> </tt> <a name="L458"></a><tt class="py-lineno">458</tt> <tt class="py-line"> </tt> <a name="L459"></a><tt class="py-lineno">459</tt> <tt class="py-line"> <tt class="py-comment"># Construct the line_offsets table.</tt> </tt> <a name="L460"></a><tt class="py-lineno">460</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-26" class="py-name" targets="Method epydoc.docwriter.html_colorize.PythonSourceColorizer.find_line_offsets()=epydoc.docwriter.html_colorize.PythonSourceColorizer-class.html#find_line_offsets"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.find_line_offsets" class="py-name" href="#" onclick="return doclink('link-26', 'find_line_offsets', 'link-26');">find_line_offsets</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> <a name="L461"></a><tt class="py-lineno">461</tt> <tt class="py-line"> </tt> <a name="L462"></a><tt class="py-lineno">462</tt> <tt class="py-line"> <tt class="py-name">num_lines</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">text</tt><tt class="py-op">.</tt><tt class="py-name">count</tt><tt class="py-op">(</tt><tt class="py-string">'\n'</tt><tt class="py-op">)</tt><tt class="py-op">+</tt><tt class="py-number">1</tt> </tt> <a name="L463"></a><tt class="py-lineno">463</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">linenum_size</tt> <tt class="py-op">=</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt><tt class="py-op">`</tt><tt class="py-name">num_lines</tt><tt class="py-op">+</tt><tt class="py-number">1</tt><tt class="py-op">`</tt><tt class="py-op">)</tt> </tt> <a name="L464"></a><tt class="py-lineno">464</tt> <tt class="py-line"> </tt> <a name="L465"></a><tt class="py-lineno">465</tt> <tt class="py-line"> <tt class="py-comment"># Call the tokenizer, and send tokens to our `tokeneater()`</tt> </tt> <a name="L466"></a><tt class="py-lineno">466</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment"># method. If anything goes wrong, then fall-back to using</tt> </tt> <a name="L467"></a><tt class="py-lineno">467</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment"># the input text as-is (with no colorization).</tt> </tt> <a name="L468"></a><tt class="py-lineno">468</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt> <a name="L469"></a><tt class="py-lineno">469</tt> <tt class="py-line"> <tt class="py-name">output</tt> <tt class="py-op">=</tt> <tt class="py-name">StringIO</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> <a name="L470"></a><tt class="py-lineno">470</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">out</tt> <tt class="py-op">=</tt> <tt class="py-name">output</tt><tt class="py-op">.</tt><tt id="link-27" class="py-name" targets="Method epydoc.docintrospecter._DevNull.write()=epydoc.docintrospecter._DevNull-class.html#write,Method epydoc.docwriter.dotgraph.DotGraph.write()=epydoc.docwriter.dotgraph.DotGraph-class.html#write,Method epydoc.docwriter.html.HTMLWriter.write()=epydoc.docwriter.html.HTMLWriter-class.html#write,Method epydoc.docwriter.latex.LatexWriter.write()=epydoc.docwriter.latex.LatexWriter-class.html#write,Method epydoc.docwriter.plaintext.PlaintextWriter.write()=epydoc.docwriter.plaintext.PlaintextWriter-class.html#write"><a title="epydoc.docintrospecter._DevNull.write epydoc.docwriter.dotgraph.DotGraph.write epydoc.docwriter.html.HTMLWriter.write epydoc.docwriter.latex.LatexWriter.write epydoc.docwriter.plaintext.PlaintextWriter.write" class="py-name" href="#" onclick="return doclink('link-27', 'write', 'link-27');">write</a></tt> </tt> <a name="L471"></a><tt class="py-lineno">471</tt> <tt class="py-line"> <tt class="py-name">tokenize</tt><tt class="py-op">.</tt><tt class="py-name">tokenize</tt><tt class="py-op">(</tt><tt class="py-name">StringIO</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">text</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-28" class="py-name" targets="Method epydoc.docintrospecter._DevNull.readline()=epydoc.docintrospecter._DevNull-class.html#readline"><a title="epydoc.docintrospecter._DevNull.readline" class="py-name" href="#" onclick="return doclink('link-28', 'readline', 'link-28');">readline</a></tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-29" class="py-name" targets="Method epydoc.docwriter.html_colorize.PythonSourceColorizer.tokeneater()=epydoc.docwriter.html_colorize.PythonSourceColorizer-class.html#tokeneater"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.tokeneater" class="py-name" href="#" onclick="return doclink('link-29', 'tokeneater', 'link-29');">tokeneater</a></tt><tt class="py-op">)</tt> </tt> <a name="L472"></a><tt class="py-lineno">472</tt> <tt class="py-line"> <tt id="link-30" class="py-name" targets="Module epydoc.docwriter.html=epydoc.docwriter.html-module.html"><a title="epydoc.docwriter.html" class="py-name" href="#" onclick="return doclink('link-30', 'html', 'link-30');">html</a></tt> <tt class="py-op">=</tt> <tt class="py-name">output</tt><tt class="py-op">.</tt><tt class="py-name">getvalue</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> <a name="L473"></a><tt class="py-lineno">473</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">has_decorators</tt><tt class="py-op">:</tt> </tt> <a name="L474"></a><tt class="py-lineno">474</tt> <tt class="py-line"> <tt id="link-31" class="py-name"><a title="epydoc.docwriter.html" class="py-name" href="#" onclick="return doclink('link-31', 'html', 'link-30');">html</a></tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-32" class="py-name" targets="Variable epydoc.docwriter.html_colorize.PythonSourceColorizer._FIX_DECORATOR_RE=epydoc.docwriter.html_colorize.PythonSourceColorizer-class.html#_FIX_DECORATOR_RE"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer._FIX_DECORATOR_RE" class="py-name" href="#" onclick="return doclink('link-32', '_FIX_DECORATOR_RE', 'link-32');">_FIX_DECORATOR_RE</a></tt><tt class="py-op">.</tt><tt class="py-name">sub</tt><tt class="py-op">(</tt><tt class="py-string">r'\2\1'</tt><tt class="py-op">,</tt> <tt id="link-33" class="py-name"><a title="epydoc.docwriter.html" class="py-name" href="#" onclick="return doclink('link-33', 'html', 'link-30');">html</a></tt><tt class="py-op">)</tt> </tt> <a name="L475"></a><tt class="py-lineno">475</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">tokenize</tt><tt class="py-op">.</tt><tt class="py-name">TokenError</tt><tt class="py-op">,</tt> <tt class="py-name">ex</tt><tt class="py-op">:</tt> </tt> <a name="L476"></a><tt class="py-lineno">476</tt> <tt class="py-line"> <tt id="link-34" class="py-name"><a title="epydoc.docwriter.html" class="py-name" href="#" onclick="return doclink('link-34', 'html', 'link-30');">html</a></tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">text</tt> </tt> <a name="L477"></a><tt class="py-lineno">477</tt> <tt class="py-line"> </tt> <a name="L478"></a><tt class="py-lineno">478</tt> <tt class="py-line"> <tt class="py-comment"># Check for a unicode encoding declaration.</tt> </tt> <a name="L479"></a><tt class="py-lineno">479</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-name">m</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-35" class="py-name"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.UNICODE_CODING_RE" class="py-name" href="#" onclick="return doclink('link-35', 'UNICODE_CODING_RE', 'link-12');">UNICODE_CODING_RE</a></tt><tt class="py-op">.</tt><tt class="py-name">match</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">text</tt><tt class="py-op">)</tt> </tt> <a name="L480"></a><tt class="py-lineno">480</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">m</tt><tt class="py-op">:</tt> <tt class="py-name">coding</tt> <tt class="py-op">=</tt> <tt class="py-name">m</tt><tt class="py-op">.</tt><tt class="py-name">group</tt><tt class="py-op">(</tt><tt class="py-number">1</tt><tt class="py-op">)</tt> </tt> <a name="L481"></a><tt class="py-lineno">481</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> <tt class="py-name">coding</tt> <tt class="py-op">=</tt> <tt class="py-string">'iso-8859-1'</tt> </tt> <a name="L482"></a><tt class="py-lineno">482</tt> <tt class="py-line"> </tt> <a name="L483"></a><tt class="py-lineno">483</tt> <tt class="py-line"> <tt class="py-comment"># Decode the html string into unicode, and then encode it back</tt> </tt> <a name="L484"></a><tt class="py-lineno">484</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment"># into ascii, replacing any non-ascii characters with xml</tt> </tt> <a name="L485"></a><tt class="py-lineno">485</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment"># character references.</tt> </tt> <a name="L486"></a><tt class="py-lineno">486</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt> <a name="L487"></a><tt class="py-lineno">487</tt> <tt class="py-line"> <tt id="link-36" class="py-name"><a title="epydoc.docwriter.html" class="py-name" href="#" onclick="return doclink('link-36', 'html', 'link-30');">html</a></tt> <tt class="py-op">=</tt> <tt id="link-37" class="py-name"><a title="epydoc.docwriter.html" class="py-name" href="#" onclick="return doclink('link-37', 'html', 'link-30');">html</a></tt><tt class="py-op">.</tt><tt class="py-name">decode</tt><tt class="py-op">(</tt><tt class="py-name">coding</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">encode</tt><tt class="py-op">(</tt><tt class="py-string">'ascii'</tt><tt class="py-op">,</tt> <tt class="py-string">'xmlcharrefreplace'</tt><tt class="py-op">)</tt> </tt> <a name="L488"></a><tt class="py-lineno">488</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">LookupError</tt><tt class="py-op">:</tt> </tt> <a name="L489"></a><tt class="py-lineno">489</tt> <tt class="py-line"> <tt class="py-name">coding</tt> <tt class="py-op">=</tt> <tt class="py-string">'iso-8859-1'</tt> </tt> <a name="L490"></a><tt class="py-lineno">490</tt> <tt class="py-line"> <tt id="link-38" class="py-name"><a title="epydoc.docwriter.html" class="py-name" href="#" onclick="return doclink('link-38', 'html', 'link-30');">html</a></tt> <tt class="py-op">=</tt> <tt id="link-39" class="py-name"><a title="epydoc.docwriter.html" class="py-name" href="#" onclick="return doclink('link-39', 'html', 'link-30');">html</a></tt><tt class="py-op">.</tt><tt class="py-name">decode</tt><tt class="py-op">(</tt><tt class="py-name">coding</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">encode</tt><tt class="py-op">(</tt><tt class="py-string">'ascii'</tt><tt class="py-op">,</tt> <tt class="py-string">'xmlcharrefreplace'</tt><tt class="py-op">)</tt> </tt> <a name="L491"></a><tt class="py-lineno">491</tt> <tt class="py-line"> </tt> <a name="L492"></a><tt class="py-lineno">492</tt> <tt class="py-line"> <tt class="py-comment"># Call expandto.</tt> </tt> <a name="L493"></a><tt class="py-lineno">493</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt id="link-40" class="py-name"><a title="epydoc.docwriter.html" class="py-name" href="#" onclick="return doclink('link-40', 'html', 'link-30');">html</a></tt> <tt class="py-op">+=</tt> <tt id="link-41" class="py-name"><a title="epydoc.docwriter.html_colorize.PYSRC_EXPANDTO_JAVASCRIPT" class="py-name" href="#" onclick="return doclink('link-41', 'PYSRC_EXPANDTO_JAVASCRIPT', 'link-8');">PYSRC_EXPANDTO_JAVASCRIPT</a></tt> </tt> <a name="L494"></a><tt class="py-lineno">494</tt> <tt class="py-line"> </tt> <a name="L495"></a><tt class="py-lineno">495</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt id="link-42" class="py-name"><a title="epydoc.docwriter.html" class="py-name" href="#" onclick="return doclink('link-42', 'html', 'link-30');">html</a></tt> </tt> </div><a name="L496"></a><tt class="py-lineno">496</tt> <tt class="py-line"> </tt> <a name="PythonSourceColorizer.tokeneater"></a><div id="PythonSourceColorizer.tokeneater-def"><a name="L497"></a><tt class="py-lineno">497</tt> <a class="py-toggle" href="#" id="PythonSourceColorizer.tokeneater-toggle" onclick="return toggle('PythonSourceColorizer.tokeneater');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="epydoc.docwriter.html_colorize.PythonSourceColorizer-class.html#tokeneater">tokeneater</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">toktype</tt><tt class="py-op">,</tt> <tt class="py-param">toktext</tt><tt class="py-op">,</tt> <tt class="py-op">(</tt><tt class="py-param">srow</tt><tt class="py-op">,</tt><tt class="py-param">scol</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> <tt class="py-op">(</tt><tt class="py-param">erow</tt><tt class="py-op">,</tt><tt class="py-param">ecol</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> <tt class="py-param">line</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> </div><div id="PythonSourceColorizer.tokeneater-collapsed" style="display:none;" pad="+++" indent="++++++++"></div><div id="PythonSourceColorizer.tokeneater-expanded"><a name="L498"></a><tt class="py-lineno">498</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt> <a name="L499"></a><tt class="py-lineno">499</tt> <tt class="py-line"><tt class="py-docstring"> A callback function used by C{tokenize.tokenize} to handle</tt> </tt> <a name="L500"></a><tt class="py-lineno">500</tt> <tt class="py-line"><tt class="py-docstring"> each token in the module. C{tokeneater} collects tokens into</tt> </tt> <a name="L501"></a><tt class="py-lineno">501</tt> <tt class="py-line"><tt class="py-docstring"> the C{self.cur_line} list until a complete logical line has</tt> </tt> <a name="L502"></a><tt class="py-lineno">502</tt> <tt class="py-line"><tt class="py-docstring"> been formed; and then calls L{handle_line} to process that line.</tt> </tt> <a name="L503"></a><tt class="py-lineno">503</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt> <a name="L504"></a><tt class="py-lineno">504</tt> <tt class="py-line"> <tt class="py-comment"># If we encounter any errors, then just give up.</tt> </tt> <a name="L505"></a><tt class="py-lineno">505</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-keyword">if</tt> <tt class="py-name">toktype</tt> <tt class="py-op">==</tt> <tt class="py-name">token</tt><tt class="py-op">.</tt><tt class="py-name">ERRORTOKEN</tt><tt class="py-op">:</tt> </tt> <a name="L506"></a><tt class="py-lineno">506</tt> <tt class="py-line"> <tt class="py-keyword">raise</tt> <tt class="py-name">tokenize</tt><tt class="py-op">.</tt><tt class="py-name">TokenError</tt><tt class="py-op">,</tt> <tt class="py-name">toktype</tt> </tt> <a name="L507"></a><tt class="py-lineno">507</tt> <tt class="py-line"> </tt> <a name="L508"></a><tt class="py-lineno">508</tt> <tt class="py-line"> <tt class="py-comment"># Did we skip anything whitespace? If so, add a pseudotoken</tt> </tt> <a name="L509"></a><tt class="py-lineno">509</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment"># for it, with toktype=None. (Note -- this skipped string</tt> </tt> <a name="L510"></a><tt class="py-lineno">510</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment"># might also contain continuation slashes; but I won't bother</tt> </tt> <a name="L511"></a><tt class="py-lineno">511</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment"># to colorize them.)</tt> </tt> <a name="L512"></a><tt class="py-lineno">512</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-name">startpos</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">line_offsets</tt><tt class="py-op">[</tt><tt class="py-name">srow</tt><tt class="py-op">]</tt> <tt class="py-op">+</tt> <tt class="py-name">scol</tt> </tt> <a name="L513"></a><tt class="py-lineno">513</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">startpos</tt> <tt class="py-op">></tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">pos</tt><tt class="py-op">:</tt> </tt> <a name="L514"></a><tt class="py-lineno">514</tt> <tt class="py-line"> <tt class="py-name">skipped</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">text</tt><tt class="py-op">[</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">pos</tt><tt class="py-op">:</tt><tt class="py-name">startpos</tt><tt class="py-op">]</tt> </tt> <a name="L515"></a><tt class="py-lineno">515</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">cur_line</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-op">(</tt><tt class="py-name">None</tt><tt class="py-op">,</tt> <tt class="py-name">skipped</tt><tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt> <a name="L516"></a><tt class="py-lineno">516</tt> <tt class="py-line"> </tt> <a name="L517"></a><tt class="py-lineno">517</tt> <tt class="py-line"> <tt class="py-comment"># Update our position.</tt> </tt> <a name="L518"></a><tt class="py-lineno">518</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">pos</tt> <tt class="py-op">=</tt> <tt class="py-name">startpos</tt> <tt class="py-op">+</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt><tt class="py-name">toktext</tt><tt class="py-op">)</tt> </tt> <a name="L519"></a><tt class="py-lineno">519</tt> <tt class="py-line"> </tt> <a name="L520"></a><tt class="py-lineno">520</tt> <tt class="py-line"> <tt class="py-comment"># Update our current line.</tt> </tt> <a name="L521"></a><tt class="py-lineno">521</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">cur_line</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt> <tt class="py-op">(</tt><tt class="py-name">toktype</tt><tt class="py-op">,</tt> <tt class="py-name">toktext</tt><tt class="py-op">)</tt> <tt class="py-op">)</tt> </tt> <a name="L522"></a><tt class="py-lineno">522</tt> <tt class="py-line"> </tt> <a name="L523"></a><tt class="py-lineno">523</tt> <tt class="py-line"> <tt class="py-comment"># When we reach the end of a line, process it.</tt> </tt> <a name="L524"></a><tt class="py-lineno">524</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-keyword">if</tt> <tt class="py-name">toktype</tt> <tt class="py-op">==</tt> <tt class="py-name">token</tt><tt class="py-op">.</tt><tt class="py-name">NEWLINE</tt> <tt class="py-keyword">or</tt> <tt class="py-name">toktype</tt> <tt class="py-op">==</tt> <tt class="py-name">token</tt><tt class="py-op">.</tt><tt class="py-name">ENDMARKER</tt><tt class="py-op">:</tt> </tt> <a name="L525"></a><tt class="py-lineno">525</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-43" class="py-name" targets="Method epydoc.docwriter.html_colorize.PythonSourceColorizer.handle_line()=epydoc.docwriter.html_colorize.PythonSourceColorizer-class.html#handle_line"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.handle_line" class="py-name" href="#" onclick="return doclink('link-43', 'handle_line', 'link-43');">handle_line</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">cur_line</tt><tt class="py-op">)</tt> </tt> <a name="L526"></a><tt class="py-lineno">526</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">cur_line</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-op">]</tt> </tt> </div><a name="L527"></a><tt class="py-lineno">527</tt> <tt class="py-line"> </tt> <a name="L528"></a><tt class="py-lineno">528</tt> <tt class="py-line"> <tt id="link-44" class="py-name" targets="Variable epydoc.docwriter.html_colorize.PythonSourceColorizer._next_uid=epydoc.docwriter.html_colorize.PythonSourceColorizer-class.html#_next_uid"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer._next_uid" class="py-name" href="#" onclick="return doclink('link-44', '_next_uid', 'link-44');">_next_uid</a></tt> <tt class="py-op">=</tt> <tt class="py-number">0</tt> </tt> <a name="L529"></a><tt class="py-lineno">529</tt> <tt class="py-line"> </tt> <a name="L530"></a><tt class="py-lineno">530</tt> <tt class="py-line"> <tt class="py-comment"># [xx] note -- this works with byte strings, not unicode strings!</tt> </tt> <a name="L531"></a><tt class="py-lineno">531</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment"># I may change it to use unicode eventually, but when I do it</tt> </tt> <a name="L532"></a><tt class="py-lineno">532</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment"># needs to be changed all at once.</tt> </tt> <a name="PythonSourceColorizer.handle_line"></a><div id="PythonSourceColorizer.handle_line-def"><a name="L533"></a><tt class="py-lineno">533</tt> <a class="py-toggle" href="#" id="PythonSourceColorizer.handle_line-toggle" onclick="return toggle('PythonSourceColorizer.handle_line');">-</a><tt class="py-line"><tt class="py-comment"></tt> <tt class="py-keyword">def</tt> <a class="py-def-name" href="epydoc.docwriter.html_colorize.PythonSourceColorizer-class.html#handle_line">handle_line</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">line</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> </div><div id="PythonSourceColorizer.handle_line-collapsed" style="display:none;" pad="+++" indent="++++++++"></div><div id="PythonSourceColorizer.handle_line-expanded"><a name="L534"></a><tt class="py-lineno">534</tt> <tt class="py-line"> <tt class="py-docstring">"""</tt> </tt> <a name="L535"></a><tt class="py-lineno">535</tt> <tt class="py-line"><tt class="py-docstring"> Render a single logical line from the module, and write the</tt> </tt> <a name="L536"></a><tt class="py-lineno">536</tt> <tt class="py-line"><tt class="py-docstring"> generated HTML to C{self.out}.</tt> </tt> <a name="L537"></a><tt class="py-lineno">537</tt> <tt class="py-line"><tt class="py-docstring"></tt> </tt> <a name="L538"></a><tt class="py-lineno">538</tt> <tt class="py-line"><tt class="py-docstring"> @param line: A single logical line, encoded as a list of</tt> </tt> <a name="L539"></a><tt class="py-lineno">539</tt> <tt class="py-line"><tt class="py-docstring"> C{(toktype,tokttext)} pairs corresponding to the tokens in</tt> </tt> <a name="L540"></a><tt class="py-lineno">540</tt> <tt class="py-line"><tt class="py-docstring"> the line.</tt> </tt> <a name="L541"></a><tt class="py-lineno">541</tt> <tt class="py-line"><tt class="py-docstring"> """</tt> </tt> <a name="L542"></a><tt class="py-lineno">542</tt> <tt class="py-line"> <tt class="py-comment"># def_name is the name of the function or class defined by</tt> </tt> <a name="L543"></a><tt class="py-lineno">543</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment"># this line; or None if no funciton or class is defined.</tt> </tt> <a name="L544"></a><tt class="py-lineno">544</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-name">def_name</tt> <tt class="py-op">=</tt> <tt class="py-name">None</tt> </tt> <a name="L545"></a><tt class="py-lineno">545</tt> <tt class="py-line"> </tt> <a name="L546"></a><tt class="py-lineno">546</tt> <tt class="py-line"> <tt class="py-comment"># def_type is the type of the function or class defined by</tt> </tt> <a name="L547"></a><tt class="py-lineno">547</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment"># this line; or None if no funciton or class is defined.</tt> </tt> <a name="L548"></a><tt class="py-lineno">548</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-name">def_type</tt> <tt class="py-op">=</tt> <tt class="py-name">None</tt> </tt> <a name="L549"></a><tt class="py-lineno">549</tt> <tt class="py-line"> </tt> <a name="L550"></a><tt class="py-lineno">550</tt> <tt class="py-line"> <tt class="py-comment"># does this line start a class/func def?</tt> </tt> <a name="L551"></a><tt class="py-lineno">551</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-name">starting_def_block</tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt> <a name="L552"></a><tt class="py-lineno">552</tt> <tt class="py-line"> </tt> <a name="L553"></a><tt class="py-lineno">553</tt> <tt class="py-line"> <tt class="py-name">in_base_list</tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt> <a name="L554"></a><tt class="py-lineno">554</tt> <tt class="py-line"> <tt class="py-name">in_param_list</tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt> <a name="L555"></a><tt class="py-lineno">555</tt> <tt class="py-line"> <tt class="py-name">in_param_default</tt> <tt class="py-op">=</tt> <tt class="py-number">0</tt> </tt> <a name="L556"></a><tt class="py-lineno">556</tt> <tt class="py-line"> <tt class="py-name">at_module_top</tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-45" class="py-name"><a title="epydoc.apidoc.RoutineDoc.lineno" class="py-name" href="#" onclick="return doclink('link-45', 'lineno', 'link-18');">lineno</a></tt> <tt class="py-op">==</tt> <tt class="py-number">1</tt><tt class="py-op">)</tt> </tt> <a name="L557"></a><tt class="py-lineno">557</tt> <tt class="py-line"> </tt> <a name="L558"></a><tt class="py-lineno">558</tt> <tt class="py-line"> <tt class="py-name">ended_def_blocks</tt> <tt class="py-op">=</tt> <tt class="py-number">0</tt> </tt> <a name="L559"></a><tt class="py-lineno">559</tt> <tt class="py-line"> </tt> <a name="L560"></a><tt class="py-lineno">560</tt> <tt class="py-line"> <tt class="py-comment"># The html output.</tt> </tt> <a name="L561"></a><tt class="py-lineno">561</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-keyword">if</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-46" class="py-name"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.ADD_LINE_NUMBERS" class="py-name" href="#" onclick="return doclink('link-46', 'ADD_LINE_NUMBERS', 'link-14');">ADD_LINE_NUMBERS</a></tt><tt class="py-op">:</tt> </tt> <a name="L562"></a><tt class="py-lineno">562</tt> <tt class="py-line"> <tt class="py-name">s</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-47" class="py-name" targets="Method epydoc.docwriter.html_colorize.PythonSourceColorizer.lineno_to_html()=epydoc.docwriter.html_colorize.PythonSourceColorizer-class.html#lineno_to_html"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.lineno_to_html" class="py-name" href="#" onclick="return doclink('link-47', 'lineno_to_html', 'link-47');">lineno_to_html</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> <a name="L563"></a><tt class="py-lineno">563</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-48" class="py-name"><a title="epydoc.apidoc.RoutineDoc.lineno" class="py-name" href="#" onclick="return doclink('link-48', 'lineno', 'link-18');">lineno</a></tt> <tt class="py-op">+=</tt> <tt class="py-number">1</tt> </tt> <a name="L564"></a><tt class="py-lineno">564</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt> <a name="L565"></a><tt class="py-lineno">565</tt> <tt class="py-line"> <tt class="py-name">s</tt> <tt class="py-op">=</tt> <tt class="py-string">''</tt> </tt> <a name="L566"></a><tt class="py-lineno">566</tt> <tt class="py-line"> <tt class="py-name">s</tt> <tt class="py-op">+=</tt> <tt class="py-string">' <tt class="py-line">'</tt> </tt> <a name="L567"></a><tt class="py-lineno">567</tt> <tt class="py-line"> </tt> <a name="L568"></a><tt class="py-lineno">568</tt> <tt class="py-line"> <tt class="py-comment"># Loop through each token, and colorize it appropriately.</tt> </tt> <a name="L569"></a><tt class="py-lineno">569</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt><tt class="py-op">,</tt> <tt class="py-op">(</tt><tt class="py-name">toktype</tt><tt class="py-op">,</tt> <tt class="py-name">toktext</tt><tt class="py-op">)</tt> <tt class="py-keyword">in</tt> <tt class="py-name">enumerate</tt><tt class="py-op">(</tt><tt class="py-name">line</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> <a name="L570"></a><tt class="py-lineno">570</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">type</tt><tt class="py-op">(</tt><tt class="py-name">s</tt><tt class="py-op">)</tt> <tt class="py-keyword">is</tt> <tt class="py-keyword">not</tt> <tt class="py-name">str</tt><tt class="py-op">:</tt> </tt> <a name="L571"></a><tt class="py-lineno">571</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">type</tt><tt class="py-op">(</tt><tt class="py-name">s</tt><tt class="py-op">)</tt> <tt class="py-keyword">is</tt> <tt class="py-name">unicode</tt><tt class="py-op">:</tt> </tt> <a name="L572"></a><tt class="py-lineno">572</tt> <tt class="py-line"> <tt id="link-49" class="py-name"><a title="epydoc.cli.ConsoleLogger.log epydoc.cli.HTMLLogger.log epydoc.gui.GUILogger.log epydoc.log epydoc.log.Logger.log epydoc.log.SimpleLogger.log" class="py-name" href="#" onclick="return doclink('link-49', 'log', 'link-1');">log</a></tt><tt class="py-op">.</tt><tt id="link-50" class="py-name" targets="Function epydoc.log.error()=epydoc.log-module.html#error"><a title="epydoc.log.error" class="py-name" href="#" onclick="return doclink('link-50', 'error', 'link-50');">error</a></tt><tt class="py-op">(</tt><tt class="py-string">'While colorizing %s -- got unexpected '</tt> </tt> <a name="L573"></a><tt class="py-lineno">573</tt> <tt class="py-line"> <tt class="py-string">'unicode string'</tt> <tt class="py-op">%</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">module_name</tt><tt class="py-op">)</tt> </tt> <a name="L574"></a><tt class="py-lineno">574</tt> <tt class="py-line"> <tt class="py-name">s</tt> <tt class="py-op">=</tt> <tt class="py-name">s</tt><tt class="py-op">.</tt><tt class="py-name">encode</tt><tt class="py-op">(</tt><tt class="py-string">'ascii'</tt><tt class="py-op">,</tt> <tt class="py-string">'xmlcharrefreplace'</tt><tt class="py-op">)</tt> </tt> <a name="L575"></a><tt class="py-lineno">575</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt> <a name="L576"></a><tt class="py-lineno">576</tt> <tt class="py-line"> <tt class="py-keyword">raise</tt> <tt class="py-name">ValueError</tt><tt class="py-op">(</tt><tt class="py-string">'Unexpected value for s -- %s'</tt> <tt class="py-op">%</tt> </tt> <a name="L577"></a><tt class="py-lineno">577</tt> <tt class="py-line"> <tt class="py-name">type</tt><tt class="py-op">(</tt><tt class="py-name">s</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">__name__</tt><tt class="py-op">)</tt> </tt> <a name="L578"></a><tt class="py-lineno">578</tt> <tt class="py-line"> </tt> <a name="L579"></a><tt class="py-lineno">579</tt> <tt class="py-line"> <tt class="py-comment"># For each token, determine its css class and whether it</tt> </tt> <a name="L580"></a><tt class="py-lineno">580</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment"># should link to a url.</tt> </tt> <a name="L581"></a><tt class="py-lineno">581</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-name">css_class</tt> <tt class="py-op">=</tt> <tt class="py-name">None</tt> </tt> <a name="L582"></a><tt class="py-lineno">582</tt> <tt class="py-line"> <tt id="link-51" class="py-name" targets="Method epydoc.docwriter.html.HTMLWriter.url()=epydoc.docwriter.html.HTMLWriter-class.html#url"><a title="epydoc.docwriter.html.HTMLWriter.url" class="py-name" href="#" onclick="return doclink('link-51', 'url', 'link-51');">url</a></tt> <tt class="py-op">=</tt> <tt class="py-name">None</tt> </tt> <a name="L583"></a><tt class="py-lineno">583</tt> <tt class="py-line"> <tt class="py-name">tooltip</tt> <tt class="py-op">=</tt> <tt class="py-name">None</tt> </tt> <a name="L584"></a><tt class="py-lineno">584</tt> <tt class="py-line"> <tt class="py-name">onclick</tt> <tt class="py-op">=</tt> <tt class="py-name">uid</tt> <tt class="py-op">=</tt> <tt class="py-name">targets</tt> <tt class="py-op">=</tt> <tt class="py-name">None</tt> <tt class="py-comment"># these 3 are used together.</tt> </tt> <a name="L585"></a><tt class="py-lineno">585</tt> <tt class="py-line"> </tt> <a name="L586"></a><tt class="py-lineno">586</tt> <tt class="py-line"> <tt class="py-comment"># Is this token the class name in a class definition? If</tt> </tt> <a name="L587"></a><tt class="py-lineno">587</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment"># so, then make it a link back into the API docs.</tt> </tt> <a name="L588"></a><tt class="py-lineno">588</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-keyword">if</tt> <tt class="py-name">i</tt><tt class="py-op">>=</tt><tt class="py-number">2</tt> <tt class="py-keyword">and</tt> <tt class="py-name">line</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">-</tt><tt class="py-number">2</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-string">'class'</tt><tt class="py-op">:</tt> </tt> <a name="L589"></a><tt class="py-lineno">589</tt> <tt class="py-line"> <tt class="py-name">in_base_list</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt> <a name="L590"></a><tt class="py-lineno">590</tt> <tt class="py-line"> <tt class="py-name">css_class</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-52" class="py-name"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.CSS_CLASSES" class="py-name" href="#" onclick="return doclink('link-52', 'CSS_CLASSES', 'link-9');">CSS_CLASSES</a></tt><tt class="py-op">[</tt><tt class="py-string">'DEFNAME'</tt><tt class="py-op">]</tt> </tt> <a name="L591"></a><tt class="py-lineno">591</tt> <tt class="py-line"> <tt class="py-name">def_name</tt> <tt class="py-op">=</tt> <tt class="py-name">toktext</tt> </tt> <a name="L592"></a><tt class="py-lineno">592</tt> <tt class="py-line"> <tt class="py-name">def_type</tt> <tt class="py-op">=</tt> <tt class="py-string">'class'</tt> </tt> <a name="L593"></a><tt class="py-lineno">593</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-string">'func'</tt> <tt class="py-keyword">not</tt> <tt class="py-keyword">in</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">context_types</tt><tt class="py-op">:</tt> </tt> <a name="L594"></a><tt class="py-lineno">594</tt> <tt class="py-line"> <tt class="py-name">cls_name</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-53" class="py-name" targets="Method epydoc.docwriter.html_colorize.PythonSourceColorizer.context_name()=epydoc.docwriter.html_colorize.PythonSourceColorizer-class.html#context_name"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.context_name" class="py-name" href="#" onclick="return doclink('link-53', 'context_name', 'link-53');">context_name</a></tt><tt class="py-op">(</tt><tt class="py-name">def_name</tt><tt class="py-op">)</tt> </tt> <a name="L595"></a><tt class="py-lineno">595</tt> <tt class="py-line"> <tt id="link-54" class="py-name"><a title="epydoc.docwriter.html.HTMLWriter.url" class="py-name" href="#" onclick="return doclink('link-54', 'url', 'link-51');">url</a></tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-55" class="py-name" targets="Method epydoc.docwriter.html_colorize.PythonSourceColorizer.name2url()=epydoc.docwriter.html_colorize.PythonSourceColorizer-class.html#name2url"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.name2url" class="py-name" href="#" onclick="return doclink('link-55', 'name2url', 'link-55');">name2url</a></tt><tt class="py-op">(</tt><tt class="py-name">cls_name</tt><tt class="py-op">)</tt> </tt> <a name="L596"></a><tt class="py-lineno">596</tt> <tt class="py-line"> <tt class="py-name">s</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-56" class="py-name" targets="Method epydoc.docwriter.html_colorize.PythonSourceColorizer.mark_def()=epydoc.docwriter.html_colorize.PythonSourceColorizer-class.html#mark_def"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.mark_def" class="py-name" href="#" onclick="return doclink('link-56', 'mark_def', 'link-56');">mark_def</a></tt><tt class="py-op">(</tt><tt class="py-name">s</tt><tt class="py-op">,</tt> <tt class="py-name">cls_name</tt><tt class="py-op">)</tt> </tt> <a name="L597"></a><tt class="py-lineno">597</tt> <tt class="py-line"> <tt class="py-name">starting_def_block</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt> <a name="L598"></a><tt class="py-lineno">598</tt> <tt class="py-line"> </tt> <a name="L599"></a><tt class="py-lineno">599</tt> <tt class="py-line"> <tt class="py-comment"># Is this token the function name in a function def? If</tt> </tt> <a name="L600"></a><tt class="py-lineno">600</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment"># so, then make it a link back into the API docs.</tt> </tt> <a name="L601"></a><tt class="py-lineno">601</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-keyword">elif</tt> <tt class="py-name">i</tt><tt class="py-op">>=</tt><tt class="py-number">2</tt> <tt class="py-keyword">and</tt> <tt class="py-name">line</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">-</tt><tt class="py-number">2</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-string">'def'</tt><tt class="py-op">:</tt> </tt> <a name="L602"></a><tt class="py-lineno">602</tt> <tt class="py-line"> <tt class="py-name">in_param_list</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt> <a name="L603"></a><tt class="py-lineno">603</tt> <tt class="py-line"> <tt class="py-name">css_class</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-57" class="py-name"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.CSS_CLASSES" class="py-name" href="#" onclick="return doclink('link-57', 'CSS_CLASSES', 'link-9');">CSS_CLASSES</a></tt><tt class="py-op">[</tt><tt class="py-string">'DEFNAME'</tt><tt class="py-op">]</tt> </tt> <a name="L604"></a><tt class="py-lineno">604</tt> <tt class="py-line"> <tt class="py-name">def_name</tt> <tt class="py-op">=</tt> <tt class="py-name">toktext</tt> </tt> <a name="L605"></a><tt class="py-lineno">605</tt> <tt class="py-line"> <tt class="py-name">def_type</tt> <tt class="py-op">=</tt> <tt class="py-string">'func'</tt> </tt> <a name="L606"></a><tt class="py-lineno">606</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-string">'func'</tt> <tt class="py-keyword">not</tt> <tt class="py-keyword">in</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">context_types</tt><tt class="py-op">:</tt> </tt> <a name="L607"></a><tt class="py-lineno">607</tt> <tt class="py-line"> <tt class="py-name">cls_name</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-58" class="py-name"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.context_name" class="py-name" href="#" onclick="return doclink('link-58', 'context_name', 'link-53');">context_name</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> <a name="L608"></a><tt class="py-lineno">608</tt> <tt class="py-line"> <tt class="py-name">func_name</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-59" class="py-name"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.context_name" class="py-name" href="#" onclick="return doclink('link-59', 'context_name', 'link-53');">context_name</a></tt><tt class="py-op">(</tt><tt class="py-name">def_name</tt><tt class="py-op">)</tt> </tt> <a name="L609"></a><tt class="py-lineno">609</tt> <tt class="py-line"> <tt id="link-60" class="py-name"><a title="epydoc.docwriter.html.HTMLWriter.url" class="py-name" href="#" onclick="return doclink('link-60', 'url', 'link-51');">url</a></tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-61" class="py-name"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.name2url" class="py-name" href="#" onclick="return doclink('link-61', 'name2url', 'link-55');">name2url</a></tt><tt class="py-op">(</tt><tt class="py-name">cls_name</tt><tt class="py-op">,</tt> <tt class="py-name">def_name</tt><tt class="py-op">)</tt> </tt> <a name="L610"></a><tt class="py-lineno">610</tt> <tt class="py-line"> <tt class="py-name">s</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-62" class="py-name"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.mark_def" class="py-name" href="#" onclick="return doclink('link-62', 'mark_def', 'link-56');">mark_def</a></tt><tt class="py-op">(</tt><tt class="py-name">s</tt><tt class="py-op">,</tt> <tt class="py-name">func_name</tt><tt class="py-op">)</tt> </tt> <a name="L611"></a><tt class="py-lineno">611</tt> <tt class="py-line"> <tt class="py-name">starting_def_block</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt> <a name="L612"></a><tt class="py-lineno">612</tt> <tt class="py-line"> </tt> <a name="L613"></a><tt class="py-lineno">613</tt> <tt class="py-line"> <tt class="py-comment"># For each indent, update the indents list (which we use</tt> </tt> <a name="L614"></a><tt class="py-lineno">614</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment"># to keep track of indentation strings) and the context</tt> </tt> <a name="L615"></a><tt class="py-lineno">615</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment"># list. If this indent is the start of a class or</tt> </tt> <a name="L616"></a><tt class="py-lineno">616</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment"># function def block, then self.def_name will be its name;</tt> </tt> <a name="L617"></a><tt class="py-lineno">617</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment"># otherwise, it will be None.</tt> </tt> <a name="L618"></a><tt class="py-lineno">618</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-keyword">elif</tt> <tt class="py-name">toktype</tt> <tt class="py-op">==</tt> <tt class="py-name">token</tt><tt class="py-op">.</tt><tt class="py-name">INDENT</tt><tt class="py-op">:</tt> </tt> <a name="L619"></a><tt class="py-lineno">619</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">indents</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt><tt class="py-name">toktext</tt><tt class="py-op">)</tt> </tt> <a name="L620"></a><tt class="py-lineno">620</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">context</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">def_name</tt><tt class="py-op">)</tt> </tt> <a name="L621"></a><tt class="py-lineno">621</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">context_types</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">def_type</tt><tt class="py-op">)</tt> </tt> <a name="L622"></a><tt class="py-lineno">622</tt> <tt class="py-line"> </tt> <a name="L623"></a><tt class="py-lineno">623</tt> <tt class="py-line"> <tt class="py-comment"># When we dedent, pop the last elements off the indents</tt> </tt> <a name="L624"></a><tt class="py-lineno">624</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment"># list and the context list. If the last context element</tt> </tt> <a name="L625"></a><tt class="py-lineno">625</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment"># is a name, then we're ending a class or function def</tt> </tt> <a name="L626"></a><tt class="py-lineno">626</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment"># block; so write an end-div tag.</tt> </tt> <a name="L627"></a><tt class="py-lineno">627</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-keyword">elif</tt> <tt class="py-name">toktype</tt> <tt class="py-op">==</tt> <tt class="py-name">token</tt><tt class="py-op">.</tt><tt class="py-name">DEDENT</tt><tt class="py-op">:</tt> </tt> <a name="L628"></a><tt class="py-lineno">628</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">indents</tt><tt class="py-op">.</tt><tt class="py-name">pop</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> <a name="L629"></a><tt class="py-lineno">629</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">context_types</tt><tt class="py-op">.</tt><tt class="py-name">pop</tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> <a name="L630"></a><tt class="py-lineno">630</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">context</tt><tt class="py-op">.</tt><tt class="py-name">pop</tt><tt class="py-op">(</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> <a name="L631"></a><tt class="py-lineno">631</tt> <tt class="py-line"> <tt class="py-name">ended_def_blocks</tt> <tt class="py-op">+=</tt> <tt class="py-number">1</tt> </tt> <a name="L632"></a><tt class="py-lineno">632</tt> <tt class="py-line"> </tt> <a name="L633"></a><tt class="py-lineno">633</tt> <tt class="py-line"> <tt class="py-comment"># If this token contains whitespace, then don't bother to</tt> </tt> <a name="L634"></a><tt class="py-lineno">634</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment"># give it a css tag.</tt> </tt> <a name="L635"></a><tt class="py-lineno">635</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-keyword">elif</tt> <tt class="py-name">toktype</tt> <tt class="py-keyword">in</tt> <tt class="py-op">(</tt><tt class="py-name">None</tt><tt class="py-op">,</tt> <tt class="py-name">tokenize</tt><tt class="py-op">.</tt><tt class="py-name">NL</tt><tt class="py-op">,</tt> <tt class="py-name">token</tt><tt class="py-op">.</tt><tt class="py-name">NEWLINE</tt><tt class="py-op">,</tt> </tt> <a name="L636"></a><tt class="py-lineno">636</tt> <tt class="py-line"> <tt class="py-name">token</tt><tt class="py-op">.</tt><tt class="py-name">ENDMARKER</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> <a name="L637"></a><tt class="py-lineno">637</tt> <tt class="py-line"> <tt class="py-name">css_class</tt> <tt class="py-op">=</tt> <tt class="py-name">None</tt> </tt> <a name="L638"></a><tt class="py-lineno">638</tt> <tt class="py-line"> </tt> <a name="L639"></a><tt class="py-lineno">639</tt> <tt class="py-line"> <tt class="py-comment"># Check if the token is a keyword.</tt> </tt> <a name="L640"></a><tt class="py-lineno">640</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-keyword">elif</tt> <tt class="py-name">toktype</tt> <tt class="py-op">==</tt> <tt class="py-name">token</tt><tt class="py-op">.</tt><tt class="py-name">NAME</tt> <tt class="py-keyword">and</tt> <tt class="py-name">keyword</tt><tt class="py-op">.</tt><tt class="py-name">iskeyword</tt><tt class="py-op">(</tt><tt class="py-name">toktext</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> <a name="L641"></a><tt class="py-lineno">641</tt> <tt class="py-line"> <tt class="py-name">css_class</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-63" class="py-name"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.CSS_CLASSES" class="py-name" href="#" onclick="return doclink('link-63', 'CSS_CLASSES', 'link-9');">CSS_CLASSES</a></tt><tt class="py-op">[</tt><tt class="py-string">'KEYWORD'</tt><tt class="py-op">]</tt> </tt> <a name="L642"></a><tt class="py-lineno">642</tt> <tt class="py-line"> </tt> <a name="L643"></a><tt class="py-lineno">643</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">in_base_list</tt> <tt class="py-keyword">and</tt> <tt class="py-name">toktype</tt> <tt class="py-op">==</tt> <tt class="py-name">token</tt><tt class="py-op">.</tt><tt class="py-name">NAME</tt><tt class="py-op">:</tt> </tt> <a name="L644"></a><tt class="py-lineno">644</tt> <tt class="py-line"> <tt class="py-name">css_class</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-64" class="py-name"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.CSS_CLASSES" class="py-name" href="#" onclick="return doclink('link-64', 'CSS_CLASSES', 'link-9');">CSS_CLASSES</a></tt><tt class="py-op">[</tt><tt class="py-string">'BASECLASS'</tt><tt class="py-op">]</tt> </tt> <a name="L645"></a><tt class="py-lineno">645</tt> <tt class="py-line"> </tt> <a name="L646"></a><tt class="py-lineno">646</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-op">(</tt><tt class="py-name">in_param_list</tt> <tt class="py-keyword">and</tt> <tt class="py-name">toktype</tt> <tt class="py-op">==</tt> <tt class="py-name">token</tt><tt class="py-op">.</tt><tt class="py-name">NAME</tt> <tt class="py-keyword">and</tt> </tt> <a name="L647"></a><tt class="py-lineno">647</tt> <tt class="py-line"> <tt class="py-keyword">not</tt> <tt class="py-name">in_param_default</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> <a name="L648"></a><tt class="py-lineno">648</tt> <tt class="py-line"> <tt class="py-name">css_class</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-65" class="py-name"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.CSS_CLASSES" class="py-name" href="#" onclick="return doclink('link-65', 'CSS_CLASSES', 'link-9');">CSS_CLASSES</a></tt><tt class="py-op">[</tt><tt class="py-string">'PARAM'</tt><tt class="py-op">]</tt> </tt> <a name="L649"></a><tt class="py-lineno">649</tt> <tt class="py-line"> </tt> <a name="L650"></a><tt class="py-lineno">650</tt> <tt class="py-line"> <tt class="py-comment"># Class/function docstring.</tt> </tt> <a name="L651"></a><tt class="py-lineno">651</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-keyword">elif</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">def_name</tt> <tt class="py-keyword">and</tt> <tt class="py-name">line</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">-</tt><tt class="py-number">1</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-name">token</tt><tt class="py-op">.</tt><tt class="py-name">INDENT</tt> <tt class="py-keyword">and</tt> </tt> <a name="L652"></a><tt class="py-lineno">652</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-66" class="py-name" targets="Method epydoc.docwriter.html_colorize.PythonSourceColorizer.is_docstring()=epydoc.docwriter.html_colorize.PythonSourceColorizer-class.html#is_docstring"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.is_docstring" class="py-name" href="#" onclick="return doclink('link-66', 'is_docstring', 'link-66');">is_docstring</a></tt><tt class="py-op">(</tt><tt class="py-name">line</tt><tt class="py-op">,</tt> <tt class="py-name">i</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> <a name="L653"></a><tt class="py-lineno">653</tt> <tt class="py-line"> <tt class="py-name">css_class</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-67" class="py-name"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.CSS_CLASSES" class="py-name" href="#" onclick="return doclink('link-67', 'CSS_CLASSES', 'link-9');">CSS_CLASSES</a></tt><tt class="py-op">[</tt><tt class="py-string">'DOCSTRING'</tt><tt class="py-op">]</tt> </tt> <a name="L654"></a><tt class="py-lineno">654</tt> <tt class="py-line"> </tt> <a name="L655"></a><tt class="py-lineno">655</tt> <tt class="py-line"> <tt class="py-comment"># Module docstring.</tt> </tt> <a name="L656"></a><tt class="py-lineno">656</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-keyword">elif</tt> <tt class="py-name">at_module_top</tt> <tt class="py-keyword">and</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-68" class="py-name"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.is_docstring" class="py-name" href="#" onclick="return doclink('link-68', 'is_docstring', 'link-66');">is_docstring</a></tt><tt class="py-op">(</tt><tt class="py-name">line</tt><tt class="py-op">,</tt> <tt class="py-name">i</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> <a name="L657"></a><tt class="py-lineno">657</tt> <tt class="py-line"> <tt class="py-name">css_class</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-69" class="py-name"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.CSS_CLASSES" class="py-name" href="#" onclick="return doclink('link-69', 'CSS_CLASSES', 'link-9');">CSS_CLASSES</a></tt><tt class="py-op">[</tt><tt class="py-string">'DOCSTRING'</tt><tt class="py-op">]</tt> </tt> <a name="L658"></a><tt class="py-lineno">658</tt> <tt class="py-line"> </tt> <a name="L659"></a><tt class="py-lineno">659</tt> <tt class="py-line"> <tt class="py-comment"># check for decorators??</tt> </tt> <a name="L660"></a><tt class="py-lineno">660</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-keyword">elif</tt> <tt class="py-op">(</tt><tt class="py-name">toktype</tt> <tt class="py-op">==</tt> <tt class="py-name">token</tt><tt class="py-op">.</tt><tt class="py-name">NAME</tt> <tt class="py-keyword">and</tt> </tt> <a name="L661"></a><tt class="py-lineno">661</tt> <tt class="py-line"> <tt class="py-op">(</tt><tt class="py-op">(</tt><tt class="py-name">i</tt><tt class="py-op">></tt><tt class="py-number">0</tt> <tt class="py-keyword">and</tt> <tt class="py-name">line</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">-</tt><tt class="py-number">1</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">]</tt><tt class="py-op">==</tt><tt class="py-string">'@'</tt><tt class="py-op">)</tt> <tt class="py-keyword">or</tt> </tt> <a name="L662"></a><tt class="py-lineno">662</tt> <tt class="py-line"> <tt class="py-op">(</tt><tt class="py-name">i</tt><tt class="py-op">></tt><tt class="py-number">1</tt> <tt class="py-keyword">and</tt> <tt class="py-name">line</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">-</tt><tt class="py-number">1</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">==</tt><tt class="py-name">None</tt> <tt class="py-keyword">and</tt> <tt class="py-name">line</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">-</tt><tt class="py-number">2</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-string">'@'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> <a name="L663"></a><tt class="py-lineno">663</tt> <tt class="py-line"> <tt class="py-name">css_class</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-70" class="py-name"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.CSS_CLASSES" class="py-name" href="#" onclick="return doclink('link-70', 'CSS_CLASSES', 'link-9');">CSS_CLASSES</a></tt><tt class="py-op">[</tt><tt class="py-string">'DECORATOR'</tt><tt class="py-op">]</tt> </tt> <a name="L664"></a><tt class="py-lineno">664</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">has_decorators</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt> <a name="L665"></a><tt class="py-lineno">665</tt> <tt class="py-line"> </tt> <a name="L666"></a><tt class="py-lineno">666</tt> <tt class="py-line"> <tt class="py-comment"># If it's a name, try to link it.</tt> </tt> <a name="L667"></a><tt class="py-lineno">667</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-keyword">elif</tt> <tt class="py-name">toktype</tt> <tt class="py-op">==</tt> <tt class="py-name">token</tt><tt class="py-op">.</tt><tt class="py-name">NAME</tt><tt class="py-op">:</tt> </tt> <a name="L668"></a><tt class="py-lineno">668</tt> <tt class="py-line"> <tt class="py-name">css_class</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-71" class="py-name"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.CSS_CLASSES" class="py-name" href="#" onclick="return doclink('link-71', 'CSS_CLASSES', 'link-9');">CSS_CLASSES</a></tt><tt class="py-op">[</tt><tt class="py-string">'NAME'</tt><tt class="py-op">]</tt> </tt> <a name="L669"></a><tt class="py-lineno">669</tt> <tt class="py-line"> <tt class="py-comment"># If we have a variable named `toktext` in the current</tt> </tt> <a name="L670"></a><tt class="py-lineno">670</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment"># context, then link to that. Note that if we're inside</tt> </tt> <a name="L671"></a><tt class="py-lineno">671</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment"># a function, then that function is our context, not</tt> </tt> <a name="L672"></a><tt class="py-lineno">672</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment"># the namespace that contains it. [xx] this isn't always</tt> </tt> <a name="L673"></a><tt class="py-lineno">673</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment"># the right thing to do.</tt> </tt> <a name="L674"></a><tt class="py-lineno">674</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-keyword">if</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-72" class="py-name"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.GUESS_LINK_TARGETS" class="py-name" href="#" onclick="return doclink('link-72', 'GUESS_LINK_TARGETS', 'link-16');">GUESS_LINK_TARGETS</a></tt> <tt class="py-keyword">and</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">docindex</tt> <tt class="py-keyword">is</tt> <tt class="py-keyword">not</tt> <tt class="py-name">None</tt> </tt> <a name="L675"></a><tt class="py-lineno">675</tt> <tt class="py-line"> <tt class="py-keyword">and</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">url_func</tt> <tt class="py-keyword">is</tt> <tt class="py-keyword">not</tt> <tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> <a name="L676"></a><tt class="py-lineno">676</tt> <tt class="py-line"> <tt class="py-name">context</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-name">n</tt> <tt class="py-keyword">for</tt> <tt class="py-name">n</tt> <tt class="py-keyword">in</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">context</tt> <tt class="py-keyword">if</tt> <tt class="py-name">n</tt> <tt class="py-keyword">is</tt> <tt class="py-keyword">not</tt> <tt class="py-name">None</tt><tt class="py-op">]</tt> </tt> <a name="L677"></a><tt class="py-lineno">677</tt> <tt class="py-line"> <tt id="link-73" class="py-name" targets="Method epydoc.apidoc.DocIndex.container()=epydoc.apidoc.DocIndex-class.html#container,Method epydoc.apidoc.DottedName.container()=epydoc.apidoc.DottedName-class.html#container,Variable epydoc.apidoc.VariableDoc.container=epydoc.apidoc.VariableDoc-class.html#container"><a title="epydoc.apidoc.DocIndex.container epydoc.apidoc.DottedName.container epydoc.apidoc.VariableDoc.container" class="py-name" href="#" onclick="return doclink('link-73', 'container', 'link-73');">container</a></tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">docindex</tt><tt class="py-op">.</tt><tt id="link-74" class="py-name" targets="Method epydoc.apidoc.DocIndex.get_vardoc()=epydoc.apidoc.DocIndex-class.html#get_vardoc"><a title="epydoc.apidoc.DocIndex.get_vardoc" class="py-name" href="#" onclick="return doclink('link-74', 'get_vardoc', 'link-74');">get_vardoc</a></tt><tt class="py-op">(</tt> </tt> <a name="L678"></a><tt class="py-lineno">678</tt> <tt class="py-line"> <tt id="link-75" class="py-name" targets="Class epydoc.apidoc.DottedName=epydoc.apidoc.DottedName-class.html"><a title="epydoc.apidoc.DottedName" class="py-name" href="#" onclick="return doclink('link-75', 'DottedName', 'link-75');">DottedName</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">module_name</tt><tt class="py-op">,</tt> <tt class="py-op">*</tt><tt class="py-name">context</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt> <a name="L679"></a><tt class="py-lineno">679</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt id="link-76" class="py-name"><a title="epydoc.apidoc.DocIndex.container epydoc.apidoc.DottedName.container epydoc.apidoc.VariableDoc.container" class="py-name" href="#" onclick="return doclink('link-76', 'container', 'link-73');">container</a></tt><tt class="py-op">,</tt> <tt id="link-77" class="py-name" targets="Class epydoc.apidoc.NamespaceDoc=epydoc.apidoc.NamespaceDoc-class.html"><a title="epydoc.apidoc.NamespaceDoc" class="py-name" href="#" onclick="return doclink('link-77', 'NamespaceDoc', 'link-77');">NamespaceDoc</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> <a name="L680"></a><tt class="py-lineno">680</tt> <tt class="py-line"> <tt class="py-name">doc</tt> <tt class="py-op">=</tt> <tt id="link-78" class="py-name"><a title="epydoc.apidoc.DocIndex.container epydoc.apidoc.DottedName.container epydoc.apidoc.VariableDoc.container" class="py-name" href="#" onclick="return doclink('link-78', 'container', 'link-73');">container</a></tt><tt class="py-op">.</tt><tt id="link-79" class="py-name" targets="Variable epydoc.apidoc.NamespaceDoc.variables=epydoc.apidoc.NamespaceDoc-class.html#variables"><a title="epydoc.apidoc.NamespaceDoc.variables" class="py-name" href="#" onclick="return doclink('link-79', 'variables', 'link-79');">variables</a></tt><tt class="py-op">.</tt><tt class="py-name">get</tt><tt class="py-op">(</tt><tt class="py-name">toktext</tt><tt class="py-op">)</tt> </tt> <a name="L681"></a><tt class="py-lineno">681</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">doc</tt> <tt class="py-keyword">is</tt> <tt class="py-keyword">not</tt> <tt class="py-name">None</tt><tt class="py-op">:</tt> </tt> <a name="L682"></a><tt class="py-lineno">682</tt> <tt class="py-line"> <tt id="link-80" class="py-name"><a title="epydoc.docwriter.html.HTMLWriter.url" class="py-name" href="#" onclick="return doclink('link-80', 'url', 'link-51');">url</a></tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">url_func</tt><tt class="py-op">(</tt><tt class="py-name">doc</tt><tt class="py-op">)</tt> </tt> <a name="L683"></a><tt class="py-lineno">683</tt> <tt class="py-line"> <tt class="py-name">tooltip</tt> <tt class="py-op">=</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">doc</tt><tt class="py-op">.</tt><tt id="link-81" class="py-name" targets="Variable epydoc.apidoc.GenericValueDoc.canonical_name=epydoc.apidoc.GenericValueDoc-class.html#canonical_name,Variable epydoc.apidoc.ValueDoc.canonical_name=epydoc.apidoc.ValueDoc-class.html#canonical_name,Variable epydoc.apidoc.VariableDoc.canonical_name=epydoc.apidoc.VariableDoc-class.html#canonical_name"><a title="epydoc.apidoc.GenericValueDoc.canonical_name epydoc.apidoc.ValueDoc.canonical_name epydoc.apidoc.VariableDoc.canonical_name" class="py-name" href="#" onclick="return doclink('link-81', 'canonical_name', 'link-81');">canonical_name</a></tt><tt class="py-op">)</tt> </tt> <a name="L684"></a><tt class="py-lineno">684</tt> <tt class="py-line"> <tt class="py-comment"># Otherwise, check the name_to_docs index to see what</tt> </tt> <a name="L685"></a><tt class="py-lineno">685</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment"># else this name might refer to.</tt> </tt> <a name="L686"></a><tt class="py-lineno">686</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-keyword">if</tt> <tt class="py-op">(</tt><tt id="link-82" class="py-name"><a title="epydoc.docwriter.html.HTMLWriter.url" class="py-name" href="#" onclick="return doclink('link-82', 'url', 'link-51');">url</a></tt> <tt class="py-keyword">is</tt> <tt class="py-name">None</tt> <tt class="py-keyword">and</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name_to_docs</tt> <tt class="py-keyword">is</tt> <tt class="py-keyword">not</tt> <tt class="py-name">None</tt> </tt> <a name="L687"></a><tt class="py-lineno">687</tt> <tt class="py-line"> <tt class="py-keyword">and</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">url_func</tt> <tt class="py-keyword">is</tt> <tt class="py-keyword">not</tt> <tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> <a name="L688"></a><tt class="py-lineno">688</tt> <tt class="py-line"> <tt class="py-name">docs</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">name_to_docs</tt><tt class="py-op">.</tt><tt class="py-name">get</tt><tt class="py-op">(</tt><tt class="py-name">toktext</tt><tt class="py-op">)</tt> </tt> <a name="L689"></a><tt class="py-lineno">689</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">docs</tt><tt class="py-op">:</tt> </tt> <a name="L690"></a><tt class="py-lineno">690</tt> <tt class="py-line"> <tt class="py-name">tooltip</tt><tt class="py-op">=</tt><tt class="py-string">'\n'</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">[</tt><tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">d</tt><tt class="py-op">.</tt><tt id="link-83" class="py-name"><a title="epydoc.apidoc.GenericValueDoc.canonical_name epydoc.apidoc.ValueDoc.canonical_name epydoc.apidoc.VariableDoc.canonical_name" class="py-name" href="#" onclick="return doclink('link-83', 'canonical_name', 'link-81');">canonical_name</a></tt><tt class="py-op">)</tt> </tt> <a name="L691"></a><tt class="py-lineno">691</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">d</tt> <tt class="py-keyword">in</tt> <tt class="py-name">docs</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt> <a name="L692"></a><tt class="py-lineno">692</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt><tt class="py-name">docs</tt><tt class="py-op">)</tt> <tt class="py-op">==</tt> <tt class="py-number">1</tt> <tt class="py-keyword">and</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-84" class="py-name"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.GUESS_LINK_TARGETS" class="py-name" href="#" onclick="return doclink('link-84', 'GUESS_LINK_TARGETS', 'link-16');">GUESS_LINK_TARGETS</a></tt><tt class="py-op">:</tt> </tt> <a name="L693"></a><tt class="py-lineno">693</tt> <tt class="py-line"> <tt id="link-85" class="py-name"><a title="epydoc.docwriter.html.HTMLWriter.url" class="py-name" href="#" onclick="return doclink('link-85', 'url', 'link-51');">url</a></tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">url_func</tt><tt class="py-op">(</tt><tt class="py-name">docs</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt> <a name="L694"></a><tt class="py-lineno">694</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt> <a name="L695"></a><tt class="py-lineno">695</tt> <tt class="py-line"> <tt class="py-name">uid</tt><tt class="py-op">,</tt> <tt class="py-name">onclick</tt><tt class="py-op">,</tt> <tt class="py-name">targets</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-86" class="py-name" targets="Method epydoc.docwriter.html_colorize.PythonSourceColorizer.doclink()=epydoc.docwriter.html_colorize.PythonSourceColorizer-class.html#doclink"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.doclink" class="py-name" href="#" onclick="return doclink('link-86', 'doclink', 'link-86');">doclink</a></tt><tt class="py-op">(</tt><tt class="py-name">toktext</tt><tt class="py-op">,</tt> <tt class="py-name">docs</tt><tt class="py-op">)</tt> </tt> <a name="L696"></a><tt class="py-lineno">696</tt> <tt class="py-line"> </tt> <a name="L697"></a><tt class="py-lineno">697</tt> <tt class="py-line"> <tt class="py-comment"># For all other tokens, look up the CSS class to use</tt> </tt> <a name="L698"></a><tt class="py-lineno">698</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment"># based on the token's type.</tt> </tt> <a name="L699"></a><tt class="py-lineno">699</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt> <a name="L700"></a><tt class="py-lineno">700</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">toktype</tt> <tt class="py-op">==</tt> <tt class="py-name">token</tt><tt class="py-op">.</tt><tt class="py-name">OP</tt> <tt class="py-keyword">and</tt> <tt class="py-name">toktext</tt> <tt class="py-keyword">in</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-87" class="py-name"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.CSS_CLASSES" class="py-name" href="#" onclick="return doclink('link-87', 'CSS_CLASSES', 'link-9');">CSS_CLASSES</a></tt><tt class="py-op">:</tt> </tt> <a name="L701"></a><tt class="py-lineno">701</tt> <tt class="py-line"> <tt class="py-name">css_class</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-88" class="py-name"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.CSS_CLASSES" class="py-name" href="#" onclick="return doclink('link-88', 'CSS_CLASSES', 'link-9');">CSS_CLASSES</a></tt><tt class="py-op">[</tt><tt class="py-name">toktext</tt><tt class="py-op">]</tt> </tt> <a name="L702"></a><tt class="py-lineno">702</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">token</tt><tt class="py-op">.</tt><tt class="py-name">tok_name</tt><tt class="py-op">[</tt><tt class="py-name">toktype</tt><tt class="py-op">]</tt> <tt class="py-keyword">in</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-89" class="py-name"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.CSS_CLASSES" class="py-name" href="#" onclick="return doclink('link-89', 'CSS_CLASSES', 'link-9');">CSS_CLASSES</a></tt><tt class="py-op">:</tt> </tt> <a name="L703"></a><tt class="py-lineno">703</tt> <tt class="py-line"> <tt class="py-name">css_class</tt> <tt class="py-op">=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-90" class="py-name"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.CSS_CLASSES" class="py-name" href="#" onclick="return doclink('link-90', 'CSS_CLASSES', 'link-9');">CSS_CLASSES</a></tt><tt class="py-op">[</tt><tt class="py-name">token</tt><tt class="py-op">.</tt><tt class="py-name">tok_name</tt><tt class="py-op">[</tt><tt class="py-name">toktype</tt><tt class="py-op">]</tt><tt class="py-op">]</tt> </tt> <a name="L704"></a><tt class="py-lineno">704</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt> <a name="L705"></a><tt class="py-lineno">705</tt> <tt class="py-line"> <tt class="py-name">css_class</tt> <tt class="py-op">=</tt> <tt class="py-name">None</tt> </tt> <a name="L706"></a><tt class="py-lineno">706</tt> <tt class="py-line"> </tt> <a name="L707"></a><tt class="py-lineno">707</tt> <tt class="py-line"> <tt class="py-comment"># update our status..</tt> </tt> <a name="L708"></a><tt class="py-lineno">708</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-keyword">if</tt> <tt class="py-name">toktext</tt> <tt class="py-op">==</tt> <tt class="py-string">':'</tt><tt class="py-op">:</tt> </tt> <a name="L709"></a><tt class="py-lineno">709</tt> <tt class="py-line"> <tt class="py-name">in_base_list</tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt> <a name="L710"></a><tt class="py-lineno">710</tt> <tt class="py-line"> <tt class="py-name">in_param_list</tt> <tt class="py-op">=</tt> <tt class="py-name">False</tt> </tt> <a name="L711"></a><tt class="py-lineno">711</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">toktext</tt> <tt class="py-op">==</tt> <tt class="py-string">'='</tt> <tt class="py-keyword">and</tt> <tt class="py-name">in_param_list</tt><tt class="py-op">:</tt> </tt> <a name="L712"></a><tt class="py-lineno">712</tt> <tt class="py-line"> <tt class="py-name">in_param_default</tt> <tt class="py-op">=</tt> <tt class="py-name">True</tt> </tt> <a name="L713"></a><tt class="py-lineno">713</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">in_param_default</tt><tt class="py-op">:</tt> </tt> <a name="L714"></a><tt class="py-lineno">714</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">toktext</tt> <tt class="py-keyword">in</tt> <tt class="py-op">(</tt><tt class="py-string">'('</tt><tt class="py-op">,</tt><tt class="py-string">'['</tt><tt class="py-op">,</tt><tt class="py-string">'{'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-name">in_param_default</tt> <tt class="py-op">+=</tt> <tt class="py-number">1</tt> </tt> <a name="L715"></a><tt class="py-lineno">715</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">toktext</tt> <tt class="py-keyword">in</tt> <tt class="py-op">(</tt><tt class="py-string">')'</tt><tt class="py-op">,</tt><tt class="py-string">']'</tt><tt class="py-op">,</tt><tt class="py-string">'}'</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> <tt class="py-name">in_param_default</tt> <tt class="py-op">-=</tt> <tt class="py-number">1</tt> </tt> <a name="L716"></a><tt class="py-lineno">716</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">toktext</tt> <tt class="py-op">==</tt> <tt class="py-string">','</tt> <tt class="py-keyword">and</tt> <tt class="py-name">in_param_default</tt> <tt class="py-op">==</tt> <tt class="py-number">1</tt><tt class="py-op">:</tt> </tt> <a name="L717"></a><tt class="py-lineno">717</tt> <tt class="py-line"> <tt class="py-name">in_param_default</tt> <tt class="py-op">=</tt> <tt class="py-number">0</tt> </tt> <a name="L718"></a><tt class="py-lineno">718</tt> <tt class="py-line"> </tt> <a name="L719"></a><tt class="py-lineno">719</tt> <tt class="py-line"> <tt class="py-comment"># Write this token, with appropriate colorization.</tt> </tt> <a name="L720"></a><tt class="py-lineno">720</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-keyword">if</tt> <tt class="py-name">tooltip</tt> <tt class="py-keyword">and</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-91" class="py-name"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.ADD_TOOLTIPS" class="py-name" href="#" onclick="return doclink('link-91', 'ADD_TOOLTIPS', 'link-15');">ADD_TOOLTIPS</a></tt><tt class="py-op">:</tt> </tt> <a name="L721"></a><tt class="py-lineno">721</tt> <tt class="py-line"> <tt class="py-name">tooltip_html</tt> <tt class="py-op">=</tt> <tt class="py-string">' title="%s"'</tt> <tt class="py-op">%</tt> <tt class="py-name">tooltip</tt> </tt> <a name="L722"></a><tt class="py-lineno">722</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> <tt class="py-name">tooltip_html</tt> <tt class="py-op">=</tt> <tt class="py-string">''</tt> </tt> <a name="L723"></a><tt class="py-lineno">723</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">css_class</tt><tt class="py-op">:</tt> <tt class="py-name">css_class_html</tt> <tt class="py-op">=</tt> <tt class="py-string">' class="%s"'</tt> <tt class="py-op">%</tt> <tt class="py-name">css_class</tt> </tt> <a name="L724"></a><tt class="py-lineno">724</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> <tt class="py-name">css_class_html</tt> <tt class="py-op">=</tt> <tt class="py-string">''</tt> </tt> <a name="L725"></a><tt class="py-lineno">725</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">onclick</tt><tt class="py-op">:</tt> </tt> <a name="L726"></a><tt class="py-lineno">726</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">targets</tt><tt class="py-op">:</tt> <tt class="py-name">targets_html</tt> <tt class="py-op">=</tt> <tt class="py-string">' targets="%s"'</tt> <tt class="py-op">%</tt> <tt class="py-name">targets</tt> </tt> <a name="L727"></a><tt class="py-lineno">727</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> <tt class="py-name">targets_html</tt> <tt class="py-op">=</tt> <tt class="py-string">''</tt> </tt> <a name="L728"></a><tt class="py-lineno">728</tt> <tt class="py-line"> <tt class="py-name">s</tt> <tt class="py-op">+=</tt> <tt class="py-op">(</tt><tt class="py-string">'<tt id="%s"%s%s><a%s%s href="#" onclick="%s">'</tt> <tt class="py-op">%</tt> </tt> <a name="L729"></a><tt class="py-lineno">729</tt> <tt class="py-line"> <tt class="py-op">(</tt><tt class="py-name">uid</tt><tt class="py-op">,</tt> <tt class="py-name">css_class_html</tt><tt class="py-op">,</tt> <tt class="py-name">targets_html</tt><tt class="py-op">,</tt> <tt class="py-name">tooltip_html</tt><tt class="py-op">,</tt> </tt> <a name="L730"></a><tt class="py-lineno">730</tt> <tt class="py-line"> <tt class="py-name">css_class_html</tt><tt class="py-op">,</tt> <tt class="py-name">onclick</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt> <a name="L731"></a><tt class="py-lineno">731</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt id="link-92" class="py-name"><a title="epydoc.docwriter.html.HTMLWriter.url" class="py-name" href="#" onclick="return doclink('link-92', 'url', 'link-51');">url</a></tt><tt class="py-op">:</tt> </tt> <a name="L732"></a><tt class="py-lineno">732</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt id="link-93" class="py-name"><a title="epydoc.docwriter.html.HTMLWriter.url" class="py-name" href="#" onclick="return doclink('link-93', 'url', 'link-51');">url</a></tt><tt class="py-op">,</tt> <tt class="py-name">unicode</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> <a name="L733"></a><tt class="py-lineno">733</tt> <tt class="py-line"> <tt id="link-94" class="py-name"><a title="epydoc.docwriter.html.HTMLWriter.url" class="py-name" href="#" onclick="return doclink('link-94', 'url', 'link-51');">url</a></tt> <tt class="py-op">=</tt> <tt id="link-95" class="py-name"><a title="epydoc.docwriter.html.HTMLWriter.url" class="py-name" href="#" onclick="return doclink('link-95', 'url', 'link-51');">url</a></tt><tt class="py-op">.</tt><tt class="py-name">encode</tt><tt class="py-op">(</tt><tt class="py-string">'ascii'</tt><tt class="py-op">,</tt> <tt class="py-string">'xmlcharrefreplace'</tt><tt class="py-op">)</tt> </tt> <a name="L734"></a><tt class="py-lineno">734</tt> <tt class="py-line"> <tt class="py-name">s</tt> <tt class="py-op">+=</tt> <tt class="py-op">(</tt><tt class="py-string">'<a%s%s href="%s">'</tt> <tt class="py-op">%</tt> </tt> <a name="L735"></a><tt class="py-lineno">735</tt> <tt class="py-line"> <tt class="py-op">(</tt><tt class="py-name">tooltip_html</tt><tt class="py-op">,</tt> <tt class="py-name">css_class_html</tt><tt class="py-op">,</tt> <tt id="link-96" class="py-name"><a title="epydoc.docwriter.html.HTMLWriter.url" class="py-name" href="#" onclick="return doclink('link-96', 'url', 'link-51');">url</a></tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt> <a name="L736"></a><tt class="py-lineno">736</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">css_class_html</tt> <tt class="py-keyword">or</tt> <tt class="py-name">tooltip_html</tt><tt class="py-op">:</tt> </tt> <a name="L737"></a><tt class="py-lineno">737</tt> <tt class="py-line"> <tt class="py-name">s</tt> <tt class="py-op">+=</tt> <tt class="py-string">'<tt%s%s>'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">tooltip_html</tt><tt class="py-op">,</tt> <tt class="py-name">css_class_html</tt><tt class="py-op">)</tt> </tt> <a name="L738"></a><tt class="py-lineno">738</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">i</tt> <tt class="py-op">==</tt> <tt class="py-name">len</tt><tt class="py-op">(</tt><tt class="py-name">line</tt><tt class="py-op">)</tt><tt class="py-op">-</tt><tt class="py-number">1</tt><tt class="py-op">:</tt> </tt> <a name="L739"></a><tt class="py-lineno">739</tt> <tt class="py-line"> <tt class="py-name">s</tt> <tt class="py-op">+=</tt> <tt class="py-string">' </tt>'</tt> <tt class="py-comment"># Closes <tt class="py-line"></tt> </tt> <a name="L740"></a><tt class="py-lineno">740</tt> <tt class="py-line"> <tt class="py-name">s</tt> <tt class="py-op">+=</tt> <tt class="py-name">cgi</tt><tt class="py-op">.</tt><tt class="py-name">escape</tt><tt class="py-op">(</tt><tt class="py-name">toktext</tt><tt class="py-op">)</tt> </tt> <a name="L741"></a><tt class="py-lineno">741</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt> <a name="L742"></a><tt class="py-lineno">742</tt> <tt class="py-line"> <tt class="py-keyword">try</tt><tt class="py-op">:</tt> </tt> <a name="L743"></a><tt class="py-lineno">743</tt> <tt class="py-line"> <tt class="py-name">s</tt> <tt class="py-op">+=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-97" class="py-name" targets="Method epydoc.docwriter.html_colorize.PythonSourceColorizer.add_line_numbers()=epydoc.docwriter.html_colorize.PythonSourceColorizer-class.html#add_line_numbers"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.add_line_numbers" class="py-name" href="#" onclick="return doclink('link-97', 'add_line_numbers', 'link-97');">add_line_numbers</a></tt><tt class="py-op">(</tt><tt class="py-name">cgi</tt><tt class="py-op">.</tt><tt class="py-name">escape</tt><tt class="py-op">(</tt><tt class="py-name">toktext</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> <tt class="py-name">css_class</tt><tt class="py-op">)</tt> </tt> <a name="L744"></a><tt class="py-lineno">744</tt> <tt class="py-line"> <tt class="py-keyword">except</tt> <tt class="py-name">Exception</tt><tt class="py-op">,</tt> <tt class="py-name">e</tt><tt class="py-op">:</tt> </tt> <a name="L745"></a><tt class="py-lineno">745</tt> <tt class="py-line"> <tt class="py-keyword">print</tt> <tt class="py-op">(</tt><tt class="py-name">toktext</tt><tt class="py-op">,</tt> <tt class="py-name">css_class</tt><tt class="py-op">,</tt> <tt class="py-name">toktext</tt><tt class="py-op">.</tt><tt class="py-name">encode</tt><tt class="py-op">(</tt><tt class="py-string">'ascii'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt> <a name="L746"></a><tt class="py-lineno">746</tt> <tt class="py-line"> <tt class="py-keyword">raise</tt> </tt> <a name="L747"></a><tt class="py-lineno">747</tt> <tt class="py-line"> </tt> <a name="L748"></a><tt class="py-lineno">748</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">onclick</tt><tt class="py-op">:</tt> <tt class="py-name">s</tt> <tt class="py-op">+=</tt> <tt class="py-string">"</a></tt>"</tt> </tt> <a name="L749"></a><tt class="py-lineno">749</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt id="link-98" class="py-name"><a title="epydoc.docwriter.html.HTMLWriter.url" class="py-name" href="#" onclick="return doclink('link-98', 'url', 'link-51');">url</a></tt><tt class="py-op">:</tt> <tt class="py-name">s</tt> <tt class="py-op">+=</tt> <tt class="py-string">'</a>'</tt> </tt> <a name="L750"></a><tt class="py-lineno">750</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">css_class_html</tt> <tt class="py-keyword">or</tt> <tt class="py-name">tooltip_html</tt><tt class="py-op">:</tt> <tt class="py-name">s</tt> <tt class="py-op">+=</tt> <tt class="py-string">'</tt>'</tt> </tt> <a name="L751"></a><tt class="py-lineno">751</tt> <tt class="py-line"> </tt> <a name="L752"></a><tt class="py-lineno">752</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-99" class="py-name"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.ADD_DEF_BLOCKS" class="py-name" href="#" onclick="return doclink('link-99', 'ADD_DEF_BLOCKS', 'link-13');">ADD_DEF_BLOCKS</a></tt><tt class="py-op">:</tt> </tt> <a name="L753"></a><tt class="py-lineno">753</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">i</tt> <tt class="py-keyword">in</tt> <tt class="py-name">range</tt><tt class="py-op">(</tt><tt class="py-name">ended_def_blocks</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> <a name="L754"></a><tt class="py-lineno">754</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">out</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-100" class="py-name"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.END_DEF_BLOCK" class="py-name" href="#" onclick="return doclink('link-100', 'END_DEF_BLOCK', 'link-11');">END_DEF_BLOCK</a></tt><tt class="py-op">)</tt> </tt> <a name="L755"></a><tt class="py-lineno">755</tt> <tt class="py-line"> </tt> <a name="L756"></a><tt class="py-lineno">756</tt> <tt class="py-line"> <tt class="py-comment"># Strip any empty <tt>s.</tt> </tt> <a name="L757"></a><tt class="py-lineno">757</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-name">s</tt> <tt class="py-op">=</tt> <tt class="py-name">re</tt><tt class="py-op">.</tt><tt class="py-name">sub</tt><tt class="py-op">(</tt><tt class="py-string">r'<tt class="[\w+]"></tt>'</tt><tt class="py-op">,</tt> <tt class="py-string">''</tt><tt class="py-op">,</tt> <tt class="py-name">s</tt><tt class="py-op">)</tt> </tt> <a name="L758"></a><tt class="py-lineno">758</tt> <tt class="py-line"> </tt> <a name="L759"></a><tt class="py-lineno">759</tt> <tt class="py-line"> <tt class="py-comment"># Write the line.</tt> </tt> <a name="L760"></a><tt class="py-lineno">760</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">out</tt><tt class="py-op">(</tt><tt class="py-name">s</tt><tt class="py-op">)</tt> </tt> <a name="L761"></a><tt class="py-lineno">761</tt> <tt class="py-line"> </tt> <a name="L762"></a><tt class="py-lineno">762</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">def_name</tt> <tt class="py-keyword">and</tt> <tt class="py-name">starting_def_block</tt><tt class="py-op">:</tt> </tt> <a name="L763"></a><tt class="py-lineno">763</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">out</tt><tt class="py-op">(</tt><tt class="py-string">'</div>'</tt><tt class="py-op">)</tt> </tt> <a name="L764"></a><tt class="py-lineno">764</tt> <tt class="py-line"> </tt> <a name="L765"></a><tt class="py-lineno">765</tt> <tt class="py-line"> <tt class="py-comment"># Add div's if we're starting a def block.</tt> </tt> <a name="L766"></a><tt class="py-lineno">766</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-keyword">if</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-101" class="py-name"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.ADD_DEF_BLOCKS" class="py-name" href="#" onclick="return doclink('link-101', 'ADD_DEF_BLOCKS', 'link-13');">ADD_DEF_BLOCKS</a></tt> <tt class="py-keyword">and</tt> <tt class="py-name">def_name</tt> <tt class="py-keyword">and</tt> <tt class="py-name">starting_def_block</tt> <tt class="py-keyword">and</tt> </tt> <a name="L767"></a><tt class="py-lineno">767</tt> <tt class="py-line"> <tt class="py-op">(</tt><tt class="py-name">line</tt><tt class="py-op">[</tt><tt class="py-op">-</tt><tt class="py-number">2</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-number">1</tt><tt class="py-op">]</tt> <tt class="py-op">==</tt> <tt class="py-string">':'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> <a name="L768"></a><tt class="py-lineno">768</tt> <tt class="py-line"> <tt class="py-name">indentation</tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt><tt class="py-string">''</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">indents</tt><tt class="py-op">)</tt><tt class="py-op">+</tt><tt class="py-string">' '</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt class="py-name">replace</tt><tt class="py-op">(</tt><tt class="py-string">' '</tt><tt class="py-op">,</tt> <tt class="py-string">'+'</tt><tt class="py-op">)</tt> </tt> <a name="L769"></a><tt class="py-lineno">769</tt> <tt class="py-line"> <tt class="py-name">linenum_padding</tt> <tt class="py-op">=</tt> <tt class="py-string">'+'</tt><tt class="py-op">*</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">linenum_size</tt> </tt> <a name="L770"></a><tt class="py-lineno">770</tt> <tt class="py-line"> <tt id="link-102" class="py-name" targets="Variable epydoc.apidoc.VariableDoc.name=epydoc.apidoc.VariableDoc-class.html#name"><a title="epydoc.apidoc.VariableDoc.name" class="py-name" href="#" onclick="return doclink('link-102', 'name', 'link-102');">name</a></tt><tt class="py-op">=</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-103" class="py-name"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.context_name" class="py-name" href="#" onclick="return doclink('link-103', 'context_name', 'link-53');">context_name</a></tt><tt class="py-op">(</tt><tt class="py-name">def_name</tt><tt class="py-op">)</tt> </tt> <a name="L771"></a><tt class="py-lineno">771</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">out</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-104" class="py-name"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.START_DEF_BLOCK" class="py-name" href="#" onclick="return doclink('link-104', 'START_DEF_BLOCK', 'link-10');">START_DEF_BLOCK</a></tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt id="link-105" class="py-name"><a title="epydoc.apidoc.VariableDoc.name" class="py-name" href="#" onclick="return doclink('link-105', 'name', 'link-102');">name</a></tt><tt class="py-op">,</tt> <tt class="py-name">linenum_padding</tt><tt class="py-op">,</tt> </tt> <a name="L772"></a><tt class="py-lineno">772</tt> <tt class="py-line"> <tt class="py-name">indentation</tt><tt class="py-op">,</tt> <tt id="link-106" class="py-name"><a title="epydoc.apidoc.VariableDoc.name" class="py-name" href="#" onclick="return doclink('link-106', 'name', 'link-102');">name</a></tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt> <a name="L773"></a><tt class="py-lineno">773</tt> <tt class="py-line"> </tt> <a name="L774"></a><tt class="py-lineno">774</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">def_name</tt> <tt class="py-op">=</tt> <tt class="py-name">def_name</tt> </tt> <a name="L775"></a><tt class="py-lineno">775</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">def_type</tt> <tt class="py-op">=</tt> <tt class="py-name">def_type</tt> </tt> </div><a name="L776"></a><tt class="py-lineno">776</tt> <tt class="py-line"> </tt> <a name="PythonSourceColorizer.context_name"></a><div id="PythonSourceColorizer.context_name-def"><a name="L777"></a><tt class="py-lineno">777</tt> <a class="py-toggle" href="#" id="PythonSourceColorizer.context_name-toggle" onclick="return toggle('PythonSourceColorizer.context_name');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="epydoc.docwriter.html_colorize.PythonSourceColorizer-class.html#context_name">context_name</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">extra</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> </div><div id="PythonSourceColorizer.context_name-collapsed" style="display:none;" pad="+++" indent="++++++++"></div><div id="PythonSourceColorizer.context_name-expanded"><a name="L778"></a><tt class="py-lineno">778</tt> <tt class="py-line"> <tt class="py-name">pieces</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-name">n</tt> <tt class="py-keyword">for</tt> <tt class="py-name">n</tt> <tt class="py-keyword">in</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">context</tt> <tt class="py-keyword">if</tt> <tt class="py-name">n</tt> <tt class="py-keyword">is</tt> <tt class="py-keyword">not</tt> <tt class="py-name">None</tt><tt class="py-op">]</tt> </tt> <a name="L779"></a><tt class="py-lineno">779</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">extra</tt> <tt class="py-keyword">is</tt> <tt class="py-keyword">not</tt> <tt class="py-name">None</tt><tt class="py-op">:</tt> <tt class="py-name">pieces</tt><tt class="py-op">.</tt><tt class="py-name">append</tt><tt class="py-op">(</tt><tt class="py-name">extra</tt><tt class="py-op">)</tt> </tt> <a name="L780"></a><tt class="py-lineno">780</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-string">'.'</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-name">pieces</tt><tt class="py-op">)</tt> </tt> </div><a name="L781"></a><tt class="py-lineno">781</tt> <tt class="py-line"> </tt> <a name="PythonSourceColorizer.doclink"></a><div id="PythonSourceColorizer.doclink-def"><a name="L782"></a><tt class="py-lineno">782</tt> <a class="py-toggle" href="#" id="PythonSourceColorizer.doclink-toggle" onclick="return toggle('PythonSourceColorizer.doclink');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="epydoc.docwriter.html_colorize.PythonSourceColorizer-class.html#doclink">doclink</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">name</tt><tt class="py-op">,</tt> <tt class="py-param">docs</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> </div><div id="PythonSourceColorizer.doclink-collapsed" style="display:none;" pad="+++" indent="++++++++"></div><div id="PythonSourceColorizer.doclink-expanded"><a name="L783"></a><tt class="py-lineno">783</tt> <tt class="py-line"> <tt class="py-name">uid</tt> <tt class="py-op">=</tt> <tt class="py-string">'link-%s'</tt> <tt class="py-op">%</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-107" class="py-name"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer._next_uid" class="py-name" href="#" onclick="return doclink('link-107', '_next_uid', 'link-44');">_next_uid</a></tt> </tt> <a name="L784"></a><tt class="py-lineno">784</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-108" class="py-name"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer._next_uid" class="py-name" href="#" onclick="return doclink('link-108', '_next_uid', 'link-44');">_next_uid</a></tt> <tt class="py-op">+=</tt> <tt class="py-number">1</tt> </tt> <a name="L785"></a><tt class="py-lineno">785</tt> <tt class="py-line"> <tt class="py-name">context</tt> <tt class="py-op">=</tt> <tt class="py-op">[</tt><tt class="py-name">n</tt> <tt class="py-keyword">for</tt> <tt class="py-name">n</tt> <tt class="py-keyword">in</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">context</tt> <tt class="py-keyword">if</tt> <tt class="py-name">n</tt> <tt class="py-keyword">is</tt> <tt class="py-keyword">not</tt> <tt class="py-name">None</tt><tt class="py-op">]</tt> </tt> <a name="L786"></a><tt class="py-lineno">786</tt> <tt class="py-line"> <tt id="link-109" class="py-name"><a title="epydoc.apidoc.DocIndex.container epydoc.apidoc.DottedName.container epydoc.apidoc.VariableDoc.container" class="py-name" href="#" onclick="return doclink('link-109', 'container', 'link-73');">container</a></tt> <tt class="py-op">=</tt> <tt id="link-110" class="py-name"><a title="epydoc.apidoc.DottedName" class="py-name" href="#" onclick="return doclink('link-110', 'DottedName', 'link-75');">DottedName</a></tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">module_name</tt><tt class="py-op">,</tt> <tt class="py-op">*</tt><tt class="py-name">context</tt><tt class="py-op">)</tt> </tt> <a name="L787"></a><tt class="py-lineno">787</tt> <tt class="py-line"> <tt class="py-comment">#else:</tt> </tt> <a name="L788"></a><tt class="py-lineno">788</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment"># container = None</tt> </tt> <a name="L789"></a><tt class="py-lineno">789</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-name">targets</tt> <tt class="py-op">=</tt> <tt class="py-string">','</tt><tt class="py-op">.</tt><tt class="py-name">join</tt><tt class="py-op">(</tt><tt class="py-op">[</tt><tt class="py-string">'%s=%s'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-111" class="py-name" targets="Method epydoc.docwriter.html_colorize.PythonSourceColorizer.doc_descr()=epydoc.docwriter.html_colorize.PythonSourceColorizer-class.html#doc_descr"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.doc_descr" class="py-name" href="#" onclick="return doclink('link-111', 'doc_descr', 'link-111');">doc_descr</a></tt><tt class="py-op">(</tt><tt class="py-name">d</tt><tt class="py-op">,</tt><tt id="link-112" class="py-name"><a title="epydoc.apidoc.DocIndex.container epydoc.apidoc.DottedName.container epydoc.apidoc.VariableDoc.container" class="py-name" href="#" onclick="return doclink('link-112', 'container', 'link-73');">container</a></tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> </tt> <a name="L790"></a><tt class="py-lineno">790</tt> <tt class="py-line"> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">url_func</tt><tt class="py-op">(</tt><tt class="py-name">d</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt> <a name="L791"></a><tt class="py-lineno">791</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">d</tt> <tt class="py-keyword">in</tt> <tt class="py-name">docs</tt><tt class="py-op">]</tt><tt class="py-op">)</tt> </tt> <a name="L792"></a><tt class="py-lineno">792</tt> <tt class="py-line"> </tt> <a name="L793"></a><tt class="py-lineno">793</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">targets</tt> <tt class="py-keyword">in</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">doclink_targets_cache</tt><tt class="py-op">:</tt> </tt> <a name="L794"></a><tt class="py-lineno">794</tt> <tt class="py-line"> <tt class="py-name">onclick</tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt><tt class="py-string">"return doclink('%s', '%s', '%s');"</tt> <tt class="py-op">%</tt> </tt> <a name="L795"></a><tt class="py-lineno">795</tt> <tt class="py-line"> <tt class="py-op">(</tt><tt class="py-name">uid</tt><tt class="py-op">,</tt> <tt id="link-113" class="py-name"><a title="epydoc.apidoc.VariableDoc.name" class="py-name" href="#" onclick="return doclink('link-113', 'name', 'link-102');">name</a></tt><tt class="py-op">,</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">doclink_targets_cache</tt><tt class="py-op">[</tt><tt class="py-name">targets</tt><tt class="py-op">]</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt> <a name="L796"></a><tt class="py-lineno">796</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">uid</tt><tt class="py-op">,</tt> <tt class="py-name">onclick</tt><tt class="py-op">,</tt> <tt class="py-name">None</tt> </tt> <a name="L797"></a><tt class="py-lineno">797</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt> <a name="L798"></a><tt class="py-lineno">798</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">doclink_targets_cache</tt><tt class="py-op">[</tt><tt class="py-name">targets</tt><tt class="py-op">]</tt> <tt class="py-op">=</tt> <tt class="py-name">uid</tt> </tt> <a name="L799"></a><tt class="py-lineno">799</tt> <tt class="py-line"> <tt class="py-name">onclick</tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt><tt class="py-string">"return doclink('%s', '%s', '%s');"</tt> <tt class="py-op">%</tt> </tt> <a name="L800"></a><tt class="py-lineno">800</tt> <tt class="py-line"> <tt class="py-op">(</tt><tt class="py-name">uid</tt><tt class="py-op">,</tt> <tt id="link-114" class="py-name"><a title="epydoc.apidoc.VariableDoc.name" class="py-name" href="#" onclick="return doclink('link-114', 'name', 'link-102');">name</a></tt><tt class="py-op">,</tt> <tt class="py-name">uid</tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt> <a name="L801"></a><tt class="py-lineno">801</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">uid</tt><tt class="py-op">,</tt> <tt class="py-name">onclick</tt><tt class="py-op">,</tt> <tt class="py-name">targets</tt> </tt> </div><a name="L802"></a><tt class="py-lineno">802</tt> <tt class="py-line"> </tt> <a name="PythonSourceColorizer.doc_descr"></a><div id="PythonSourceColorizer.doc_descr-def"><a name="L803"></a><tt class="py-lineno">803</tt> <a class="py-toggle" href="#" id="PythonSourceColorizer.doc_descr-toggle" onclick="return toggle('PythonSourceColorizer.doc_descr');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="epydoc.docwriter.html_colorize.PythonSourceColorizer-class.html#doc_descr">doc_descr</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">doc</tt><tt class="py-op">,</tt> <tt class="py-param">context</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> </div><div id="PythonSourceColorizer.doc_descr-collapsed" style="display:none;" pad="+++" indent="++++++++"></div><div id="PythonSourceColorizer.doc_descr-expanded"><a name="L804"></a><tt class="py-lineno">804</tt> <tt class="py-line"> <tt id="link-115" class="py-name"><a title="epydoc.apidoc.VariableDoc.name" class="py-name" href="#" onclick="return doclink('link-115', 'name', 'link-102');">name</a></tt> <tt class="py-op">=</tt> <tt class="py-name">str</tt><tt class="py-op">(</tt><tt class="py-name">doc</tt><tt class="py-op">.</tt><tt id="link-116" class="py-name"><a title="epydoc.apidoc.GenericValueDoc.canonical_name epydoc.apidoc.ValueDoc.canonical_name epydoc.apidoc.VariableDoc.canonical_name" class="py-name" href="#" onclick="return doclink('link-116', 'canonical_name', 'link-81');">canonical_name</a></tt><tt class="py-op">)</tt> </tt> <a name="L805"></a><tt class="py-lineno">805</tt> <tt class="py-line"> <tt id="link-117" class="py-name" targets="Variable epydoc.apidoc.APIDoc.descr=epydoc.apidoc.APIDoc-class.html#descr,Variable epydoc.cli.descr=epydoc.cli-module.html#descr,Method epydoc.docwriter.html.HTMLWriter.descr()=epydoc.docwriter.html.HTMLWriter-class.html#descr,Method epydoc.markup.ParseError.descr()=epydoc.markup.ParseError-class.html#descr,Method epydoc.markup.epytext.ColorizingError.descr()=epydoc.markup.epytext.ColorizingError-class.html#descr"><a title="epydoc.apidoc.APIDoc.descr epydoc.cli.descr epydoc.docwriter.html.HTMLWriter.descr epydoc.markup.ParseError.descr epydoc.markup.epytext.ColorizingError.descr" class="py-name" href="#" onclick="return doclink('link-117', 'descr', 'link-117');">descr</a></tt> <tt class="py-op">=</tt> <tt class="py-string">'%s %s'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-118" class="py-name" targets="Method epydoc.docwriter.html.HTMLWriter.doc_kind()=epydoc.docwriter.html.HTMLWriter-class.html#doc_kind,Method epydoc.docwriter.html_colorize.PythonSourceColorizer.doc_kind()=epydoc.docwriter.html_colorize.PythonSourceColorizer-class.html#doc_kind,Method epydoc.docwriter.latex.LatexWriter.doc_kind()=epydoc.docwriter.latex.LatexWriter-class.html#doc_kind"><a title="epydoc.docwriter.html.HTMLWriter.doc_kind epydoc.docwriter.html_colorize.PythonSourceColorizer.doc_kind epydoc.docwriter.latex.LatexWriter.doc_kind" class="py-name" href="#" onclick="return doclink('link-118', 'doc_kind', 'link-118');">doc_kind</a></tt><tt class="py-op">(</tt><tt class="py-name">doc</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> <tt id="link-119" class="py-name"><a title="epydoc.apidoc.VariableDoc.name" class="py-name" href="#" onclick="return doclink('link-119', 'name', 'link-102');">name</a></tt><tt class="py-op">)</tt> </tt> <a name="L806"></a><tt class="py-lineno">806</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">doc</tt><tt class="py-op">,</tt> <tt id="link-120" class="py-name" targets="Class epydoc.apidoc.RoutineDoc=epydoc.apidoc.RoutineDoc-class.html"><a title="epydoc.apidoc.RoutineDoc" class="py-name" href="#" onclick="return doclink('link-120', 'RoutineDoc', 'link-120');">RoutineDoc</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> <a name="L807"></a><tt class="py-lineno">807</tt> <tt class="py-line"> <tt id="link-121" class="py-name"><a title="epydoc.apidoc.APIDoc.descr epydoc.cli.descr epydoc.docwriter.html.HTMLWriter.descr epydoc.markup.ParseError.descr epydoc.markup.epytext.ColorizingError.descr" class="py-name" href="#" onclick="return doclink('link-121', 'descr', 'link-117');">descr</a></tt> <tt class="py-op">+=</tt> <tt class="py-string">'()'</tt> </tt> <a name="L808"></a><tt class="py-lineno">808</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt id="link-122" class="py-name"><a title="epydoc.apidoc.APIDoc.descr epydoc.cli.descr epydoc.docwriter.html.HTMLWriter.descr epydoc.markup.ParseError.descr epydoc.markup.epytext.ColorizingError.descr" class="py-name" href="#" onclick="return doclink('link-122', 'descr', 'link-117');">descr</a></tt> </tt> </div><a name="L809"></a><tt class="py-lineno">809</tt> <tt class="py-line"> </tt> <a name="L810"></a><tt class="py-lineno">810</tt> <tt class="py-line"> <tt class="py-comment"># [XX] copied streight from html.py; this should be consolidated,</tt> </tt> <a name="L811"></a><tt class="py-lineno">811</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment"># probably into apidoc.</tt> </tt> <a name="PythonSourceColorizer.doc_kind"></a><div id="PythonSourceColorizer.doc_kind-def"><a name="L812"></a><tt class="py-lineno">812</tt> <a class="py-toggle" href="#" id="PythonSourceColorizer.doc_kind-toggle" onclick="return toggle('PythonSourceColorizer.doc_kind');">-</a><tt class="py-line"><tt class="py-comment"></tt> <tt class="py-keyword">def</tt> <a class="py-def-name" href="epydoc.docwriter.html_colorize.PythonSourceColorizer-class.html#doc_kind">doc_kind</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">doc</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> </div><div id="PythonSourceColorizer.doc_kind-collapsed" style="display:none;" pad="+++" indent="++++++++"></div><div id="PythonSourceColorizer.doc_kind-expanded"><a name="L813"></a><tt class="py-lineno">813</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">doc</tt><tt class="py-op">,</tt> <tt id="link-123" class="py-name" targets="Class epydoc.apidoc.ModuleDoc=epydoc.apidoc.ModuleDoc-class.html"><a title="epydoc.apidoc.ModuleDoc" class="py-name" href="#" onclick="return doclink('link-123', 'ModuleDoc', 'link-123');">ModuleDoc</a></tt><tt class="py-op">)</tt> <tt class="py-keyword">and</tt> <tt class="py-name">doc</tt><tt class="py-op">.</tt><tt id="link-124" class="py-name" targets="Variable epydoc.apidoc.ModuleDoc.is_package=epydoc.apidoc.ModuleDoc-class.html#is_package"><a title="epydoc.apidoc.ModuleDoc.is_package" class="py-name" href="#" onclick="return doclink('link-124', 'is_package', 'link-124');">is_package</a></tt> <tt class="py-op">==</tt> <tt class="py-name">True</tt><tt class="py-op">:</tt> </tt> <a name="L814"></a><tt class="py-lineno">814</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-string">'Package'</tt> </tt> <a name="L815"></a><tt class="py-lineno">815</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-op">(</tt><tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">doc</tt><tt class="py-op">,</tt> <tt id="link-125" class="py-name"><a title="epydoc.apidoc.ModuleDoc" class="py-name" href="#" onclick="return doclink('link-125', 'ModuleDoc', 'link-123');">ModuleDoc</a></tt><tt class="py-op">)</tt> <tt class="py-keyword">and</tt> </tt> <a name="L816"></a><tt class="py-lineno">816</tt> <tt class="py-line"> <tt class="py-name">doc</tt><tt class="py-op">.</tt><tt id="link-126" class="py-name"><a title="epydoc.apidoc.GenericValueDoc.canonical_name epydoc.apidoc.ValueDoc.canonical_name epydoc.apidoc.VariableDoc.canonical_name" class="py-name" href="#" onclick="return doclink('link-126', 'canonical_name', 'link-81');">canonical_name</a></tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt><tt class="py-op">.</tt><tt class="py-name">startswith</tt><tt class="py-op">(</tt><tt class="py-string">'script'</tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> <a name="L817"></a><tt class="py-lineno">817</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-string">'Script'</tt> </tt> <a name="L818"></a><tt class="py-lineno">818</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">doc</tt><tt class="py-op">,</tt> <tt id="link-127" class="py-name"><a title="epydoc.apidoc.ModuleDoc" class="py-name" href="#" onclick="return doclink('link-127', 'ModuleDoc', 'link-123');">ModuleDoc</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> <a name="L819"></a><tt class="py-lineno">819</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-string">'Module'</tt> </tt> <a name="L820"></a><tt class="py-lineno">820</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">doc</tt><tt class="py-op">,</tt> <tt id="link-128" class="py-name" targets="Class epydoc.apidoc.ClassDoc=epydoc.apidoc.ClassDoc-class.html"><a title="epydoc.apidoc.ClassDoc" class="py-name" href="#" onclick="return doclink('link-128', 'ClassDoc', 'link-128');">ClassDoc</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> <a name="L821"></a><tt class="py-lineno">821</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-string">'Class'</tt> </tt> <a name="L822"></a><tt class="py-lineno">822</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">doc</tt><tt class="py-op">,</tt> <tt id="link-129" class="py-name" targets="Class epydoc.apidoc.ClassMethodDoc=epydoc.apidoc.ClassMethodDoc-class.html"><a title="epydoc.apidoc.ClassMethodDoc" class="py-name" href="#" onclick="return doclink('link-129', 'ClassMethodDoc', 'link-129');">ClassMethodDoc</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> <a name="L823"></a><tt class="py-lineno">823</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-string">'Class Method'</tt> </tt> <a name="L824"></a><tt class="py-lineno">824</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">doc</tt><tt class="py-op">,</tt> <tt id="link-130" class="py-name" targets="Class epydoc.apidoc.StaticMethodDoc=epydoc.apidoc.StaticMethodDoc-class.html"><a title="epydoc.apidoc.StaticMethodDoc" class="py-name" href="#" onclick="return doclink('link-130', 'StaticMethodDoc', 'link-130');">StaticMethodDoc</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> <a name="L825"></a><tt class="py-lineno">825</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-string">'Static Method'</tt> </tt> <a name="L826"></a><tt class="py-lineno">826</tt> <tt class="py-line"> <tt class="py-keyword">elif</tt> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">doc</tt><tt class="py-op">,</tt> <tt id="link-131" class="py-name"><a title="epydoc.apidoc.RoutineDoc" class="py-name" href="#" onclick="return doclink('link-131', 'RoutineDoc', 'link-120');">RoutineDoc</a></tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> <a name="L827"></a><tt class="py-lineno">827</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">docindex</tt> <tt class="py-keyword">is</tt> <tt class="py-keyword">not</tt> <tt class="py-name">None</tt> <tt class="py-keyword">and</tt> </tt> <a name="L828"></a><tt class="py-lineno">828</tt> <tt class="py-line"> <tt class="py-name">isinstance</tt><tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">docindex</tt><tt class="py-op">.</tt><tt id="link-132" class="py-name"><a title="epydoc.apidoc.DocIndex.container epydoc.apidoc.DottedName.container epydoc.apidoc.VariableDoc.container" class="py-name" href="#" onclick="return doclink('link-132', 'container', 'link-73');">container</a></tt><tt class="py-op">(</tt><tt class="py-name">doc</tt><tt class="py-op">)</tt><tt class="py-op">,</tt> <tt id="link-133" class="py-name"><a title="epydoc.apidoc.ClassDoc" class="py-name" href="#" onclick="return doclink('link-133', 'ClassDoc', 'link-128');">ClassDoc</a></tt><tt class="py-op">)</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> <a name="L829"></a><tt class="py-lineno">829</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-string">'Method'</tt> </tt> <a name="L830"></a><tt class="py-lineno">830</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt> <a name="L831"></a><tt class="py-lineno">831</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-string">'Function'</tt> </tt> <a name="L832"></a><tt class="py-lineno">832</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt> <a name="L833"></a><tt class="py-lineno">833</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-string">'Variable'</tt> </tt> </div><a name="L834"></a><tt class="py-lineno">834</tt> <tt class="py-line"> </tt> <a name="PythonSourceColorizer.mark_def"></a><div id="PythonSourceColorizer.mark_def-def"><a name="L835"></a><tt class="py-lineno">835</tt> <a class="py-toggle" href="#" id="PythonSourceColorizer.mark_def-toggle" onclick="return toggle('PythonSourceColorizer.mark_def');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="epydoc.docwriter.html_colorize.PythonSourceColorizer-class.html#mark_def">mark_def</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">s</tt><tt class="py-op">,</tt> <tt class="py-param">name</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> </div><div id="PythonSourceColorizer.mark_def-collapsed" style="display:none;" pad="+++" indent="++++++++"></div><div id="PythonSourceColorizer.mark_def-expanded"><a name="L836"></a><tt class="py-lineno">836</tt> <tt class="py-line"> <tt class="py-name">replacement</tt> <tt class="py-op">=</tt> <tt class="py-op">(</tt><tt class="py-string">'<a name="%s"></a><div id="%s-def">\\1'</tt> </tt> <a name="L837"></a><tt class="py-lineno">837</tt> <tt class="py-line"> <tt class="py-string">'<a class="py-toggle" href="#" id="%s-toggle" '</tt> </tt> <a name="L838"></a><tt class="py-lineno">838</tt> <tt class="py-line"> <tt class="py-string">'onclick="return toggle(\'%s\');">-</a>\\2'</tt> <tt class="py-op">%</tt> </tt> <a name="L839"></a><tt class="py-lineno">839</tt> <tt class="py-line"> <tt class="py-op">(</tt><tt id="link-134" class="py-name"><a title="epydoc.apidoc.VariableDoc.name" class="py-name" href="#" onclick="return doclink('link-134', 'name', 'link-102');">name</a></tt><tt class="py-op">,</tt> <tt id="link-135" class="py-name"><a title="epydoc.apidoc.VariableDoc.name" class="py-name" href="#" onclick="return doclink('link-135', 'name', 'link-102');">name</a></tt><tt class="py-op">,</tt> <tt id="link-136" class="py-name"><a title="epydoc.apidoc.VariableDoc.name" class="py-name" href="#" onclick="return doclink('link-136', 'name', 'link-102');">name</a></tt><tt class="py-op">,</tt> <tt id="link-137" class="py-name"><a title="epydoc.apidoc.VariableDoc.name" class="py-name" href="#" onclick="return doclink('link-137', 'name', 'link-102');">name</a></tt><tt class="py-op">)</tt><tt class="py-op">)</tt> </tt> <a name="L840"></a><tt class="py-lineno">840</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">re</tt><tt class="py-op">.</tt><tt class="py-name">sub</tt><tt class="py-op">(</tt><tt class="py-string">'(.*) (<tt class="py-line">.*)\Z'</tt><tt class="py-op">,</tt> <tt class="py-name">replacement</tt><tt class="py-op">,</tt> <tt class="py-name">s</tt><tt class="py-op">)</tt> </tt> </div><a name="L841"></a><tt class="py-lineno">841</tt> <tt class="py-line"> </tt> <a name="PythonSourceColorizer.is_docstring"></a><div id="PythonSourceColorizer.is_docstring-def"><a name="L842"></a><tt class="py-lineno">842</tt> <a class="py-toggle" href="#" id="PythonSourceColorizer.is_docstring-toggle" onclick="return toggle('PythonSourceColorizer.is_docstring');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="epydoc.docwriter.html_colorize.PythonSourceColorizer-class.html#is_docstring">is_docstring</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">line</tt><tt class="py-op">,</tt> <tt class="py-param">i</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> </div><div id="PythonSourceColorizer.is_docstring-collapsed" style="display:none;" pad="+++" indent="++++++++"></div><div id="PythonSourceColorizer.is_docstring-expanded"><a name="L843"></a><tt class="py-lineno">843</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">line</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">]</tt><tt class="py-op">[</tt><tt class="py-number">0</tt><tt class="py-op">]</tt> <tt class="py-op">!=</tt> <tt class="py-name">token</tt><tt class="py-op">.</tt><tt class="py-name">STRING</tt><tt class="py-op">:</tt> <tt class="py-keyword">return</tt> <tt class="py-name">False</tt> </tt> <a name="L844"></a><tt class="py-lineno">844</tt> <tt class="py-line"> <tt class="py-keyword">for</tt> <tt class="py-name">toktype</tt><tt class="py-op">,</tt> <tt class="py-name">toktext</tt> <tt class="py-keyword">in</tt> <tt class="py-name">line</tt><tt class="py-op">[</tt><tt class="py-name">i</tt><tt class="py-op">:</tt><tt class="py-op">]</tt><tt class="py-op">:</tt> </tt> <a name="L845"></a><tt class="py-lineno">845</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">toktype</tt> <tt class="py-keyword">not</tt> <tt class="py-keyword">in</tt> <tt class="py-op">(</tt><tt class="py-name">token</tt><tt class="py-op">.</tt><tt class="py-name">NEWLINE</tt><tt class="py-op">,</tt> <tt class="py-name">tokenize</tt><tt class="py-op">.</tt><tt class="py-name">COMMENT</tt><tt class="py-op">,</tt> </tt> <a name="L846"></a><tt class="py-lineno">846</tt> <tt class="py-line"> <tt class="py-name">tokenize</tt><tt class="py-op">.</tt><tt class="py-name">NL</tt><tt class="py-op">,</tt> <tt class="py-name">token</tt><tt class="py-op">.</tt><tt class="py-name">STRING</tt><tt class="py-op">,</tt> <tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> <a name="L847"></a><tt class="py-lineno">847</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">False</tt> </tt> <a name="L848"></a><tt class="py-lineno">848</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">True</tt> </tt> </div><a name="L849"></a><tt class="py-lineno">849</tt> <tt class="py-line"> </tt> <a name="PythonSourceColorizer.add_line_numbers"></a><div id="PythonSourceColorizer.add_line_numbers-def"><a name="L850"></a><tt class="py-lineno">850</tt> <a class="py-toggle" href="#" id="PythonSourceColorizer.add_line_numbers-toggle" onclick="return toggle('PythonSourceColorizer.add_line_numbers');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="epydoc.docwriter.html_colorize.PythonSourceColorizer-class.html#add_line_numbers">add_line_numbers</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">s</tt><tt class="py-op">,</tt> <tt class="py-param">css_class</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> </div><div id="PythonSourceColorizer.add_line_numbers-collapsed" style="display:none;" pad="+++" indent="++++++++"></div><div id="PythonSourceColorizer.add_line_numbers-expanded"><a name="L851"></a><tt class="py-lineno">851</tt> <tt class="py-line"> <tt class="py-name">result</tt> <tt class="py-op">=</tt> <tt class="py-string">''</tt> </tt> <a name="L852"></a><tt class="py-lineno">852</tt> <tt class="py-line"> <tt class="py-name">start</tt> <tt class="py-op">=</tt> <tt class="py-number">0</tt> </tt> <a name="L853"></a><tt class="py-lineno">853</tt> <tt class="py-line"> <tt class="py-name">end</tt> <tt class="py-op">=</tt> <tt class="py-name">s</tt><tt class="py-op">.</tt><tt id="link-138" class="py-name"><a title="epydoc.apidoc.DocIndex.find" class="py-name" href="#" onclick="return doclink('link-138', 'find', 'link-19');">find</a></tt><tt class="py-op">(</tt><tt class="py-string">'\n'</tt><tt class="py-op">)</tt><tt class="py-op">+</tt><tt class="py-number">1</tt> </tt> <a name="L854"></a><tt class="py-lineno">854</tt> <tt class="py-line"> <tt class="py-keyword">while</tt> <tt class="py-name">end</tt><tt class="py-op">:</tt> </tt> <a name="L855"></a><tt class="py-lineno">855</tt> <tt class="py-line"> <tt class="py-name">result</tt> <tt class="py-op">+=</tt> <tt class="py-name">s</tt><tt class="py-op">[</tt><tt class="py-name">start</tt><tt class="py-op">:</tt><tt class="py-name">end</tt><tt class="py-op">-</tt><tt class="py-number">1</tt><tt class="py-op">]</tt> </tt> <a name="L856"></a><tt class="py-lineno">856</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">css_class</tt><tt class="py-op">:</tt> <tt class="py-name">result</tt> <tt class="py-op">+=</tt> <tt class="py-string">'</tt>'</tt> </tt> <a name="L857"></a><tt class="py-lineno">857</tt> <tt class="py-line"> <tt class="py-name">result</tt> <tt class="py-op">+=</tt> <tt class="py-string">' </tt>'</tt> <tt class="py-comment"># py-line</tt> </tt> <a name="L858"></a><tt class="py-lineno">858</tt> <tt class="py-line"> <tt class="py-name">result</tt> <tt class="py-op">+=</tt> <tt class="py-string">'\n'</tt> </tt> <a name="L859"></a><tt class="py-lineno">859</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-139" class="py-name"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.ADD_LINE_NUMBERS" class="py-name" href="#" onclick="return doclink('link-139', 'ADD_LINE_NUMBERS', 'link-14');">ADD_LINE_NUMBERS</a></tt><tt class="py-op">:</tt> </tt> <a name="L860"></a><tt class="py-lineno">860</tt> <tt class="py-line"> <tt class="py-name">result</tt> <tt class="py-op">+=</tt> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-140" class="py-name"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.lineno_to_html" class="py-name" href="#" onclick="return doclink('link-140', 'lineno_to_html', 'link-47');">lineno_to_html</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> <a name="L861"></a><tt class="py-lineno">861</tt> <tt class="py-line"> <tt class="py-name">result</tt> <tt class="py-op">+=</tt> <tt class="py-string">' <tt class="py-line">'</tt> </tt> <a name="L862"></a><tt class="py-lineno">862</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">css_class</tt><tt class="py-op">:</tt> <tt class="py-name">result</tt> <tt class="py-op">+=</tt> <tt class="py-string">'<tt class="%s">'</tt> <tt class="py-op">%</tt> <tt class="py-name">css_class</tt> </tt> <a name="L863"></a><tt class="py-lineno">863</tt> <tt class="py-line"> <tt class="py-name">start</tt> <tt class="py-op">=</tt> <tt class="py-name">end</tt> </tt> <a name="L864"></a><tt class="py-lineno">864</tt> <tt class="py-line"> <tt class="py-name">end</tt> <tt class="py-op">=</tt> <tt class="py-name">s</tt><tt class="py-op">.</tt><tt id="link-141" class="py-name"><a title="epydoc.apidoc.DocIndex.find" class="py-name" href="#" onclick="return doclink('link-141', 'find', 'link-19');">find</a></tt><tt class="py-op">(</tt><tt class="py-string">'\n'</tt><tt class="py-op">,</tt> <tt class="py-name">end</tt><tt class="py-op">)</tt><tt class="py-op">+</tt><tt class="py-number">1</tt> </tt> <a name="L865"></a><tt class="py-lineno">865</tt> <tt class="py-line"> <tt class="py-name">self</tt><tt class="py-op">.</tt><tt id="link-142" class="py-name"><a title="epydoc.apidoc.RoutineDoc.lineno" class="py-name" href="#" onclick="return doclink('link-142', 'lineno', 'link-18');">lineno</a></tt> <tt class="py-op">+=</tt> <tt class="py-number">1</tt> </tt> <a name="L866"></a><tt class="py-lineno">866</tt> <tt class="py-line"> <tt class="py-name">result</tt> <tt class="py-op">+=</tt> <tt class="py-name">s</tt><tt class="py-op">[</tt><tt class="py-name">start</tt><tt class="py-op">:</tt><tt class="py-op">]</tt> </tt> <a name="L867"></a><tt class="py-lineno">867</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-name">result</tt> </tt> </div><a name="L868"></a><tt class="py-lineno">868</tt> <tt class="py-line"> </tt> <a name="PythonSourceColorizer.name2url"></a><div id="PythonSourceColorizer.name2url-def"><a name="L869"></a><tt class="py-lineno">869</tt> <a class="py-toggle" href="#" id="PythonSourceColorizer.name2url-toggle" onclick="return toggle('PythonSourceColorizer.name2url');">-</a><tt class="py-line"> <tt class="py-keyword">def</tt> <a class="py-def-name" href="epydoc.docwriter.html_colorize.PythonSourceColorizer-class.html#name2url">name2url</a><tt class="py-op">(</tt><tt class="py-param">self</tt><tt class="py-op">,</tt> <tt class="py-param">class_name</tt><tt class="py-op">,</tt> <tt class="py-param">func_name</tt><tt class="py-op">=</tt><tt class="py-name">None</tt><tt class="py-op">)</tt><tt class="py-op">:</tt> </tt> </div><div id="PythonSourceColorizer.name2url-collapsed" style="display:none;" pad="+++" indent="++++++++"></div><div id="PythonSourceColorizer.name2url-expanded"><a name="L870"></a><tt class="py-lineno">870</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">class_name</tt><tt class="py-op">:</tt> </tt> <a name="L871"></a><tt class="py-lineno">871</tt> <tt class="py-line"> <tt class="py-name">class_name</tt> <tt class="py-op">=</tt> <tt class="py-string">'%s.%s'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">module_name</tt><tt class="py-op">,</tt> <tt class="py-name">class_name</tt><tt class="py-op">)</tt> </tt> <a name="L872"></a><tt class="py-lineno">872</tt> <tt class="py-line"> <tt class="py-keyword">if</tt> <tt class="py-name">func_name</tt><tt class="py-op">:</tt> </tt> <a name="L873"></a><tt class="py-lineno">873</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-string">'%s-class.html#%s'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">class_name</tt><tt class="py-op">,</tt> <tt class="py-name">func_name</tt><tt class="py-op">)</tt> </tt> <a name="L874"></a><tt class="py-lineno">874</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt> <a name="L875"></a><tt class="py-lineno">875</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-string">'%s-class.html'</tt> <tt class="py-op">%</tt> <tt class="py-name">class_name</tt> </tt> <a name="L876"></a><tt class="py-lineno">876</tt> <tt class="py-line"> <tt class="py-keyword">else</tt><tt class="py-op">:</tt> </tt> <a name="L877"></a><tt class="py-lineno">877</tt> <tt class="py-line"> <tt class="py-keyword">return</tt> <tt class="py-string">'%s-module.html#%s'</tt> <tt class="py-op">%</tt> <tt class="py-op">(</tt><tt class="py-name">self</tt><tt class="py-op">.</tt><tt class="py-name">module_name</tt><tt class="py-op">,</tt> <tt class="py-name">func_name</tt><tt class="py-op">)</tt> </tt> </div><a name="L878"></a><tt class="py-lineno">878</tt> <tt class="py-line"> </tt> <a name="L879"></a><tt class="py-lineno">879</tt> <tt class="py-line"> <tt class="py-comment">#: A regexp used to move the <div> that marks the beginning of a</tt> </tt> <a name="L880"></a><tt class="py-lineno">880</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-comment">#: function or method to just before the decorators.</tt> </tt> <a name="L881"></a><tt class="py-lineno">881</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt id="link-143" class="py-name"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer._FIX_DECORATOR_RE" class="py-name" href="#" onclick="return doclink('link-143', '_FIX_DECORATOR_RE', 'link-32');">_FIX_DECORATOR_RE</a></tt> <tt class="py-op">=</tt> <tt class="py-name">re</tt><tt class="py-op">.</tt><tt class="py-name">compile</tt><tt class="py-op">(</tt> </tt> <a name="L882"></a><tt class="py-lineno">882</tt> <tt class="py-line"> <tt class="py-string">r'((?:^<a name="L\d+"></a><tt class="py-lineno">\s*\d+</tt>'</tt> </tt> <a name="L883"></a><tt class="py-lineno">883</tt> <tt class="py-line"> <tt class="py-string">r'\s*<tt class="py-line">(?:<tt class="py-decorator">.*|\s*</tt>|'</tt> </tt> <a name="L884"></a><tt class="py-lineno">884</tt> <tt class="py-line"> <tt class="py-string">r'\s*<tt class="py-comment">.*)\n)+)'</tt> </tt> <a name="L885"></a><tt class="py-lineno">885</tt> <tt class="py-line"> <tt class="py-string">r'(<a name="\w+"></a><div id="\w+-def">)'</tt><tt class="py-op">,</tt> <tt class="py-name">re</tt><tt class="py-op">.</tt><tt class="py-name">MULTILINE</tt><tt class="py-op">)</tt> </tt> </div><a name="L886"></a><tt class="py-lineno">886</tt> <tt class="py-line"> </tt> <a name="L887"></a><tt class="py-lineno">887</tt> <tt class="py-line"><tt id="link-144" class="py-name" targets="Variable epydoc.docwriter.html_colorize._HDR=epydoc.docwriter.html_colorize-module.html#_HDR"><a title="epydoc.docwriter.html_colorize._HDR" class="py-name" href="#" onclick="return doclink('link-144', '_HDR', 'link-144');">_HDR</a></tt> <tt class="py-op">=</tt> <tt class="py-string">'''\</tt> </tt> <a name="L888"></a><tt class="py-lineno">888</tt> <tt class="py-line"><tt class="py-string"><?xml version="1.0" encoding="ascii"?></tt> </tt> <a name="L889"></a><tt class="py-lineno">889</tt> <tt class="py-line"><tt class="py-string"> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"</tt> </tt> <a name="L890"></a><tt class="py-lineno">890</tt> <tt class="py-line"><tt class="py-string"> "DTD/xhtml1-transitional.dtd"></tt> </tt> <a name="L891"></a><tt class="py-lineno">891</tt> <tt class="py-line"><tt class="py-string"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en"></tt> </tt> <a name="L892"></a><tt class="py-lineno">892</tt> <tt class="py-line"><tt class="py-string"> <head></tt> </tt> <a name="L893"></a><tt class="py-lineno">893</tt> <tt class="py-line"><tt class="py-string"> <title>$title$</title></tt> </tt> <a name="L894"></a><tt class="py-lineno">894</tt> <tt class="py-line"><tt class="py-string"> <link rel="stylesheet" href="epydoc.css" type="text/css" /></tt> </tt> <a name="L895"></a><tt class="py-lineno">895</tt> <tt class="py-line"><tt class="py-string"> <script type="text/javascript" src="epydoc.js"></script></tt> </tt> <a name="L896"></a><tt class="py-lineno">896</tt> <tt class="py-line"><tt class="py-string"> </head></tt> </tt> <a name="L897"></a><tt class="py-lineno">897</tt> <tt class="py-line"><tt class="py-string"> </tt> </tt> <a name="L898"></a><tt class="py-lineno">898</tt> <tt class="py-line"><tt class="py-string"> <body bgcolor="white" text="black" link="blue" vlink="#204080"</tt> </tt> <a name="L899"></a><tt class="py-lineno">899</tt> <tt class="py-line"><tt class="py-string"> alink="#204080"></tt> </tt> <a name="L900"></a><tt class="py-lineno">900</tt> <tt class="py-line"><tt class="py-string">'''</tt> </tt> <a name="L901"></a><tt class="py-lineno">901</tt> <tt class="py-line"><tt id="link-145" class="py-name" targets="Variable epydoc.docwriter.html_colorize._FOOT=epydoc.docwriter.html_colorize-module.html#_FOOT"><a title="epydoc.docwriter.html_colorize._FOOT" class="py-name" href="#" onclick="return doclink('link-145', '_FOOT', 'link-145');">_FOOT</a></tt> <tt class="py-op">=</tt> <tt class="py-string">'</body></html>'</tt> </tt> <a name="L902"></a><tt class="py-lineno">902</tt> <tt class="py-line"><tt class="py-keyword">if</tt> <tt class="py-name">__name__</tt><tt class="py-op">==</tt><tt class="py-string">'__main__'</tt><tt class="py-op">:</tt> </tt> <a name="L903"></a><tt class="py-lineno">903</tt> <tt class="py-line"> <tt class="py-comment">#s = PythonSourceColorizer('../apidoc.py', 'epydoc.apidoc').colorize()</tt> </tt> <a name="L904"></a><tt class="py-lineno">904</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-name">s</tt> <tt class="py-op">=</tt> <tt id="link-146" class="py-name" targets="Class epydoc.docwriter.html_colorize.PythonSourceColorizer=epydoc.docwriter.html_colorize.PythonSourceColorizer-class.html"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer" class="py-name" href="#" onclick="return doclink('link-146', 'PythonSourceColorizer', 'link-146');">PythonSourceColorizer</a></tt><tt class="py-op">(</tt><tt class="py-string">'/tmp/fo.py'</tt><tt class="py-op">,</tt> <tt class="py-string">'epydoc.apidoc'</tt><tt class="py-op">)</tt><tt class="py-op">.</tt><tt id="link-147" class="py-name" targets="Method epydoc.docwriter.html_colorize.PythonSourceColorizer.colorize()=epydoc.docwriter.html_colorize.PythonSourceColorizer-class.html#colorize,Method epydoc.markup.pyval_repr.PyvalColorizer.colorize()=epydoc.markup.pyval_repr.PyvalColorizer-class.html#colorize"><a title="epydoc.docwriter.html_colorize.PythonSourceColorizer.colorize epydoc.markup.pyval_repr.PyvalColorizer.colorize" class="py-name" href="#" onclick="return doclink('link-147', 'colorize', 'link-147');">colorize</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> <a name="L905"></a><tt class="py-lineno">905</tt> <tt class="py-line"> <tt class="py-comment">#print s</tt> </tt> <a name="L906"></a><tt class="py-lineno">906</tt> <tt class="py-line"><tt class="py-comment"></tt> <tt class="py-keyword">import</tt> <tt class="py-name">codecs</tt> </tt> <a name="L907"></a><tt class="py-lineno">907</tt> <tt class="py-line"> <tt class="py-name">f</tt> <tt class="py-op">=</tt> <tt class="py-name">codecs</tt><tt class="py-op">.</tt><tt id="link-148" class="py-name"><a title="epydoc.gui.EpydocGUI.open" class="py-name" href="#" onclick="return doclink('link-148', 'open', 'link-24');">open</a></tt><tt class="py-op">(</tt><tt class="py-string">'/home/edloper/public_html/color3.html'</tt><tt class="py-op">,</tt> <tt class="py-string">'w'</tt><tt class="py-op">,</tt> <tt class="py-string">'ascii'</tt><tt class="py-op">,</tt> <tt class="py-string">'xmlcharrefreplace'</tt><tt class="py-op">)</tt> </tt> <a name="L908"></a><tt class="py-lineno">908</tt> <tt class="py-line"> <tt class="py-name">f</tt><tt class="py-op">.</tt><tt id="link-149" class="py-name"><a title="epydoc.docintrospecter._DevNull.write epydoc.docwriter.dotgraph.DotGraph.write epydoc.docwriter.html.HTMLWriter.write epydoc.docwriter.latex.LatexWriter.write epydoc.docwriter.plaintext.PlaintextWriter.write" class="py-name" href="#" onclick="return doclink('link-149', 'write', 'link-27');">write</a></tt><tt class="py-op">(</tt><tt id="link-150" class="py-name"><a title="epydoc.docwriter.html_colorize._HDR" class="py-name" href="#" onclick="return doclink('link-150', '_HDR', 'link-144');">_HDR</a></tt><tt class="py-op">+</tt><tt class="py-string">'<pre id="py-src-top" class="py-src">'</tt><tt class="py-op">+</tt><tt class="py-name">s</tt><tt class="py-op">+</tt><tt class="py-string">'</pre>'</tt><tt class="py-op">+</tt><tt id="link-151" class="py-name"><a title="epydoc.docwriter.html_colorize._FOOT" class="py-name" href="#" onclick="return doclink('link-151', '_FOOT', 'link-145');">_FOOT</a></tt><tt class="py-op">)</tt> </tt> <a name="L909"></a><tt class="py-lineno">909</tt> <tt class="py-line"> <tt class="py-name">f</tt><tt class="py-op">.</tt><tt id="link-152" class="py-name" targets="Method epydoc.cli.HTMLLogger.close()=epydoc.cli.HTMLLogger-class.html#close,Method epydoc.docintrospecter._DevNull.close()=epydoc.docintrospecter._DevNull-class.html#close,Method epydoc.log.Logger.close()=epydoc.log.Logger-class.html#close,Function epydoc.log.close()=epydoc.log-module.html#close"><a title="epydoc.cli.HTMLLogger.close epydoc.docintrospecter._DevNull.close epydoc.log.Logger.close epydoc.log.close" class="py-name" href="#" onclick="return doclink('link-152', 'close', 'link-152');">close</a></tt><tt class="py-op">(</tt><tt class="py-op">)</tt> </tt> <a name="L910"></a><tt class="py-lineno">910</tt> <tt class="py-line"> </tt><script type="text/javascript"> <!-- expandto(location.href); // --> </script> </pre> <br /> <!-- ==================== NAVIGATION BAR ==================== --> <table class="navbar" border="0" width="100%" cellpadding="0" bgcolor="#a0c0ff" cellspacing="0"> <tr valign="middle"> <!-- Home link --> <th> <a href="epydoc-module.html">Home</a> </th> <!-- Tree link --> <th> <a href="module-tree.html">Trees</a> </th> <!-- Index link --> <th> <a href="identifier-index.html">Indices</a> </th> <!-- Help link --> <th> <a href="help.html">Help</a> </th> <!-- Project homepage --> <th class="navbar" align="right" width="100%"> <table border="0" cellpadding="0" cellspacing="0"> <tr><th class="navbar" align="center" ><a class="navbar" target="_top" href="http://epydoc.sourceforge.net">epydoc 3.0.1</a></th> </tr></table></th> </tr> </table> <table border="0" cellpadding="0" cellspacing="0" width="100%%"> <tr> <td align="left" class="footer"> <a href="epydoc-log.html">Generated by Epydoc 3.0.1 on Wed Jan 30 14:09:44 2008</a> </td> <td align="right" class="footer"> <a target="mainFrame" href="http://epydoc.sourceforge.net" >http://epydoc.sourceforge.net</a> </td> </tr> </table> <script type="text/javascript"> <!-- // Private objects are initially displayed (because if // javascript is turned off then we want them to be // visible); but by default, we want to hide them. So hide // them unless we have a cookie that says to show them. checkCookie(); // --> </script> </body> </html>