src/share/jaxws_classes/com/sun/tools/internal/xjc/generator/bean/DualObjectFactoryGenerator.java

Thu, 31 Aug 2017 15:18:52 +0800

author
aoqi
date
Thu, 31 Aug 2017 15:18:52 +0800
changeset 637
9c07ef4934dd
parent 368
0989ad8c0860
parent 0
373ffda63c9a
permissions
-rw-r--r--

merge

     1 /*
     2  * Copyright (c) 1997, 2011, Oracle and/or its affiliates. All rights reserved.
     3  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
     4  *
     5  * This code is free software; you can redistribute it and/or modify it
     6  * under the terms of the GNU General Public License version 2 only, as
     7  * published by the Free Software Foundation.  Oracle designates this
     8  * particular file as subject to the "Classpath" exception as provided
     9  * by Oracle in the LICENSE file that accompanied this code.
    10  *
    11  * This code is distributed in the hope that it will be useful, but WITHOUT
    12  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
    13  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
    14  * version 2 for more details (a copy is included in the LICENSE file that
    15  * accompanied this code).
    16  *
    17  * You should have received a copy of the GNU General Public License version
    18  * 2 along with this work; if not, write to the Free Software Foundation,
    19  * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
    20  *
    21  * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
    22  * or visit www.oracle.com if you need additional information or have any
    23  * questions.
    24  */
    26 package com.sun.tools.internal.xjc.generator.bean;
    28 import com.sun.codemodel.internal.JDefinedClass;
    29 import com.sun.codemodel.internal.JExpr;
    30 import com.sun.codemodel.internal.JMod;
    31 import com.sun.codemodel.internal.JPackage;
    32 import com.sun.tools.internal.xjc.model.CElementInfo;
    33 import com.sun.tools.internal.xjc.model.Model;
    35 /**
    36  * {@link ObjectFactoryGenerator} used when we generate
    37  * interfaces and implementations in separate packages.
    38  *
    39  * <p>
    40  * {@link #publicOFG} and {@link #privateOFG} gives you access to
    41  * {@code ObjectFactory}s in both packages, if you need to.
    42  *
    43  * @author Kohsuke Kawaguchi
    44  */
    45 public final class DualObjectFactoryGenerator extends ObjectFactoryGenerator {
    46     public final ObjectFactoryGenerator publicOFG;
    47     public final ObjectFactoryGenerator privateOFG;
    49     DualObjectFactoryGenerator(BeanGenerator outline, Model model, JPackage targetPackage) {
    50         this.publicOFG = new PublicObjectFactoryGenerator(outline,model,targetPackage);
    51         this.privateOFG = new PrivateObjectFactoryGenerator(outline,model,targetPackage);
    53         // put the marker so that we can detect missing jaxb.properties
    54         publicOFG.getObjectFactory().field(JMod.PRIVATE|JMod.STATIC|JMod.FINAL,
    55                 Void.class, "_useJAXBProperties", JExpr._null());
    56     }
    58     void populate(CElementInfo ei) {
    59         publicOFG.populate(ei);
    60         privateOFG.populate(ei);
    61     }
    63     void populate(ClassOutlineImpl cc) {
    64         publicOFG.populate(cc);
    65         privateOFG.populate(cc);
    66     }
    68     /**
    69      * Returns the private version (which is what gets used at runtime.)
    70      */
    71     public JDefinedClass getObjectFactory() {
    72         return privateOFG.getObjectFactory();
    73     }
    74 }

mercurial