KickJava   Java API By Example, From Geeks To Geeks.

Java > Open Source Codes > org > jboss > test > security > ejb > project > support > DefaultName


1 /*
2   * JBoss, Home of Professional Open Source
3   * Copyright 2005, JBoss Inc., and individual contributors as indicated
4   * by the @authors tag. See the copyright.txt in the distribution for a
5   * full listing of individual contributors.
6   *
7   * This is free software; you can redistribute it and/or modify it
8   * under the terms of the GNU Lesser General Public License as
9   * published by the Free Software Foundation; either version 2.1 of
10   * the License, or (at your option) any later version.
11   *
12   * This software is distributed in the hope that it will be useful,
13   * but WITHOUT ANY WARRANTY; without even the implied warranty of
14   * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15   * Lesser General Public License for more details.
16   *
17   * You should have received a copy of the GNU Lesser General Public
18   * License along with this software; if not, write to the Free
19   * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
20   * 02110-1301 USA, or see the FSF site: http://www.fsf.org.
21   */

22 package org.jboss.test.security.ejb.project.support;
23
24 import java.util.Enumeration JavaDoc;
25 import java.util.Properties JavaDoc;
26 import javax.naming.CompoundName JavaDoc;
27 import javax.naming.InvalidNameException JavaDoc;
28 import javax.naming.Name JavaDoc;
29 import javax.naming.NameParser JavaDoc;
30 import javax.naming.NamingException JavaDoc;
31
32 /** A simple subclass of CompoundName that fixes the name syntax to:
33     jndi.syntax.direction = left_to_right
34     jndi.syntax.separator = "/"
35
36 @author Scott_Stark@displayscape.com
37 @version $Revision: 37406 $
38 */

39 public class DefaultName extends CompoundName JavaDoc
40 {
41     /** The Properties used for the project directory heirarchical names */
42     static Name JavaDoc emptyName;
43     static Properties JavaDoc nameSyntax = new Properties JavaDoc();
44     static
45     {
46         nameSyntax.put("jndi.syntax.direction", "left_to_right");
47         nameSyntax.put("jndi.syntax.separator", "/");
48         try
49         {
50             emptyName = new DefaultName("");
51         }
52         catch(InvalidNameException JavaDoc e)
53         {
54         }
55     }
56
57     private static class DefaultNameParser implements NameParser JavaDoc
58     {
59         public Name JavaDoc parse(String JavaDoc path) throws NamingException JavaDoc
60         {
61             DefaultName name = new DefaultName(path);
62             return name;
63         }
64     }
65
66     public static NameParser JavaDoc getNameParser()
67     {
68         return new DefaultNameParser();
69     }
70
71     /** Creates new DefaultName */
72     public DefaultName(Enumeration JavaDoc comps)
73     {
74         super(comps, nameSyntax);
75     }
76     public DefaultName(String JavaDoc name) throws InvalidNameException JavaDoc
77     {
78         super(name, nameSyntax);
79     }
80     public DefaultName(Name JavaDoc name)
81     {
82         super(name.getAll(), nameSyntax);
83     }
84     public DefaultName()
85     {
86         this(emptyName);
87     }
88
89 }
90
Popular Tags