<?xml version="1.0" encoding="iso-8859-1"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" lang="en"> <!-- Source/Synopsis/Formatters/HTML/View.py.html --> <!-- this view was generated by Source --> <head> <meta content="text/html; charset=iso-8859-1" http-equiv="Content-Type"/> <title >Synopsis - Synopsis/Formatters/HTML/View.py</title> <link href="../../../../style.css" type="text/css" rel="stylesheet" /> </head> <body class="Source"> <div class="navigation"> <span class="normal"><a href="../../../../Scopes/Synopsis.html" >Global Package</a></span> <span class="normal"><a href="../../../../InheritanceTree.html" >Inheritance Tree</a></span> <span class="normal"><a href="../../../../InheritanceGraph.html" >Inheritance Graph</a></span> <span class="normal"><a href="../../../../NameIndex.html" >Name Index</a></span> </div> File: <b >Synopsis/Formatters/HTML/View.py</b><pre class="sxr"><a id="line1"></a><span class="lineno"> 1</span><span class="line"><span class="py-comment">#</span></span> <a id="line2"></a><span class="lineno"> 2</span><span class="line"><span class="py-comment"># Copyright (C) 2000 Stephen Davies</span></span> <a id="line3"></a><span class="lineno"> 3</span><span class="line"><span class="py-comment"># Copyright (C) 2000 Stefan Seefeld</span></span> <a id="line4"></a><span class="lineno"> 4</span><span class="line"><span class="py-comment"># All rights reserved.</span></span> <a id="line5"></a><span class="lineno"> 5</span><span class="line"><span class="py-comment"># Licensed to the public under the terms of the GNU LGPL (>= 2),</span></span> <a id="line6"></a><span class="lineno"> 6</span><span class="line"><span class="py-comment"># see the file COPYING for details.</span></span> <a id="line7"></a><span class="lineno"> 7</span><span class="line"><span class="py-comment">#</span></span> <a id="line8"></a><span class="lineno"> 8</span> <a id="line9"></a><span class="lineno"> 9</span><span class="line"><span class="py-string">"""</span></span> <a id="line10"></a><span class="lineno"> 10</span><span class="line"><span class="py-string">View base class, contains base functionality and common interface for all Views.</span></span> <a id="line11"></a><span class="lineno"> 11</span><span class="line"><span class="py-string">"""</span></span> <a id="line12"></a><span class="lineno"> 12</span> <a id="line13"></a><span class="lineno"> 13</span><span class="line"><span class="py-keyword">from</span> Synopsis.Processor <span class="py-keyword">import</span> Parametrized, Parameter</span> <a id="line14"></a><span class="lineno"> 14</span><span class="line"><span class="py-keyword">from</span> Synopsis.Formatters <span class="py-keyword">import</span> open_file</span> <a id="line15"></a><span class="lineno"> 15</span><span class="line"><span class="py-keyword">from</span> Tags <span class="py-keyword">import</span> *</span> <a id="line16"></a><span class="lineno"> 16</span> <a id="line17"></a><span class="lineno"> 17</span><span class="line"><span class="py-keyword">import</span> re, os</span> <a id="line18"></a><span class="lineno"> 18</span> <a id="line19"></a><span class="lineno"> 19</span><span class="line"><span class="py-keyword">class</span> <a href="../../../../Scopes/Synopsis/Formatters/HTML/View/Format.html">Format</a>(Parametrized):</span> <a id="line20"></a><span class="lineno"> 20</span><span class="line"> <span class="py-string">"""Default and base class for formatting a view layout. The Format</span></span> <a id="line21"></a><span class="lineno"> 21</span><span class="line"><span class="py-string"> class basically defines the HTML used at the start and end of the view.</span></span> <a id="line22"></a><span class="lineno"> 22</span><span class="line"><span class="py-string"> The default creates an XHTML compliant header and footer with a proper</span></span> <a id="line23"></a><span class="lineno"> 23</span><span class="line"><span class="py-string"> title, and link to the stylesheet."""</span></span> <a id="line24"></a><span class="lineno"> 24</span> <a id="line25"></a><span class="lineno"> 25</span><span class="line"> <span class="py-keyword">def</span> <a href="../../../../Scopes/Synopsis/Formatters/HTML/View/Format.html#init">init</a>(self, processor, prefix):</span> <a id="line26"></a><span class="lineno"> 26</span> <a id="line27"></a><span class="lineno"> 27</span><span class="line"> self.prefix = prefix</span> <a id="line28"></a><span class="lineno"> 28</span> <a id="line29"></a><span class="lineno"> 29</span><span class="line"> <span class="py-keyword">def</span> <a href="../../../../Scopes/Synopsis/Formatters/HTML/View/Format.html#view_header">view_header</a>(self, os, title, body, headextra, view):</span> <a id="line30"></a><span class="lineno"> 30</span><span class="line"> <span class="py-string">"""Called to output the view header to the given output stream.</span></span> <a id="line31"></a><span class="lineno"> 31</span><span class="line"><span class="py-string"> @param os a file-like object (use os.write())</span></span> <a id="line32"></a><span class="lineno"> 32</span><span class="line"><span class="py-string"> @param title the title of this view</span></span> <a id="line33"></a><span class="lineno"> 33</span><span class="line"><span class="py-string"> @param body the body tag, which may contain extra parameters such as</span></span> <a id="line34"></a><span class="lineno"> 34</span><span class="line"><span class="py-string"> onLoad scripts, and may also be empty eg: for the frames index</span></span> <a id="line35"></a><span class="lineno"> 35</span><span class="line"><span class="py-string"> @param headextra extra html to put in the head section, such as</span></span> <a id="line36"></a><span class="lineno"> 36</span><span class="line"><span class="py-string"> scripts</span></span> <a id="line37"></a><span class="lineno"> 37</span><span class="line"><span class="py-string"> """</span></span> <a id="line38"></a><span class="lineno"> 38</span> <a id="line39"></a><span class="lineno"> 39</span><span class="line"> os.write(<span class="py-string">'<?xml version="1.0" encoding="iso-8859-1"?>\n'</span>)</span> <a id="line40"></a><span class="lineno"> 40</span><span class="line"> os.write(<span class="py-string">'<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"\n'</span>)</span> <a id="line41"></a><span class="lineno"> 41</span><span class="line"> os.write(<span class="py-string">' "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">\n'</span>)</span> <a id="line42"></a><span class="lineno"> 42</span><span class="line"> os.write(<span class="py-string">'<html xmlns="http://www.w3.org/1999/xhtml" lang="en">\n'</span>)</span> <a id="line43"></a><span class="lineno"> 43</span><span class="line"> os.write(<span class="py-string">'<!-- '</span> + view.filename() + <span class="py-string">' -->\n'</span>)</span> <a id="line44"></a><span class="lineno"> 44</span><span class="line"> os.write(<span class="py-string">'<!-- this view was generated by '</span> + view.__class__.__name__ + <span class="py-string">' -->\n'</span>)</span> <a id="line45"></a><span class="lineno"> 45</span><span class="line"> os.write(<span class="py-string">"<head>\n"</span>)</span> <a id="line46"></a><span class="lineno"> 46</span><span class="line"> os.write(<span class="py-string">'<meta content="text/html; charset=iso-8859-1" http-equiv="Content-Type"/>\n'</span>)</span> <a id="line47"></a><span class="lineno"> 47</span><span class="line"> os.write(element(<span class="py-string">'title'</span>,<span class="py-string">'Synopsis - '</span>+ title) + <span class="py-string">'\n'</span>)</span> <a id="line48"></a><span class="lineno"> 48</span><span class="line"> css = self.prefix + <span class="py-string">'style.css'</span></span> <a id="line49"></a><span class="lineno"> 49</span><span class="line"> os.write(element(<span class="py-string">'link'</span>, type=<span class="py-string">'text/css'</span>, rel=<span class="py-string">'stylesheet'</span>, href=css) + <span class="py-string">'\n'</span>)</span> <a id="line50"></a><span class="lineno"> 50</span><span class="line"> os.write(headextra)</span> <a id="line51"></a><span class="lineno"> 51</span><span class="line"> os.write(<span class="py-string">"</head>\n%s\n"</span>%body)</span> <a id="line52"></a><span class="lineno"> 52</span> <a id="line53"></a><span class="lineno"> 53</span><span class="line"> <span class="py-keyword">def</span> <a href="../../../../Scopes/Synopsis/Formatters/HTML/View/Format.html#view_footer">view_footer</a>(self, os, body):</span> <a id="line54"></a><span class="lineno"> 54</span><span class="line"> <span class="py-string">"""Called to output the view footer to the given output stream.</span></span> <a id="line55"></a><span class="lineno"> 55</span><span class="line"><span class="py-string"> @param os a file-like object (use os.write())</span></span> <a id="line56"></a><span class="lineno"> 56</span><span class="line"><span class="py-string"> @param body the close body tag, which may be empty eg: for the frames</span></span> <a id="line57"></a><span class="lineno"> 57</span><span class="line"><span class="py-string"> index</span></span> <a id="line58"></a><span class="lineno"> 58</span><span class="line"><span class="py-string"> """</span></span> <a id="line59"></a><span class="lineno"> 59</span> <a id="line60"></a><span class="lineno"> 60</span><span class="line"> os.write(<span class="py-string">"\n%s\n</html>\n"</span>%body)</span> <a id="line61"></a><span class="lineno"> 61</span> <a id="line62"></a><span class="lineno"> 62</span><span class="line"><span class="py-keyword">class</span> <a href="../../../../Scopes/Synopsis/Formatters/HTML/View/Template.html">Template</a>(Format):</span> <a id="line63"></a><span class="lineno"> 63</span><span class="line"> <span class="py-string">"""Format subclass that uses a template file to define the HTML header</span></span> <a id="line64"></a><span class="lineno"> 64</span><span class="line"><span class="py-string"> and footer for each view."""</span></span> <a id="line65"></a><span class="lineno"> 65</span> <a id="line66"></a><span class="lineno"> 66</span><span class="line"> template = Parameter(<span class="py-string">''</span>, <span class="py-string">'the html template file'</span>)</span> <a id="line67"></a><span class="lineno"> 67</span><span class="line"> copy_files = Parameter([], <span class="py-string">'a list of files to be copied into the output dir'</span>)</span> <a id="line68"></a><span class="lineno"> 68</span> <a id="line69"></a><span class="lineno"> 69</span><span class="line"> <span class="py-keyword">def</span> <a href="../../../../Scopes/Synopsis/Formatters/HTML/View/Template.html#init">init</a>(self, processor, prefix):</span> <a id="line70"></a><span class="lineno"> 70</span> <a id="line71"></a><span class="lineno"> 71</span><span class="line"> Format.init(self, processor, prefix)</span> <a id="line72"></a><span class="lineno"> 72</span><span class="line"> self.__re_body = re.compile(<span class="py-string">'<body(?P<params>([ \t\n]+[-a-zA-Z0-9]+=("[^"]*"|\'[^\']*\'|[^ \t\n>]*))*)>'</span>, re.I)</span> <a id="line73"></a><span class="lineno"> 73</span><span class="line"> self.__re_closebody = re.compile(<span class="py-string">'</body>'</span>, re.I)</span> <a id="line74"></a><span class="lineno"> 74</span><span class="line"> self.__re_closehead = re.compile(<span class="py-string">'</head>'</span>, re.I)</span> <a id="line75"></a><span class="lineno"> 75</span><span class="line"> self.__title_tag = <span class="py-string">'@TITLE@'</span></span> <a id="line76"></a><span class="lineno"> 76</span><span class="line"> self.__content_tag = <span class="py-string">'@CONTENT@'</span></span> <a id="line77"></a><span class="lineno"> 77</span><span class="line"> <span class="py-keyword">for</span> file <span class="py-keyword">in</span> self.copy_files:</span> <a id="line78"></a><span class="lineno"> 78</span><span class="line"> processor.file_layout.copy_file(file, file)</span> <a id="line79"></a><span class="lineno"> 79</span><span class="line"> self.load_file()</span> <a id="line80"></a><span class="lineno"> 80</span> <a id="line81"></a><span class="lineno"> 81</span><span class="line"> <span class="py-keyword">def</span> <a href="../../../../Scopes/Synopsis/Formatters/HTML/View/Template.html#load_file">load_file</a>(self):</span> <a id="line82"></a><span class="lineno"> 82</span><span class="line"> <span class="py-string">"""Loads and parses the template file"""</span></span> <a id="line83"></a><span class="lineno"> 83</span> <a id="line84"></a><span class="lineno"> 84</span><span class="line"> f = open(self.template, <span class="py-string">'rt'</span>)</span> <a id="line85"></a><span class="lineno"> 85</span><span class="line"> text = f.read(1024*64) <span class="py-comment"># arbitrary max limit of 64kb</span></span> <a id="line86"></a><span class="lineno"> 86</span><span class="line"> f.close()</span> <a id="line87"></a><span class="lineno"> 87</span><span class="line"> <span class="py-comment"># Find the content tag</span></span> <a id="line88"></a><span class="lineno"> 88</span><span class="line"> content_index = text.find(self.__content_tag)</span> <a id="line89"></a><span class="lineno"> 89</span><span class="line"> <span class="py-keyword">if</span> content_index == -1:</span> <a id="line90"></a><span class="lineno"> 90</span><span class="line"> <span class="py-keyword">print</span> <span class="py-string">"Fatal: content tag '%s' not found in template file!"</span>%self.__content_tag</span> <a id="line91"></a><span class="lineno"> 91</span><span class="line"> <span class="py-keyword">raise</span> SystemError, <span class="py-string">"Content tag not found"</span></span> <a id="line92"></a><span class="lineno"> 92</span><span class="line"> header = text[:content_index]</span> <a id="line93"></a><span class="lineno"> 93</span><span class="line"> <span class="py-comment"># Find the title (doesn't matter if not found)</span></span> <a id="line94"></a><span class="lineno"> 94</span><span class="line"> self.__title_index = text.find(self.__title_tag)</span> <a id="line95"></a><span class="lineno"> 95</span><span class="line"> <span class="py-keyword">if</span> self.__title_index != -1:</span> <a id="line96"></a><span class="lineno"> 96</span><span class="line"> <span class="py-comment"># Remove the title tag</span></span> <a id="line97"></a><span class="lineno"> 97</span><span class="line"> header = header[:self.__title_index] +header[self.__title_index+len(self.__title_tag):]</span> <a id="line98"></a><span class="lineno"> 98</span><span class="line"> <span class="py-comment"># Find the close head tag</span></span> <a id="line99"></a><span class="lineno"> 99</span><span class="line"> mo = self.__re_closehead.search(header)</span> <a id="line100"></a><span class="lineno">100</span><span class="line"> <span class="py-keyword">if</span> mo: self.__headextra_index = mo.start()</span> <a id="line101"></a><span class="lineno">101</span><span class="line"> <span class="py-keyword">else</span>: self.__headextra_index = -1</span> <a id="line102"></a><span class="lineno">102</span><span class="line"> <span class="py-comment"># Find the body tag</span></span> <a id="line103"></a><span class="lineno">103</span><span class="line"> mo = self.__re_body.search(header)</span> <a id="line104"></a><span class="lineno">104</span><span class="line"> <span class="py-keyword">if</span> <span class="py-keyword">not</span> mo:</span> <a id="line105"></a><span class="lineno">105</span><span class="line"> <span class="py-keyword">print</span> <span class="py-string">"Fatal: body tag not found in template file!"</span></span> <a id="line106"></a><span class="lineno">106</span><span class="line"> <span class="py-keyword">print</span> <span class="py-string">"(if you are sure there is one, this may be a bug in Synopsis)"</span></span> <a id="line107"></a><span class="lineno">107</span><span class="line"> <span class="py-keyword">raise</span> SystemError, <span class="py-string">"Body tag not found"</span></span> <a id="line108"></a><span class="lineno">108</span><span class="line"> <span class="py-keyword">if</span> mo.group(<span class="py-string">'params'</span>): self.__body_params = mo.group(<span class="py-string">'params'</span>)</span> <a id="line109"></a><span class="lineno">109</span><span class="line"> <span class="py-keyword">else</span>: self.__body_params = <span class="py-string">''</span></span> <a id="line110"></a><span class="lineno">110</span><span class="line"> self.__body_index = mo.start()</span> <a id="line111"></a><span class="lineno">111</span><span class="line"> header = header[:mo.start()] + header[mo.end():]</span> <a id="line112"></a><span class="lineno">112</span><span class="line"> <span class="py-comment"># Store the header</span></span> <a id="line113"></a><span class="lineno">113</span><span class="line"> self.__header = header</span> <a id="line114"></a><span class="lineno">114</span><span class="line"> footer = text[content_index+len(self.__content_tag):]</span> <a id="line115"></a><span class="lineno">115</span><span class="line"> <span class="py-comment"># Find the close body tag</span></span> <a id="line116"></a><span class="lineno">116</span><span class="line"> mo = self.__re_closebody.search(footer)</span> <a id="line117"></a><span class="lineno">117</span><span class="line"> <span class="py-keyword">if</span> <span class="py-keyword">not</span> mo:</span> <a id="line118"></a><span class="lineno">118</span><span class="line"> <span class="py-keyword">print</span> <span class="py-string">"Fatal: close body tag not found in template file"</span></span> <a id="line119"></a><span class="lineno">119</span><span class="line"> <span class="py-keyword">raise</span> SystemError, <span class="py-string">"Close body tag not found"</span></span> <a id="line120"></a><span class="lineno">120</span><span class="line"> self.__closebody_index = mo.start()</span> <a id="line121"></a><span class="lineno">121</span><span class="line"> footer = footer[:mo.start()] + footer[mo.end():]</span> <a id="line122"></a><span class="lineno">122</span><span class="line"> self.__footer = footer</span> <a id="line123"></a><span class="lineno">123</span> <a id="line124"></a><span class="lineno">124</span><span class="line"> <span class="py-keyword">def</span> <a href="../../../../Scopes/Synopsis/Formatters/HTML/View/Template.html#write">write</a>(self, os, text):</span> <a id="line125"></a><span class="lineno">125</span><span class="line"> <span class="py-string">"""Writes the text to the output stream, replaceing @PREFIX@ with the</span></span> <a id="line126"></a><span class="lineno">126</span><span class="line"><span class="py-string"> prefix for this file"""</span></span> <a id="line127"></a><span class="lineno">127</span> <a id="line128"></a><span class="lineno">128</span><span class="line"> sections = text.split(<span class="py-string">'@PREFIX@'</span>)</span> <a id="line129"></a><span class="lineno">129</span><span class="line"> os.write(self.prefix.join(sections))</span> <a id="line130"></a><span class="lineno">130</span> <a id="line131"></a><span class="lineno">131</span><span class="line"> <span class="py-keyword">def</span> <a href="../../../../Scopes/Synopsis/Formatters/HTML/View/Template.html#view_header">view_header</a>(self, os, title, body, headextra, view):</span> <a id="line132"></a><span class="lineno">132</span><span class="line"> <span class="py-string">"""Formats the header using the template file"""</span></span> <a id="line133"></a><span class="lineno">133</span> <a id="line134"></a><span class="lineno">134</span><span class="line"> <span class="py-keyword">if</span> <span class="py-keyword">not</span> body: <span class="py-keyword">return</span> Format.view_header(self, os, title, body, headextra)</span> <a id="line135"></a><span class="lineno">135</span><span class="line"> header = self.__header</span> <a id="line136"></a><span class="lineno">136</span><span class="line"> index = 0</span> <a id="line137"></a><span class="lineno">137</span><span class="line"> <span class="py-keyword">if</span> self.__title_index != -1:</span> <a id="line138"></a><span class="lineno">138</span><span class="line"> self.write(os, header[:self.__title_index])</span> <a id="line139"></a><span class="lineno">139</span><span class="line"> self.write(os, title)</span> <a id="line140"></a><span class="lineno">140</span><span class="line"> index = self.__title_index</span> <a id="line141"></a><span class="lineno">141</span><span class="line"> <span class="py-keyword">if</span> self.__headextra_index != -1:</span> <a id="line142"></a><span class="lineno">142</span><span class="line"> self.write(os, header[index:self.__headextra_index])</span> <a id="line143"></a><span class="lineno">143</span><span class="line"> self.write(os, headextra)</span> <a id="line144"></a><span class="lineno">144</span><span class="line"> index = self.__headextra_index</span> <a id="line145"></a><span class="lineno">145</span><span class="line"> self.write(os, header[index:self.__body_index])</span> <a id="line146"></a><span class="lineno">146</span><span class="line"> <span class="py-keyword">if</span> body:</span> <a id="line147"></a><span class="lineno">147</span><span class="line"> <span class="py-keyword">if</span> body[-1] == <span class="py-string">'>'</span>:</span> <a id="line148"></a><span class="lineno">148</span><span class="line"> self.write(os, body[:-1]+self.__body_params+body[-1])</span> <a id="line149"></a><span class="lineno">149</span><span class="line"> <span class="py-keyword">else</span>:</span> <a id="line150"></a><span class="lineno">150</span><span class="line"> <span class="py-comment"># Hmmmm... Should not happen, perhaps use regex?</span></span> <a id="line151"></a><span class="lineno">151</span><span class="line"> self.write(os, body)</span> <a id="line152"></a><span class="lineno">152</span><span class="line"> self.write(os, header[self.__body_index:])</span> <a id="line153"></a><span class="lineno">153</span> <a id="line154"></a><span class="lineno">154</span><span class="line"> <span class="py-keyword">def</span> <a href="../../../../Scopes/Synopsis/Formatters/HTML/View/Template.html#view_footer">view_footer</a>(self, os, body):</span> <a id="line155"></a><span class="lineno">155</span><span class="line"> <span class="py-string">"""Formats the footer using the template file"""</span></span> <a id="line156"></a><span class="lineno">156</span> <a id="line157"></a><span class="lineno">157</span><span class="line"> <span class="py-keyword">if</span> <span class="py-keyword">not</span> body: <span class="py-keyword">return</span> Format.view_footer(self, os, body)</span> <a id="line158"></a><span class="lineno">158</span><span class="line"> footer = self.__footer</span> <a id="line159"></a><span class="lineno">159</span><span class="line"> self.write(os, footer[:self.__closebody_index])</span> <a id="line160"></a><span class="lineno">160</span><span class="line"> self.write(os, body)</span> <a id="line161"></a><span class="lineno">161</span><span class="line"> self.write(os, footer[self.__closebody_index:])</span> <a id="line162"></a><span class="lineno">162</span> <a id="line163"></a><span class="lineno">163</span><span class="line"><span class="py-keyword">class</span> <a href="../../../../Scopes/Synopsis/Formatters/HTML/View/View.html">View</a>(Parametrized):</span> <a id="line164"></a><span class="lineno">164</span><span class="line"> <span class="py-string">"""Base class for Views. The base class provides a common interface, and</span></span> <a id="line165"></a><span class="lineno">165</span><span class="line"><span class="py-string"> also handles common operations such as opening the file, and delegating</span></span> <a id="line166"></a><span class="lineno">166</span><span class="line"><span class="py-string"> the view formatting to a strategy class."""</span></span> <a id="line167"></a><span class="lineno">167</span> <a id="line168"></a><span class="lineno">168</span><span class="line"> template = Parameter(Format(), <span class="py-string">'the object that provides the html template for the view'</span>)</span> <a id="line169"></a><span class="lineno">169</span> <a id="line170"></a><span class="lineno">170</span><span class="line"> <span class="py-keyword">def</span> <a href="../../../../Scopes/Synopsis/Formatters/HTML/View/View.html#__init__">__init__</a>(self, **kwds):</span> <a id="line171"></a><span class="lineno">171</span> <a id="line172"></a><span class="lineno">172</span><span class="line"> super(View, self).__init__(**kwds)</span> <a id="line173"></a><span class="lineno">173</span><span class="line"> self.main = False</span> <a id="line174"></a><span class="lineno">174</span> <a id="line175"></a><span class="lineno">175</span><span class="line"> <span class="py-keyword">def</span> <a href="../../../../Scopes/Synopsis/Formatters/HTML/View/View.html#register">register</a>(self, frame):</span> <a id="line176"></a><span class="lineno">176</span><span class="line"> <span class="py-string">"""Registers this View class with its frame."""</span></span> <a id="line177"></a><span class="lineno">177</span> <a id="line178"></a><span class="lineno">178</span><span class="line"> self.frame = frame</span> <a id="line179"></a><span class="lineno">179</span><span class="line"> self.directory_layout = self.frame.processor.directory_layout</span> <a id="line180"></a><span class="lineno">180</span><span class="line"> self.processor = frame.processor</span> <a id="line181"></a><span class="lineno">181</span><span class="line"> self.__os = None</span> <a id="line182"></a><span class="lineno">182</span> <a id="line183"></a><span class="lineno">183</span><span class="line"> <span class="py-keyword">def</span> <a href="../../../../Scopes/Synopsis/Formatters/HTML/View/View.html#filename">filename</a>(self):</span> <a id="line184"></a><span class="lineno">184</span><span class="line"> <span class="py-string">"""Return the filename (currently) associated with the view."""</span></span> <a id="line185"></a><span class="lineno">185</span> <a id="line186"></a><span class="lineno">186</span><span class="line"> <span class="py-keyword">return</span> <span class="py-string">''</span></span> <a id="line187"></a><span class="lineno">187</span> <a id="line188"></a><span class="lineno">188</span><span class="line"> <span class="py-keyword">def</span> <a href="../../../../Scopes/Synopsis/Formatters/HTML/View/View.html#title">title</a>(self):</span> <a id="line189"></a><span class="lineno">189</span><span class="line"> <span class="py-string">"""Return the title (currently) associated with the view."""</span></span> <a id="line190"></a><span class="lineno">190</span> <a id="line191"></a><span class="lineno">191</span><span class="line"> <span class="py-keyword">return</span> <span class="py-string">''</span></span> <a id="line192"></a><span class="lineno">192</span> <a id="line193"></a><span class="lineno">193</span><span class="line"> <span class="py-keyword">def</span> <a href="../../../../Scopes/Synopsis/Formatters/HTML/View/View.html#root">root</a>(self):</span> <a id="line194"></a><span class="lineno">194</span><span class="line"> <span class="py-string">"""Return a pair of (url, label) to link to the entry point of this view."""</span></span> <a id="line195"></a><span class="lineno">195</span> <a id="line196"></a><span class="lineno">196</span><span class="line"> <span class="py-keyword">return</span> None, None</span> <a id="line197"></a><span class="lineno">197</span> <a id="line198"></a><span class="lineno">198</span><span class="line"> <span class="py-keyword">def</span> <a href="../../../../Scopes/Synopsis/Formatters/HTML/View/View.html#write_navigation_bar">write_navigation_bar</a>(self):</span> <a id="line199"></a><span class="lineno">199</span><span class="line"> <span class="py-string">"""Generate a navigation bar for this view."""</span></span> <a id="line200"></a><span class="lineno">200</span> <a id="line201"></a><span class="lineno">201</span><span class="line"> self.write(self.frame.navigation_bar(self) + <span class="py-string">'\n'</span>)</span> <a id="line202"></a><span class="lineno">202</span> <a id="line203"></a><span class="lineno">203</span><span class="line"> <span class="py-keyword">def</span> <a href="../../../../Scopes/Synopsis/Formatters/HTML/View/View.html#os">os</a>(self):</span> <a id="line204"></a><span class="lineno">204</span><span class="line"> <span class="py-string">"Returns the output stream opened with start_file"</span></span> <a id="line205"></a><span class="lineno">205</span> <a id="line206"></a><span class="lineno">206</span><span class="line"> <span class="py-keyword">return</span> self.__os</span> <a id="line207"></a><span class="lineno">207</span> <a id="line208"></a><span class="lineno">208</span><span class="line"> <span class="py-keyword">def</span> <a href="../../../../Scopes/Synopsis/Formatters/HTML/View/View.html#write">write</a>(self, str):</span> <a id="line209"></a><span class="lineno">209</span><span class="line"> <span class="py-string">"""Writes the given string to the currently opened file"""</span></span> <a id="line210"></a><span class="lineno">210</span> <a id="line211"></a><span class="lineno">211</span><span class="line"> self.__os.write(str)</span> <a id="line212"></a><span class="lineno">212</span> <a id="line213"></a><span class="lineno">213</span><span class="line"> <span class="py-keyword">def</span> <a href="../../../../Scopes/Synopsis/Formatters/HTML/View/View.html#register_filenames">register_filenames</a>(self):</span> <a id="line214"></a><span class="lineno">214</span><span class="line"> <span class="py-string">"""Register filenames for each file this View will generate."""</span></span> <a id="line215"></a><span class="lineno">215</span> <a id="line216"></a><span class="lineno">216</span><span class="line"> <span class="py-keyword">pass</span></span> <a id="line217"></a><span class="lineno">217</span> <a id="line218"></a><span class="lineno">218</span><span class="line"> <span class="py-keyword">def</span> <a href="../../../../Scopes/Synopsis/Formatters/HTML/View/View.html#toc">toc</a>(self):</span> <a id="line219"></a><span class="lineno">219</span><span class="line"> <span class="py-string">"""Retrieves the TOC for this view. This method assumes that the view</span></span> <a id="line220"></a><span class="lineno">220</span><span class="line"><span class="py-string"> generates info for the the whole ASG, which could be the Scope,</span></span> <a id="line221"></a><span class="lineno">221</span><span class="line"><span class="py-string"> the Source (source code) or the XRef (cross reference info).</span></span> <a id="line222"></a><span class="lineno">222</span><span class="line"><span class="py-string"> The default implementation returns None."""</span></span> <a id="line223"></a><span class="lineno">223</span> <a id="line224"></a><span class="lineno">224</span><span class="line"> <span class="py-keyword">pass</span></span> <a id="line225"></a><span class="lineno">225</span> <a id="line226"></a><span class="lineno">226</span><span class="line"> <span class="py-keyword">def</span> <a href="../../../../Scopes/Synopsis/Formatters/HTML/View/View.html#process">process</a>(self):</span> <a id="line227"></a><span class="lineno">227</span><span class="line"> <span class="py-string">"""Process the ASG, creating view-specific html pages."""</span></span> <a id="line228"></a><span class="lineno">228</span> <a id="line229"></a><span class="lineno">229</span><span class="line"> <span class="py-keyword">pass</span></span> <a id="line230"></a><span class="lineno">230</span> <a id="line231"></a><span class="lineno">231</span><span class="line"> <span class="py-keyword">def</span> <a href="../../../../Scopes/Synopsis/Formatters/HTML/View/View.html#open_file">open_file</a>(self):</span> <a id="line232"></a><span class="lineno">232</span><span class="line"> <span class="py-string">"""Returns a new output stream. This template method is for internal</span></span> <a id="line233"></a><span class="lineno">233</span><span class="line"><span class="py-string"> use only, but may be overriden in derived classes.</span></span> <a id="line234"></a><span class="lineno">234</span><span class="line"><span class="py-string"> The default joins output dir and self.filename()"""</span></span> <a id="line235"></a><span class="lineno">235</span> <a id="line236"></a><span class="lineno">236</span><span class="line"> path = os.path.join(self.processor.output, self.filename())</span> <a id="line237"></a><span class="lineno">237</span><span class="line"> <span class="py-keyword">return</span> open_file(path)</span> <a id="line238"></a><span class="lineno">238</span> <a id="line239"></a><span class="lineno">239</span><span class="line"> <span class="py-keyword">def</span> <a href="../../../../Scopes/Synopsis/Formatters/HTML/View/View.html#close_file">close_file</a>(self):</span> <a id="line240"></a><span class="lineno">240</span><span class="line"> <span class="py-string">"""Closes the internal output stream. This template method is for</span></span> <a id="line241"></a><span class="lineno">241</span><span class="line"><span class="py-string"> internal use only, but may be overriden in derived classes."""</span></span> <a id="line242"></a><span class="lineno">242</span> <a id="line243"></a><span class="lineno">243</span><span class="line"> self.__os.close()</span> <a id="line244"></a><span class="lineno">244</span><span class="line"> self.__os = None</span> <a id="line245"></a><span class="lineno">245</span> <a id="line246"></a><span class="lineno">246</span><span class="line"> <span class="py-keyword">def</span> <a href="../../../../Scopes/Synopsis/Formatters/HTML/View/View.html#start_file">start_file</a>(self, body=<span class="py-string">''</span>, headextra=<span class="py-string">''</span>):</span> <a id="line247"></a><span class="lineno">247</span><span class="line"> <span class="py-string">"""Start a new file with given filename, title and body. This method</span></span> <a id="line248"></a><span class="lineno">248</span><span class="line"><span class="py-string"> opens a file for writing, and writes the html header crap at the top.</span></span> <a id="line249"></a><span class="lineno">249</span><span class="line"><span class="py-string"> You must specify a title, which is prepended with the project name.</span></span> <a id="line250"></a><span class="lineno">250</span><span class="line"><span class="py-string"> The body argument is optional, and it is preferred to use stylesheets</span></span> <a id="line251"></a><span class="lineno">251</span><span class="line"><span class="py-string"> for that sort of stuff. You may want to put an onLoad handler in it</span></span> <a id="line252"></a><span class="lineno">252</span><span class="line"><span class="py-string"> though in which case that's the place to do it. The opened file is</span></span> <a id="line253"></a><span class="lineno">253</span><span class="line"><span class="py-string"> stored and can be accessed using the os() method."""</span></span> <a id="line254"></a><span class="lineno">254</span> <a id="line255"></a><span class="lineno">255</span><span class="line"> self.__os = self.open_file()</span> <a id="line256"></a><span class="lineno">256</span><span class="line"> prefix = rel(self.filename(), <span class="py-string">''</span>)</span> <a id="line257"></a><span class="lineno">257</span><span class="line"> self.template.init(self.processor, prefix)</span> <a id="line258"></a><span class="lineno">258</span><span class="line"> <span class="py-keyword">if</span> <span class="py-keyword">not</span> body:</span> <a id="line259"></a><span class="lineno">259</span><span class="line"> body = <span class="py-string">'<body class="%s">'</span>%self.__class__.__name__</span> <a id="line260"></a><span class="lineno">260</span><span class="line"> self.template.view_header(self.__os, self.title(), body, headextra, self)</span> <a id="line261"></a><span class="lineno">261</span> <a id="line262"></a><span class="lineno">262</span><span class="line"> <span class="py-keyword">def</span> <a href="../../../../Scopes/Synopsis/Formatters/HTML/View/View.html#end_file">end_file</a>(self, body=<span class="py-string">'</body>'</span>):</span> <a id="line263"></a><span class="lineno">263</span><span class="line"> <span class="py-string">"""Close the file using given close body tag. The default is</span></span> <a id="line264"></a><span class="lineno">264</span><span class="line"><span class="py-string"> just a close body tag, but if you specify '' then nothing will be</span></span> <a id="line265"></a><span class="lineno">265</span><span class="line"><span class="py-string"> written (useful for a frames view)"""</span></span> <a id="line266"></a><span class="lineno">266</span> <a id="line267"></a><span class="lineno">267</span><span class="line"> self.template.view_footer(self.__os, body)</span> <a id="line268"></a><span class="lineno">268</span><span class="line"> self.close_file()</span> <a id="line269"></a><span class="lineno">269</span> <a id="line270"></a><span class="lineno">270</span><span class="line"> <span class="py-keyword">def</span> <a href="../../../../Scopes/Synopsis/Formatters/HTML/View/View.html#reference">reference</a>(self, name, scope, label=None, **keys):</span> <a id="line271"></a><span class="lineno">271</span><span class="line"> <span class="py-string">"""Returns a reference to the given name. The name is a scoped name,</span></span> <a id="line272"></a><span class="lineno">272</span><span class="line"><span class="py-string"> and the optional label is an alternative name to use as the link text.</span></span> <a id="line273"></a><span class="lineno">273</span><span class="line"><span class="py-string"> The name is looked up in the TOC so the link may not be local. The</span></span> <a id="line274"></a><span class="lineno">274</span><span class="line"><span class="py-string"> optional keys are appended as attributes to the A tag."""</span></span> <a id="line275"></a><span class="lineno">275</span> <a id="line276"></a><span class="lineno">276</span><span class="line"> <span class="py-keyword">if</span> <span class="py-keyword">not</span> label: label = escape(str(scope.prune(name)))</span> <a id="line277"></a><span class="lineno">277</span><span class="line"> entry = self.processor.toc[name]</span> <a id="line278"></a><span class="lineno">278</span><span class="line"> <span class="py-keyword">if</span> entry: <span class="py-keyword">return</span> href(rel(self.filename(), entry.link), label, **keys)</span> <a id="line279"></a><span class="lineno">279</span><span class="line"> <span class="py-keyword">return</span> label <span class="py-keyword">or</span> <span class="py-string">''</span></span> <a id="line280"></a><span class="lineno">280</span> </pre> <div class="logo">Generated on Thu Apr 16 16:27:16 2009 by <br/> <a href="http://synopsis.fresco.org" target="_blank"><img src="../../../../synopsis.png" alt="logo"/> synopsis</a> (version devel)</div> </body> </html>