weka.core.CheckGOE Maven / Gradle / Ivy
/*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
*/
/*
* CheckGOE.java
* Copyright (C) 2007 University of Waikato, Hamilton, New Zealand
*
*/
package weka.core;
import java.beans.BeanInfo;
import java.beans.Introspector;
import java.beans.PropertyDescriptor;
import java.util.Collections;
import java.util.Enumeration;
import java.util.HashSet;
import java.util.Iterator;
import java.util.Vector;
/**
* Simple command line checking of classes that are editable in the GOE.
*
* Usage:
*
* CheckGOE -W classname -- test options
*
*
* Valid options are:
*
* -D
* Turn on debugging output.
*
* -S
* Silent mode - prints nothing to stdout.
*
* -ignored <comma-separated list of properties>
* Skipped properties.
* (default: capabilities,options)
*
* -W
* Full name of the class analysed.
* eg: weka.classifiers.rules.ZeroR
* (default weka.classifiers.rules.ZeroR)
*
*
* @author FracPete (fracpete at waikato dot ac dot nz)
* @version $Revision: 1.4 $
*/
public class CheckGOE
extends Check {
/** the object to test */
protected Object m_Object = new weka.classifiers.rules.ZeroR();
/** whether the tests were successful */
protected boolean m_Success;
/** properties that are skipped in the checkToolTips method
* @see #checkToolTips() */
protected HashSet m_IgnoredProperties = new HashSet();
/**
* default constructor
*/
public CheckGOE() {
super();
// set default options
try {
setOptions(new String[0]);
}
catch (Exception e) {
e.printStackTrace();
}
}
/**
* Returns an enumeration describing the available options.
*
* @return an enumeration of all the available options.
*/
public Enumeration listOptions() {
Vector result = new Vector();
Enumeration en = super.listOptions();
while (en.hasMoreElements())
result.addElement(en.nextElement());
result.addElement(new Option(
"\tSkipped properties.\n"
+ "\t(default: capabilities,options)",
"ignored", 1, "-ignored "));
result.addElement(new Option(
"\tFull name of the class analysed.\n"
+"\teg: weka.classifiers.rules.ZeroR\n"
+ "\t(default weka.classifiers.rules.ZeroR)",
"W", 1, "-W"));
return result.elements();
}
/**
* Parses a given list of options.
*
* Valid options are:
*
* -D
* Turn on debugging output.
*
* -S
* Silent mode - prints nothing to stdout.
*
* -ignored <comma-separated list of properties>
* Skipped properties.
* (default: capabilities,options)
*
* -W
* Full name of the class analysed.
* eg: weka.classifiers.rules.ZeroR
* (default weka.classifiers.rules.ZeroR)
*
*
* @param options the list of options as an array of strings
* @throws Exception if an option is not supported
*/
public void setOptions(String[] options) throws Exception {
String tmpStr;
super.setOptions(options);
tmpStr = Utils.getOption('W', options);
if (tmpStr.length() == 0)
tmpStr = weka.classifiers.rules.ZeroR.class.getName();
setObject(Utils.forName(Object.class, tmpStr, null));
tmpStr = Utils.getOption("ignored", options);
if (tmpStr.length() == 0)
tmpStr = "capabilities,options";
setIgnoredProperties(tmpStr);
}
/**
* Gets the current settings of the object.
*
* @return an array of strings suitable for passing to setOptions
*/
public String[] getOptions() {
Vector result;
String[] options;
int i;
result = new Vector();
options = super.getOptions();
for (i = 0; i < options.length; i++)
result.add(options[i]);
result.add("-ignored");
result.add(getIgnoredProperties());
if (getObject() != null) {
result.add("-W");
result.add(getObject().getClass().getName());
}
return (String[]) result.toArray(new String[result.size()]);
}
/**
* Set the object to work on..
*
* @param value the object to use.
*/
public void setObject(Object value) {
m_Object = value;
}
/**
* Get the object used in the tests.
*
* @return the object used in the tests.
*/
public Object getObject() {
return m_Object;
}
/**
* Sets the properties to ignore in checkToolTips(). Comma-separated list.
*
* @param value the list of properties
* @see #checkToolTips()
*/
public void setIgnoredProperties(String value) {
String[] props;
int i;
m_IgnoredProperties.clear();
props = value.split(",");
for (i = 0; i < props.length; i++)
m_IgnoredProperties.add(props[i]);
}
/**
* Get the ignored properties used in checkToolTips() as comma-separated
* list (sorted).
*
* @return the ignored properties
* @see #checkToolTips()
*/
public String getIgnoredProperties() {
String result;
Vector list;
Iterator iter;
int i;
list = new Vector();
iter = m_IgnoredProperties.iterator();
while (iter.hasNext())
list.add((String) iter.next());
// sort
if (list.size() > 1)
Collections.sort(list);
result = "";
for (i = 0; i < list.size(); i++) {
if (i > 0)
result += ",";
result += list.get(i);
}
return result;
}
/**
* returns the success of the tests
*
* @return true if the tests were successful
*/
public boolean getSuccess() {
return m_Success;
}
/**
* checks whether the object declares a globalInfo method.
*
* @return true if the test was passed
*/
public boolean checkGlobalInfo() {
boolean result;
Class cls;
print("Global info...");
result = true;
cls = getObject().getClass();
// test for globalInfo method
try {
cls.getMethod("globalInfo", (Class[]) null);
}
catch (Exception e) {
result = false;
}
if (result)
println("yes");
else
println("no");
return result;
}
/**
* checks whether the object declares tip text method for all its
* properties.
*
* @return true if the test was passed
*/
public boolean checkToolTips() {
boolean result;
Class cls;
BeanInfo info;
PropertyDescriptor[] desc;
int i;
Vector missing;
String suffix;
print("Tool tips...");
result = true;
suffix = "TipText";
cls = getObject().getClass();
// get properties
try {
info = Introspector.getBeanInfo(cls, Object.class);
desc = info.getPropertyDescriptors();
}
catch (Exception e) {
e.printStackTrace();
desc = null;
}
// test for TipText methods
if (desc != null) {
missing = new Vector();
for (i = 0; i < desc.length; i++) {
// skip property?
if (m_IgnoredProperties.contains(desc[i].getName()))
continue;
if ((desc[i].getReadMethod() == null) || (desc[i].getWriteMethod() == null))
continue;
try {
cls.getMethod(desc[i].getName() + suffix, (Class[]) null);
}
catch (Exception e) {
result = false;
missing.add(desc[i].getName() + suffix);
}
}
if (result)
println("yes");
else
println("no (missing: " + missing + ")");
}
else {
println("maybe");
}
return result;
}
/**
* Runs some diagnostic tests on the object. Output is
* printed to System.out (if not silent).
*/
public void doTests() {
println("Object: " + m_Object.getClass().getName() + "\n");
println("--> Tests");
m_Success = checkGlobalInfo();
if (m_Success)
m_Success = checkToolTips();
}
/**
* Returns the revision string.
*
* @return the revision
*/
public String getRevision() {
return RevisionUtils.extract("$Revision: 1.4 $");
}
/**
* Main method for using the CheckGOE.
*
* @param args the options to the CheckGOE
*/
public static void main(String[] args) {
CheckGOE check = new CheckGOE();
runCheck(check, args);
if (check.getSuccess())
System.exit(0);
else
System.exit(1);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy