Classes in this File | Line Coverage | Branch Coverage | Complexity | ||||
AttributeNotationJava |
|
| 2.2;2.2 |
1 | /* $Id: AttributeNotationJava.java 18615 2010-08-03 08:23:26Z mvw $ | |
2 | ***************************************************************************** | |
3 | * Copyright (c) 2009-2010 Contributors - see below | |
4 | * All rights reserved. This program and the accompanying materials | |
5 | * are made available under the terms of the Eclipse Public License v1.0 | |
6 | * which accompanies this distribution, and is available at | |
7 | * http://www.eclipse.org/legal/epl-v10.html | |
8 | * | |
9 | * Contributors: | |
10 | * mvw | |
11 | ***************************************************************************** | |
12 | * | |
13 | * Some portions of this file was previously release using the BSD License: | |
14 | */ | |
15 | ||
16 | // Copyright (c) 2006-2009 The Regents of the University of California. All | |
17 | // Rights Reserved. Permission to use, copy, modify, and distribute this | |
18 | // software and its documentation without fee, and without a written | |
19 | // agreement is hereby granted, provided that the above copyright notice | |
20 | // and this paragraph appear in all copies. This software program and | |
21 | // documentation are copyrighted by The Regents of the University of | |
22 | // California. The software program and documentation are supplied "AS | |
23 | // IS", without any accompanying services from The Regents. The Regents | |
24 | // does not warrant that the operation of the program will be | |
25 | // uninterrupted or error-free. The end-user understands that the program | |
26 | // was developed for research purposes and is advised not to rely | |
27 | // exclusively on the program for any reason. IN NO EVENT SHALL THE | |
28 | // UNIVERSITY OF CALIFORNIA BE LIABLE TO ANY PARTY FOR DIRECT, INDIRECT, | |
29 | // SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES, INCLUDING LOST PROFITS, | |
30 | // ARISING OUT OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN IF | |
31 | // THE UNIVERSITY OF CALIFORNIA HAS BEEN ADVISED OF THE POSSIBILITY OF | |
32 | // SUCH DAMAGE. THE UNIVERSITY OF CALIFORNIA SPECIFICALLY DISCLAIMS ANY | |
33 | // WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF | |
34 | // MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE SOFTWARE | |
35 | // PROVIDED HEREUNDER IS ON AN "AS IS" BASIS, AND THE UNIVERSITY OF | |
36 | // CALIFORNIA HAS NO OBLIGATIONS TO PROVIDE MAINTENANCE, SUPPORT, | |
37 | // UPDATES, ENHANCEMENTS, OR MODIFICATIONS. | |
38 | ||
39 | package org.argouml.notation.providers.java; | |
40 | ||
41 | import org.argouml.application.events.ArgoEventPump; | |
42 | import org.argouml.application.events.ArgoEventTypes; | |
43 | import org.argouml.application.events.ArgoHelpEvent; | |
44 | import org.argouml.model.Model; | |
45 | import org.argouml.notation.NotationSettings; | |
46 | import org.argouml.notation.providers.AttributeNotation; | |
47 | ||
48 | /** | |
49 | * @author michiel | |
50 | */ | |
51 | public class AttributeNotationJava extends AttributeNotation { | |
52 | ||
53 | /** | |
54 | * The constructor. | |
55 | * @param attribute the UML object | |
56 | */ | |
57 | public AttributeNotationJava(Object attribute) { | |
58 | 0 | super(attribute); |
59 | 0 | } |
60 | ||
61 | /* | |
62 | * @see org.argouml.notation.providers.NotationProvider#getParsingHelp() | |
63 | */ | |
64 | public String getParsingHelp() { | |
65 | // return "parsing.java.help.attribute"; | |
66 | 0 | return "Parsing in Java not yet supported"; |
67 | } | |
68 | ||
69 | /* | |
70 | * @see org.argouml.notation.providers.NotationProvider#parse(java.lang.Object, java.lang.String) | |
71 | */ | |
72 | public void parse(Object modelElement, String text) { | |
73 | 0 | ArgoEventPump.fireEvent(new ArgoHelpEvent( |
74 | ArgoEventTypes.HELP_CHANGED, this, | |
75 | "Parsing in Java not yet supported")); | |
76 | 0 | } |
77 | ||
78 | private String toString(Object modelElement) { | |
79 | 0 | StringBuffer sb = new StringBuffer(80); |
80 | 0 | sb.append(NotationUtilityJava.generateVisibility(modelElement)); |
81 | 0 | sb.append(NotationUtilityJava.generateScope(modelElement)); |
82 | 0 | sb.append(NotationUtilityJava.generateChangeability(modelElement)); |
83 | 0 | Object type = Model.getFacade().getType(modelElement); |
84 | 0 | Object multi = Model.getFacade().getMultiplicity(modelElement); |
85 | // handle multiplicity here since we need the type | |
86 | // actually the API of generator is buggy since to generate | |
87 | // multiplicity correctly we need the attribute too | |
88 | 0 | if (type != null && multi != null) { |
89 | 0 | if (Model.getFacade().getUpper(multi) == 1) { |
90 | 0 | sb.append(NotationUtilityJava.generateClassifierRef(type)) |
91 | .append(' '); | |
92 | 0 | } else if (Model.getFacade().isADataType(type)) { |
93 | 0 | sb.append(NotationUtilityJava.generateClassifierRef(type)) |
94 | .append("[] "); | |
95 | } else { | |
96 | 0 | sb.append("java.util.Vector "); |
97 | } | |
98 | } | |
99 | ||
100 | 0 | sb.append(Model.getFacade().getName(modelElement)); |
101 | 0 | Object init = Model.getFacade().getInitialValue(modelElement); |
102 | 0 | if (init != null) { |
103 | 0 | String initStr = |
104 | NotationUtilityJava.generateExpression(init).trim(); | |
105 | 0 | if (initStr.length() > 0) { |
106 | 0 | sb.append(" = ").append(initStr); |
107 | } | |
108 | } | |
109 | ||
110 | 0 | return sb.toString(); |
111 | } | |
112 | ||
113 | @Override | |
114 | public String toString(Object modelElement, NotationSettings settings) { | |
115 | 0 | return toString(modelElement); |
116 | } | |
117 | ||
118 | } |