summaryrefslogtreecommitdiffstats
path: root/sdo-java/branches/emf-2.5/impl/src/main/java/org/apache/tuscany/sdo/codegen/NoJavaImplementationException.java
blob: a6253e81315bf2abee0d4870571cace0dc03b08b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
/**
 *
 *  Licensed to the Apache Software Foundation (ASF) under one
 *  or more contributor license agreements.  See the NOTICE file
 *  distributed with this work for additional information
 *  regarding copyright ownership.  The ASF licenses this file
 *  to you under the Apache License, Version 2.0 (the
 *  "License"); you may not use this file except in compliance
 *  with the License.  You may obtain a copy of the License at
 *
 *    http://www.apache.org/licenses/LICENSE-2.0
 *
 *  Unless required by applicable law or agreed to in writing,
 *  software distributed under the License is distributed on an
 *  "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
 *  KIND, either express or implied.  See the License for the
 *  specific language governing permissions and limitations
 *  under the License.
 */
package org.apache.tuscany.sdo.codegen;

import commonj.sdo.Type;

/**
 * Exception that indicates there is no Java mapping for an SDO type.
 *
 * @version $Rev$ $Date$
 */
public class NoJavaImplementationException extends GenerationException {
    private final Type type;

    /**
     * Constructor supplying the Type that did not have a Java implementation.
     * A default message is provided of the form "${URI}#${Name}"
     *
     * @param type the type that did not have a Java implementation.
     */
    public NoJavaImplementationException(Type type) {
        super(type == null ? null : type.getURI() + "#" + type.getName());
        this.type = type;
    }

    /**
     * Constructor supplying a message and the Type that did not have a Java implementation.
     *
     * @param message the message
     * @param type the type that did not have a Java implementation.
     */
    public NoJavaImplementationException(String message, Type type) {
        super(message);
        this.type = type;
    }

    /**
     * Return the type that did not have a Java implementation.
     * @return the type that did not have a Java implementation
     */
    public Type getType() {
        return type;
    }
}