/jEdit/tags/jedit-4-2-pre8/bsh/Capabilities.java
# · Java · 125 lines · 37 code · 14 blank · 74 comment · 7 complexity · 9878f1eb6b1dad1fcf55e666277e71cd MD5 · raw file
- /*****************************************************************************
- * *
- * This file is part of the BeanShell Java Scripting distribution. *
- * Documentation and updates may be found at http://www.beanshell.org/ *
- * *
- * Sun Public License Notice: *
- * *
- * The contents of this file are subject to the Sun Public License Version *
- * 1.0 (the "License"); you may not use this file except in compliance with *
- * the License. A copy of the License is available at http://www.sun.com *
- * *
- * The Original Code is BeanShell. The Initial Developer of the Original *
- * Code is Pat Niemeyer. Portions created by Pat Niemeyer are Copyright *
- * (C) 2000. All Rights Reserved. *
- * *
- * GNU Public License Notice: *
- * *
- * Alternatively, the contents of this file may be used under the terms of *
- * the GNU Lesser General Public License (the "LGPL"), in which case the *
- * provisions of LGPL are applicable instead of those above. If you wish to *
- * allow use of your version of this file only under the terms of the LGPL *
- * and not to allow others to use your version of this file under the SPL, *
- * indicate your decision by deleting the provisions above and replace *
- * them with the notice and other provisions required by the LGPL. If you *
- * do not delete the provisions above, a recipient may use your version of *
- * this file under either the SPL or the LGPL. *
- * *
- * Patrick Niemeyer (pat@pat.net) *
- * Author of Learning Java, O'Reilly & Associates *
- * http://www.pat.net/~pat/ *
- * *
- *****************************************************************************/
- package bsh;
- import java.util.Hashtable;
- /**
- The map of extended features supported by the runtime in which we live.
- <p>
- This class should be independent of all other bsh classes!
- <p>
- Note that tests for class existence here do *not* use the
- BshClassManager, as it may require other optional class files to be
- loaded.
- */
- public class Capabilities
- {
- private static boolean accessibility = false;
- public static boolean haveSwing() {
- // classExists caches info for us
- return classExists( "javax.swing.JButton" );
- }
- public static boolean canGenerateInterfaces() {
- // classExists caches info for us
- return classExists( "java.lang.reflect.Proxy" );
- }
- /**
- If accessibility is enabled
- determine if the accessibility mechanism exists and if we have
- the optional bsh package to use it.
- Note that even if both are true it does not necessarily mean that we
- have runtime permission to access the fields... Java security has
- a say in it.
- @see bsh.ReflectManager
- */
- public static boolean haveAccessibility()
- {
- // classExists caches the tests for us
- return ( accessibility
- && classExists( "java.lang.reflect.AccessibleObject" )
- && classExists("bsh.reflect.ReflectManagerImpl")
- );
- }
- public static void setAccessibility( boolean b ) { accessibility = b; }
- private static Hashtable classes = new Hashtable();
- /**
- Use direct Class.forName() to test for the existence of a class.
- We should not use BshClassManager here because:
- a) the systems using these tests would probably not load the
- classes through it anyway.
- b) bshclassmanager is heavy and touches other class files.
- this capabilities code must be light enough to be used by any
- system **including the remote applet**.
- */
- public static boolean classExists( String name )
- {
- Object c = classes.get( name );
- if ( c == null ) {
- try {
- /*
- Note: do *not* change this to
- BshClassManager plainClassForName() or equivalent.
- This class must not touch any other bsh classes.
- */
- c = Class.forName( name );
- } catch ( ClassNotFoundException e ) { }
- if ( c != null )
- classes.put(c,"unused");
- }
- return c != null;
- }
- /**
- An attempt was made to use an unavailable capability supported by
- an optional package. The normal operation is to test before attempting
- to use these packages... so this is runtime exception.
- */
- public static class Unavailable extends UtilEvalError
- {
- public Unavailable(String s ){ super(s); }
- }
- }