[RFC][IcedTea-Web]: Add Logging of applet exceptions.

Dr Andrew John Hughes ahughes at redhat.com
Tue Jan 11 14:41:57 PST 2011


On 16:19 Tue 11 Jan     , Andrew Su wrote:
> On 01/11/2011 04:00 PM, Dr Andrew John Hughes wrote:
> > On 15:39 Tue 11 Jan     , Andrew Su wrote:
> >>
> >> ----- Original Message -----
> >>> From: "Andrew Su"<asu at redhat.com>
> >>> To: "OpenJDK"<distro-pkg-dev at openjdk.java.net>
> >>> Sent: Tuesday, January 11, 2011 2:19:57 PM
> >>> Subject: [RFC][IcedTea-Web]: Add Logging of applet exceptions.
> >>> Hello,
> >>>
> >>> I have attached a patch which allows exceptions be logged to file if
> >>> the
> >>> option "Enable logging" is set in deployments.property file.
> >>>
> >>> Comments? Questions? Concerns?
> >> Hi,
> >>
> >> I have updated the patch (removed unused import).
> >>
> >> Cheers,
> >>   Andrew
> > As Log and AppletLogger should never have instances (as far as I can tell), you
> > should add a private no-argument constructor to prevent them being created.
> > Also, it would be nice to break the long line in Log (the getName() one) onto
> > two lines.
> > Other than that, looks good.
> Hi Andrew,
> 
> I have made the above changes, but making constructor for Log private 
> needs me to make a different constructor for AppletLogger so instead I 
> used no modifier for the constructor which is only accessible from the 
> same package. (However used private for AppletLogger's constructor.)
> 

Ah yes, that's because the subclass constructor will implicitly call super().
Looks fine.

> Ok for head?
> 
> Cheers,
>    Andrew

> diff -r dc02a605f905 ChangeLog
> --- a/ChangeLog	Fri Jan 07 08:00:08 2011 -0500
> +++ b/ChangeLog	Tue Jan 11 16:16:20 2011 -0500
> @@ -1,3 +1,13 @@
> +2011-01-11  Andrew Su  <asu at redhat.com>
> +
> +	* makefile.am: Added net.sourceforge.jnlp.config to NETX_PKGS
> +	variable.
> +	* netx/net/sourceforge/jnlp/NetxPanel.java:
> +	(showAppletException): Override, adds logging to file. Then proceed
> +	with showAppletException in sun.applet.AppletPanel
> +	* netx/net/sourceforge/jnlp/debug/AppletLogger.java: New class.
> +	* netx/net/sourceforge/jnlp/debug/Log.java: New class.
> +
>  2011-01-04  Omair Majid  <omajid at redhat.com>
>  
>  	* netx/net/sourceforge/jnlp/security/KeyStores.java
> diff -r dc02a605f905 Makefile.am
> --- a/Makefile.am	Fri Jan 07 08:00:08 2011 -0500
> +++ b/Makefile.am	Tue Jan 11 16:16:20 2011 -0500
> @@ -29,7 +29,8 @@
>  	net.sourceforge.jnlp.cache net.sourceforge.jnlp.event \
>  	net.sourceforge.jnlp.security net.sourceforge.jnlp.security.viewer \
>  	net.sourceforge.jnlp.services net.sourceforge.jnlp.tools \
> -	net.sourceforge.jnlp.util net.sourceforge.jnlp.controlpanel
> +	net.sourceforge.jnlp.util net.sourceforge.jnlp.controlpanel \
> +	net.sourceforge.jnlp.debug
>  
>  # Conditional defintions
>  if ENABLE_PLUGIN
> diff -r dc02a605f905 netx/net/sourceforge/jnlp/NetxPanel.java
> --- a/netx/net/sourceforge/jnlp/NetxPanel.java	Fri Jan 07 08:00:08 2011 -0500
> +++ b/netx/net/sourceforge/jnlp/NetxPanel.java	Tue Jan 11 16:16:20 2011 -0500
> @@ -22,6 +22,7 @@
>  
>  package net.sourceforge.jnlp;
>  
> +import net.sourceforge.jnlp.debug.AppletLogger;
>  import net.sourceforge.jnlp.runtime.AppThreadGroup;
>  import net.sourceforge.jnlp.runtime.AppletInstance;
>  import net.sourceforge.jnlp.runtime.JNLPRuntime;
> @@ -68,6 +69,12 @@
>          super.run();
>      }
>  
> +    @Override
> +    protected void showAppletException(Throwable t) {
> +        AppletLogger.log(t); // log the exception
> +        super.showAppletException(t);
> +    }
> +    
>      //Overriding to use Netx classloader. You might need to relax visibility
>      //in sun.applet.AppletPanel for runLoader().
>      protected void runLoader() {
> diff -r dc02a605f905 netx/net/sourceforge/jnlp/debug/AppletLogger.java
> --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
> +++ b/netx/net/sourceforge/jnlp/debug/AppletLogger.java	Tue Jan 11 16:16:20 2011 -0500
> @@ -0,0 +1,45 @@
> +package net.sourceforge.jnlp.debug;
> +
> +import java.io.IOException;
> +import java.util.logging.FileHandler;
> +import java.util.logging.Level;
> +import java.util.logging.Logger;
> +import java.util.logging.XMLFormatter;
> +
> +/**
> + * This class writes log information to file.
> + * @author Andrew Su (asu at redhat.com, andrew.su at utoronto.ca)
> + *
> + */
> +public class AppletLogger extends Log {
> +    public static Logger logger;
> +
> +    static {
> +        try {
> +            // If logging is enabled, we create logger.
> +            if (enableLogging) {
> +                String fn = icedteaLogDir + "Plugin" + java.lang.System.currentTimeMillis() + ".log";
> +                boolean append = false;
> +                FileHandler fh = new FileHandler(fn, append);
> +                fh.setFormatter(new XMLFormatter());
> +                String logClassName = AppletLogger.class.getName();
> +                logger = Logger.getLogger(logClassName);
> +                logger.setLevel(Level.ALL);
> +                logger.addHandler(fh);
> +            }
> +        } catch (IOException e) {
> +            e.printStackTrace();
> +        }
> +    }
> +    
> +    private AppletLogger(){}
> +
> +    public synchronized static void log(Throwable e) {
> +        if (enableLogging) {
> +            String ex = e.toString();
> +            for (StackTraceElement ste : e.getStackTrace())
> +                ex = ex + "\n\tat " + ste;
> +            logger.log(Level.FINE, ex);
> +        }
> +    }
> +}
> diff -r dc02a605f905 netx/net/sourceforge/jnlp/debug/Log.java
> --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
> +++ b/netx/net/sourceforge/jnlp/debug/Log.java	Tue Jan 11 16:16:20 2011 -0500
> @@ -0,0 +1,48 @@
> +package net.sourceforge.jnlp.debug;
> +
> +import java.io.File;
> +
> +import javax.naming.ConfigurationException;
> +
> +import net.sourceforge.jnlp.config.DeploymentConfiguration;
> +
> +/**
> + * This file provides the information required to do logging.
> + * @author Andrew Su (asu at redhat.com, andrew.su at utoronto.ca)
> + *
> + */
> +public class Log {
> +
> +    // Directory where the logs are stored.
> +    public static String icedteaLogDir;
> +
> +    public static boolean enableLogging = false;
> +    public static boolean enableTracing = false;
> +
> +    // Prepare for logging.
> +    static {
> +        DeploymentConfiguration config = new DeploymentConfiguration();
> +        try {
> +            config.load();
> +        } catch (ConfigurationException e) {
> +            e.printStackTrace();
> +        }
> +
> +        // Check whether logging and tracing is enabled.
> +        enableLogging = Boolean.parseBoolean(config.getProperty(DeploymentConfiguration.KEY_ENABLE_LOGGING));
> +        enableTracing = Boolean.parseBoolean(config.getProperty(DeploymentConfiguration.KEY_ENABLE_TRACING));
> +
> +        // Get log directory, create it if it doesn't exist. If unable to create and doesn't exist, don't log.
> +        icedteaLogDir = config.getProperty(DeploymentConfiguration.KEY_USER_LOG_DIR);
> +        if (icedteaLogDir != null) {
> +            File f = new File(icedteaLogDir);
> +            if (f.isDirectory() || f.mkdirs())
> +                icedteaLogDir += File.separator;
> +            else
> +                enableLogging = false;
> +        }
> +    }
> +    
> +    Log(){}
> +
> +}


-- 
Andrew :)

Free Java Software Engineer
Red Hat, Inc. (http://www.redhat.com)

Support Free Java!
Contribute to GNU Classpath and IcedTea
http://www.gnu.org/software/classpath
http://icedtea.classpath.org
PGP Key: 94EFD9D8 (http://subkeys.pgp.net)
Fingerprint = F8EF F1EA 401E 2E60 15FA  7927 142C 2591 94EF D9D8



More information about the distro-pkg-dev mailing list