sbsv2/raptor/python/plugins/filter_tagcount.py
author jjkang
Wed, 23 Jun 2010 17:27:59 +0800
changeset 591 22486c9c7b15
permissions -rw-r--r--
raptor v2.14.0
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
591
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
     1
#
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
     2
# Copyright (c) 2008-2009 Nokia Corporation and/or its subsidiary(-ies).
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
     3
# All rights reserved.
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
     4
# This component and the accompanying materials are made available
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
     5
# under the terms of the License "Eclipse Public License v1.0"
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
     6
# which accompanies this distribution, and is available
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
     7
# at the URL "http://www.eclipse.org/legal/epl-v10.html".
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
     8
#
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
     9
# Initial Contributors:
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    10
# Nokia Corporation - initial contribution.
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    11
#
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    12
# Contributors:
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    13
#
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    14
# Description: 
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    15
# Example of a Filter class using the SAX parser base class
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    16
#
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    17
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    18
import filter_interface
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    19
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    20
class FilterTagCounter(filter_interface.FilterSAX):
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    21
	
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    22
	def __init__(self, params = []):
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    23
		"""parameters to this filter are the names of tags to print.
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    24
		
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    25
		If no parameters are passed then all tags are reported."""
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    26
		self.interesting = params
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    27
		super(FilterTagCounter, self).__init__()
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    28
		
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    29
	def startDocument(self):
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    30
		# for each element name count the number of occurences
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    31
		# and the amount of body text contained.
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    32
		self.names = []
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    33
		self.count = {}
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    34
		self.errors = 0
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    35
		self.fatals = 0
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    36
		self.warns = 0
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    37
		
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    38
	def startElement(self, name, attributes):
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    39
		if name == "buildlog":
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    40
			# print out the attributes of the "top" element
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    41
			print "version:"
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    42
			for a,v in attributes.items():
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    43
				print a, "=", v
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    44
		
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    45
		# push name onto the stack of names and increment the count
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    46
		self.names.append(name)
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    47
		if name in self.count:
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    48
			self.count[name][0] += 1
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    49
		else:
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    50
			self.count[name] = [1, 0]    # occurs, characters	
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    51
	
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    52
	def characters(self, char):
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    53
		# these are for the current element
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    54
		current = self.names[-1]
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    55
		self.count[current][1] += len(char)
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    56
		
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    57
	def endElement(self, name):
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    58
		# pop the name off the stack
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    59
		self.names.pop()
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    60
	
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    61
	def endDocument(self):
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    62
		# report
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    63
		print "\nsummary:"
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    64
		for name,nos in sorted(self.count.items()):
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    65
			if name in self.interesting or len(self.interesting) == 0:
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    66
				print name, nos[0], nos[1]
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    67
			
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    68
		print "\nparsing:"
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    69
		print "errors =", self.errors
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    70
		print "fatals =", self.fatals
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    71
		print "warnings =", self.warns
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    72
	
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    73
	def error(self, exception):
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    74
		self.errors += 1
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    75
		
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    76
	def fatalError(self, exception):
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    77
		self.fatals += 1
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    78
		
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    79
	def warning(self, exception):
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    80
		self.warns += 1
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    81
	
22486c9c7b15 raptor v2.14.0
jjkang
parents:
diff changeset
    82
# the end