001: /*
002: * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
003: *
004: * Copyright 1997-2007 Sun Microsystems, Inc. All rights reserved.
005: *
006: * The contents of this file are subject to the terms of either the GNU
007: * General Public License Version 2 only ("GPL") or the Common
008: * Development and Distribution License("CDDL") (collectively, the
009: * "License"). You may not use this file except in compliance with the
010: * License. You can obtain a copy of the License at
011: * http://www.netbeans.org/cddl-gplv2.html
012: * or nbbuild/licenses/CDDL-GPL-2-CP. See the License for the
013: * specific language governing permissions and limitations under the
014: * License. When distributing the software, include this License Header
015: * Notice in each file and include the License file at
016: * nbbuild/licenses/CDDL-GPL-2-CP. Sun designates this
017: * particular file as subject to the "Classpath" exception as provided
018: * by Sun in the GPL Version 2 section of the License file that
019: * accompanied this code. If applicable, add the following below the
020: * License Header, with the fields enclosed by brackets [] replaced by
021: * your own identifying information:
022: * "Portions Copyrighted [year] [name of copyright owner]"
023: *
024: * Contributor(s):
025: *
026: * The Original Software is NetBeans. The Initial Developer of the Original
027: * Software is Sun Microsystems, Inc. Portions Copyright 1997-2006 Sun
028: * Microsystems, Inc. All Rights Reserved.
029: *
030: * If you wish your version of this file to be governed by only the CDDL
031: * or only the GPL Version 2, indicate your decision by adding
032: * "[Contributor] elects to include this software in this distribution
033: * under the [CDDL or GPL Version 2] license." If you do not indicate a
034: * single choice of license, a recipient has the option to distribute
035: * your version of this file under either the CDDL, the GPL Version 2 or
036: * to extend the choice of license to its licensees as provided above.
037: * However, if you add GPL Version 2 code and therefore, elected the GPL
038: * Version 2 license, then the option applies only if the new code is
039: * made subject to such option by the copyright holder.
040: */
041:
042: package org.netbeans.modules.xml.retriever.catalog.impl;
043:
044: import java.net.URI;
045: import java.net.URISyntaxException;
046: import java.util.HashMap;
047: import org.netbeans.modules.xml.retriever.catalog.CatalogElement;
048: import org.netbeans.modules.xml.xam.locator.CatalogModel;
049: import org.netbeans.modules.xml.xam.locator.CatalogModelException;
050: import org.netbeans.modules.xml.xam.ModelSource;
051: import org.netbeans.modules.xml.retriever.catalog.CatalogEntry;
052:
053: /**
054: *
055: * @author girix
056: */
057: public class CatalogEntryImpl implements CatalogEntry {
058: private CatalogElement entryType;
059: //mapping string
060: private String source;
061: //mapped string
062: private String target;
063:
064: private CatalogModel this CatModel = null;
065:
066: private HashMap<String, String> extraAttributeMap = null;
067:
068: /**
069: * one example of source is: systemId attribute value for system tag of catalog
070: * one example of mappingEntity is: uri attribute value for system tag of catalog
071: *
072: * @param entryType - Catalog entry type as in public, system, rewriteSystem, etc.
073: * @param source - source URL/String
074: * @param target - Target URL/String
075: */
076: public CatalogEntryImpl(CatalogElement entryType,
077: String mappingEntity, String mappedEntity) {
078: this .entryType = entryType;
079: this .source = mappingEntity;
080: this .target = mappedEntity;
081: }
082:
083: public CatalogEntryImpl(CatalogElement entryType,
084: String mappingEntity, String mappedEntity,
085: HashMap<String, String> extraAttribMap) {
086: this .entryType = entryType;
087: this .source = mappingEntity;
088: this .target = mappedEntity;
089: this .extraAttributeMap = extraAttribMap;
090: }
091:
092: public CatalogElement getEntryType() {
093: return entryType;
094: }
095:
096: public String getSource() {
097: return this .source;
098: }
099:
100: public String getTarget() {
101: return this .target;
102: }
103:
104: public HashMap<String, String> getExtraAttributeMap() {
105: return extraAttributeMap;
106: }
107:
108: public boolean isValid() {
109: if (this CatModel == null)
110: return false;
111: ModelSource ms = null;
112: try {
113: //TODO remove null
114: ms = this CatModel.getModelSource(new URI(source), null);
115: } catch (URISyntaxException ex) {
116: return false;
117: } catch (CatalogModelException ex) {
118: return false;
119: }
120: if (ms != null)
121: return true;
122: return false;
123: }
124:
125: public void setCatalogModel(CatalogModel thisCatModel) {
126: this.thisCatModel = thisCatModel;
127: }
128: }
|