Skip to content

Extending chkbugreport

space2 edited this page Nov 2, 2012 · 8 revisions

Home

Java plugin

If you have get the source code, you can create your own plugin as well:

  • Create a project in eclipse and add the ChkBugReport project to the java build path

  • Create a subclass of Plugin which implements ExternalPlugin (for example call it FoobarPlugin)

  • Implement initExternalPlugin like this (this will activate your plugin only when processing bugreports and not when processing traceview dumps):

      @Override
      public void initExternalPlugin(Module mod) {
          if (mod instanceof BugReportModule) {
              mod.addPlugin(this);
          }
      }
    
  • implement getPrio to return a number between 0 and 100. This will determine when will your plugin execute compared to other plugins. If you are dependent on data from other plugins, you should have a higher number.

  • implement reset, load and generate (see below for more details)

  • Creating a jar file and add a "ChkBugReport-Plugin" manifest key with your plugin class name as value

  • place the jar file into ~/.chkbugreport-plugins folder.

Executing the plugins are done in 3 steps:

  • first, each plugins reset method is called to reset their internal state
  • then load is called on each plugin to load the raw data into memory, and if possible even do some processing
  • finally generate is called on each plugin to finish processing and generate the report

More details will follow later on, for now use the source as documentation.

XML Plugin

If you just want to plot some values based on some logs, it's much easier to create an xml "plugin". For example save the following xml file as $HOME/.chkbugreport-plugins/example.xml

<plugin name="ExamplePlugin">
    <generate>
        <chapter name="Example/Test 1">
            <text>This is just some example test</text>
            <logchart name="Battery level" file="ex_battery_level">
                <dataset id="level" name="Battery level" type="plot" min="0" max="100" />
                <dataset id="screen" name="Screen on" type="state" colors="#0f0,#ff0,#f00" />
                <dataset id="am" name="ActivityManager" type="event" colors="#080,#f00" />
                <filter log="event" matchLine="battery_level: .(.*),.*,.*\\]" dataset="level" />
                <filter log="event" matchLine="screen_toggled: (.)" dataset="screen" />
                <filter log="event" matchLine="am_proc_start: " dataset="am" value="0" />
                <filter log="event" matchLine="am_proc_died: " dataset="am" value="1" />
            </logchart>
        </chapter>
    </generate>
</plugin>
# ##
Clone this wiki locally