KickJava   Java API By Example, From Geeks To Geeks.

Java > Open Source Codes > net > percederberg > grammatica > code > csharp > CSharpNamespace


1 /*
2  * CSharpNamespace.java
3  *
4  * This work is free software; you can redistribute it and/or modify
5  * it under the terms of the GNU General Public License as published
6  * by the Free Software Foundation; either version 2 of the License,
7  * or (at your option) any later version.
8  *
9  * This work is distributed in the hope that it will be useful, but
10  * WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12  * General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with this program; if not, write to the Free Software
16  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
17  * USA
18  *
19  * As a special exception, the copyright holders of this library give
20  * you permission to link this library with independent modules to
21  * produce an executable, regardless of the license terms of these
22  * independent modules, and to copy and distribute the resulting
23  * executable under terms of your choice, provided that you also meet,
24  * for each linked independent module, the terms and conditions of the
25  * license of that module. An independent module is a module which is
26  * not derived from or based on this library. If you modify this
27  * library, you may extend this exception to your version of the
28  * library, but you are not obligated to do so. If you do not wish to
29  * do so, delete this exception statement from your version.
30  *
31  * Copyright (c) 2003 Per Cederberg. All rights reserved.
32  */

33
34 package net.percederberg.grammatica.code.csharp;
35
36 import java.io.PrintWriter JavaDoc;
37 import net.percederberg.grammatica.code.CodeElementContainer;
38 import net.percederberg.grammatica.code.CodeStyle;
39
40 /**
41  * A class generating a C# namespace declaration.
42  *
43  * @author Per Cederberg, <per at percederberg dot net>
44  * @version 1.0
45  */

46 public class CSharpNamespace extends CodeElementContainer {
47
48     /**
49      * The fully qualified namespace name.
50      */

51     private String JavaDoc name;
52
53     /**
54      * Creates a new namespace.
55      *
56      * @param name the fully qualified namespace name
57      */

58     public CSharpNamespace(String JavaDoc name) {
59         this.name = name;
60     }
61
62     /**
63      * Returns a numeric category number for the code element. A lower
64      * category number implies that the code element should be placed
65      * before code elements with a higher category number within a
66      * declaration.
67      *
68      * @return the category number
69      */

70     public int category() {
71         return 11;
72     }
73
74     /**
75      * Adds a class declaration to the namespace.
76      *
77      * @param c the class declaration to add
78      */

79     public void addClass(CSharpClass c) {
80         addElement(c);
81     }
82
83     /**
84      * Adds an enumeration to the namespace.
85      *
86      * @param e the enumeration to add
87      */

88     public void addEnumeration(CSharpEnumeration e) {
89         addElement(e);
90     }
91
92     /**
93      * Prints the code element to the specified output stream.
94      *
95      * @param out the output stream
96      * @param style the code style to use
97      * @param indent the indentation level
98      */

99     public void print(PrintWriter JavaDoc out, CodeStyle style, int indent) {
100         String JavaDoc indentStr = style.getIndent(indent);
101
102         out.println(indentStr + "namespace " + name + " {");
103         out.println();
104         printContents(out, style, indent + 1);
105         out.println(indentStr + "}");
106     }
107 }
108
Popular Tags