File: DetailFormatter.py

package info (click to toggle)
synopsis 0.8.0-5
  • links: PTS
  • area: main
  • in suites: etch, etch-m68k
  • size: 10,112 kB
  • ctags: 12,996
  • sloc: cpp: 34,254; ansic: 33,620; python: 10,975; sh: 7,261; xml: 6,369; makefile: 773; asm: 445
file content (47 lines) | stat: -rw-r--r-- 1,522 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
#
# Copyright (C) 2000 Stephen Davies
# Copyright (C) 2000 Stefan Seefeld
# All rights reserved.
# Licensed to the public under the terms of the GNU LGPL (>= 2),
# see the file COPYING for details.
#

from DeclarationFormatter import DeclarationFormatter
from Synopsis.Formatters.HTML.Tags import *

class DetailFormatter(DeclarationFormatter):
   """Provide detail-specific Declaration formatting."""

   col_sep = ' '
   row_sep = '<br/>'
   whole_row = ''

   def format_exceptions(self, oper):
      """Prints out the full exception spec"""

      if len(oper.exceptions()):
         raises = span("keyword", "raises")
         exceptions = []
         for exception in oper.exceptions():
            exceptions.append(self.reference(exception.name()))
         exceptions = span("raises", string.join(exceptions, ", "))
         return '%s (%s)'%(raises, exceptions)
      return ''

   def format_enum(self, enum):

      name = span("keyword", "enum ") + self.label(enum.name())
      start = '<div class="enum">'
      enumors = string.join(map(self.format_enumerator, enum.enumerators()))
      end = "</div>"
      return '%s%s%s%s'%(name, start, enumors, end)

   def format_enumerator(self, enumerator):

      text = self.label(enumerator.name())
      if len(enumerator.value()):
         value = " = " + span("value", enumerator.value())
      else: value = ''
      comments = self.processor.comments.format(self.view, enumerator)
      return '<div class="enumerator">%s%s%s</div>'%(text,value,comments)