You are viewing a plain text version of this content. The canonical link for it is here.
Posted to scm@geronimo.apache.org by dj...@apache.org on 2004/02/20 09:11:39 UTC

cvs commit: incubator-geronimo/modules/deployment/src/test/org/apache/geronimo/deployment/tools DDBeanRootTest.java

djencks     2004/02/20 00:11:39

  Modified:    modules/deployment/src/java/org/apache/geronimo/deployment/plugin
                        DConfigBeanSupport.java
               modules/deployment/src/java/org/apache/geronimo/deployment/tools
                        DDBeanRootImpl.java
               modules/deployment/src/test/org/apache/geronimo/deployment/tools
                        DDBeanRootTest.java
  Log:
  some support for explicit namespaces in j2ee dds
  
  Revision  Changes    Path
  1.9       +43 -1     incubator-geronimo/modules/deployment/src/java/org/apache/geronimo/deployment/plugin/DConfigBeanSupport.java
  
  Index: DConfigBeanSupport.java
  ===================================================================
  RCS file: /home/cvs/incubator-geronimo/modules/deployment/src/java/org/apache/geronimo/deployment/plugin/DConfigBeanSupport.java,v
  retrieving revision 1.8
  retrieving revision 1.9
  diff -u -r1.8 -r1.9
  --- DConfigBeanSupport.java	18 Feb 2004 20:55:31 -0000	1.8
  +++ DConfigBeanSupport.java	20 Feb 2004 08:11:39 -0000	1.9
  @@ -57,6 +57,7 @@
   
   import javax.enterprise.deploy.model.DDBean;
   import javax.enterprise.deploy.model.XpathEvent;
  +import javax.enterprise.deploy.model.DDBeanRoot;
   import javax.enterprise.deploy.spi.DConfigBean;
   import javax.enterprise.deploy.spi.exceptions.BeanNotFoundException;
   import javax.enterprise.deploy.spi.exceptions.ConfigurationException;
  @@ -99,5 +100,46 @@
       }
   
       public void notifyDDChange(XpathEvent event) {
  +    }
  +
  +    protected String[] getXPathsWithPrefix(String prefix, String[][] xpathSegments) {
  +        String[] result = new String[xpathSegments.length];
  +        for (int i = 0; i < xpathSegments.length; i++) {
  +            String[] xpathSegmentArray = xpathSegments[i];
  +            StringBuffer xpath = new StringBuffer();
  +            for (int j = 0; j < xpathSegmentArray.length; j++) {
  +                String segment = xpathSegmentArray[j];
  +                if (prefix != null) {
  +                    xpath.append(prefix).append(":");
  +                }
  +                xpath.append(segment);
  +                if (j < xpathSegmentArray.length -1) {
  +                    xpath.append("/");
  +                }
  +            }
  +            result[i] = xpath.toString();
  +        }
  +        return result;
  +    }
  +
  +    protected String[] getXPathsFromNamespace(String uri, String[][] xpathSegments) {
  +        String[] attributeNames = ddBean.getRoot().getAttributeNames();
  +        for (int i = 0; i < attributeNames.length; i++) {
  +            String attributeName = attributeNames[i];
  +            if (attributeName.startsWith("xmlns")) {
  +                if (ddBean.getRoot().getAttributeValue(attributeName).equals(uri)) {
  +                    if (attributeName.equals("xmlns")) {
  +                        return getXPathsWithPrefix(null , xpathSegments);
  +                    }
  +                    return getXPathsWithPrefix(attributeName.substring(6), xpathSegments);
  +                }
  +            }
  +        }
  +        //??? malformed document, apparently
  +        throw new IllegalStateException("namespace " + uri + " not declared in source document");
  +    }
  +
  +    protected String[] getXPathsForJ2ee_1_4(String[][] xpathSegments) {
  +        return getXPathsFromNamespace("http://java.sun.com/xml/ns/j2ee", xpathSegments);
       }
   }
  
  
  
  1.3       +3 -3      incubator-geronimo/modules/deployment/src/java/org/apache/geronimo/deployment/tools/DDBeanRootImpl.java
  
  Index: DDBeanRootImpl.java
  ===================================================================
  RCS file: /home/cvs/incubator-geronimo/modules/deployment/src/java/org/apache/geronimo/deployment/tools/DDBeanRootImpl.java,v
  retrieving revision 1.2
  retrieving revision 1.3
  diff -u -r1.2 -r1.3
  --- DDBeanRootImpl.java	11 Feb 2004 08:02:21 -0000	1.2
  +++ DDBeanRootImpl.java	20 Feb 2004 08:11:39 -0000	1.3
  @@ -143,11 +143,11 @@
       }
   
       public String[] getAttributeNames() {
  -        return null;
  +        return docBean.getAttributeNames();
       }
   
       public String getAttributeValue(String attrName) {
  -        return null;
  +        return docBean.getAttributeValue(attrName);
       }
   
       public DDBean[] getChildBean(String xpath) {
  
  
  
  1.3       +1 -2      incubator-geronimo/modules/deployment/src/test/org/apache/geronimo/deployment/tools/DDBeanRootTest.java
  
  Index: DDBeanRootTest.java
  ===================================================================
  RCS file: /home/cvs/incubator-geronimo/modules/deployment/src/test/org/apache/geronimo/deployment/tools/DDBeanRootTest.java,v
  retrieving revision 1.2
  retrieving revision 1.3
  diff -u -r1.2 -r1.3
  --- DDBeanRootTest.java	11 Feb 2004 08:02:21 -0000	1.2
  +++ DDBeanRootTest.java	20 Feb 2004 08:11:39 -0000	1.3
  @@ -85,7 +85,6 @@
           assertEquals(deployable, root.getDeployableObject());
           assertEquals(ModuleType.CAR, root.getType());
           assertEquals("/", root.getXpath());
  -        assertNull(root.getAttributeNames());
           assertNull(root.getText("foo"));
           assertTrue(Arrays.equals(new String[] {"Test DD for app-client1"}, root.getText("application-client/description")));
           assertTrue(Arrays.equals(new String[] {"http://localhost"}, root.getText("application-client/env-entry/env-entry-value")));