123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657 |
- #
- # Metrix++, Copyright 2009-2019, Metrix++ Project
- # Link: https://github.com/metrixplusplus/metrixplusplus
- #
- # This file is a part of Metrix++ Tool.
- #
- import mpp.api
- import re
- class Plugin(mpp.api.Plugin,
- mpp.api.IConfigurable,
- mpp.api.Child,
- mpp.api.MetricPluginMixin):
-
- def declare_configuration(self, parser):
- self.parser = parser
- parser.add_option("--std.code.todo.comments", "--sctc",
- action="store_true", default=False,
- help="Enables collection of number of todo/fixme/etc markers in comments [default: %default]")
- parser.add_option("--std.code.todo.strings", "--scts",
- action="store_true", default=False,
- help="Enables collection of number of todo/fixme/etc markers in strings [default: %default]")
- parser.add_option("--std.code.todo.tags", "--sctt", type=str,
- default="TODO,ToDo,FIXME,FixMe,TBD,HACK,XXX",
- help="A list of typical todo markers to search, separated by comma [default: %default]")
-
- def configure(self, options):
- self.is_active_comments = options.__dict__['std.code.todo.comments']
- self.is_active_strings = options.__dict__['std.code.todo.strings']
- self.tags_list = options.__dict__['std.code.todo.tags'].split(',')
- self.tags_list.sort()
- for tag in self.tags_list:
- if re.match(r'''^[A-Za-z0-9_]+$''', tag) == None:
- self.parser.error('option --std.code.todo.tags: tag {0} includes not allowed symbols'.
- format(tag))
- self.pattern_to_search = re.compile(
- r'\b({0})\b'.
- format('|'.join(self.tags_list)))
- def initialize(self):
- self.declare_metric(self.is_active_comments,
- self.Field('comments', int, non_zero=True),
- self.pattern_to_search,
- marker_type_mask=mpp.api.Marker.T.COMMENT,
- region_type_mask=mpp.api.Region.T.ANY)
- self.declare_metric(self.is_active_strings,
- self.Field('strings', int, non_zero=True),
- self.pattern_to_search,
- marker_type_mask=mpp.api.Marker.T.STRING,
- region_type_mask=mpp.api.Region.T.ANY)
-
- super(Plugin, self).initialize(fields=self.get_fields(),
- properties=[self.Property('tags', ','.join(self.tags_list))])
-
- if self.is_active() == True:
- self.subscribe_by_parents_interface(mpp.api.ICode)
|