All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.hp.hpl.jena.ontology.ProfileRegistry Maven / Gradle / Ivy

Go to download

Jena is a Java framework for building Semantic Web applications. It provides a programmatic environment for RDF, RDFS and OWL, SPARQL and includes a rule-based inference engine.

The newest version!
/*****************************************************************************
 * Source code information
 * -----------------------
 * Original author    Ian Dickinson, HP Labs Bristol
 * Author email       [email protected]
 * Package            Jena 2
 * Web                http://sourceforge.net/projects/jena/
 * Created            06-Mar-2003
 * Filename           $RCSfile: ProfileRegistry.java,v $
 * Revision           $Revision: 1.2 $
 * Release status     $State: Exp $
 *
 * Last modified on   $Date: 2009/10/06 13:04:34 $
 *               by   $Author: ian_dickinson $
 *
 * (c) Copyright 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009 Hewlett-Packard Development Company, LP
 * (see footer for full conditions)
 *****************************************************************************/

// Package
///////////////
package com.hp.hpl.jena.ontology;


// Imports
///////////////
import com.hp.hpl.jena.ontology.impl.*;
import com.hp.hpl.jena.vocabulary.*;

import java.util.*;


/**
 * 

* Provides a means to map between the URI's that represent ontology languages * and their language profiles. *

* * @author Ian Dickinson, HP Labs * (email) * @version CVS $Id: ProfileRegistry.java,v 1.2 2009/10/06 13:04:34 ian_dickinson Exp $ */ public class ProfileRegistry { // Constants ////////////////////////////////// /** The URI that maps to the language profile for OWL-Full */ public static final String OWL_LANG = OWL.FULL_LANG.getURI(); /** The URI that maps to the language profile for OWL-DL */ public static final String OWL_DL_LANG = OWL.DL_LANG.getURI(); /** The URI that maps to the language profile for OWL-Lite */ public static final String OWL_LITE_LANG = OWL.LITE_LANG.getURI(); /** The URI that maps to the language profile for DAML+OIL */ public static final String DAML_LANG = DAMLVocabulary.NAMESPACE_DAML_2001_03_URI; /** The URI that maps to the language profile for RDFS */ public static final String RDFS_LANG = RDFS.getURI(); // Static variables ////////////////////////////////// private static Object[][] s_initData = new Object[][] { {OWL_LANG, new OWLProfile()}, {OWL_DL_LANG, new OWLDLProfile()}, {OWL_LITE_LANG, new OWLLiteProfile()}, {DAML_LANG, new DAML_OILProfile()}, {RDFS_LANG, new RDFSProfile()} }; /** Singleton instance */ private static ProfileRegistry s_instance = new ProfileRegistry(); // Instance variables ////////////////////////////////// /** Maps from public URI's to language profiles */ private Map m_registry = new HashMap(); // Constructors ////////////////////////////////// /** *

* Singleton constructor *

*/ private ProfileRegistry() { for (int i = 0; i < s_initData.length; i++) { registerProfile( (String) s_initData[i][0], (Profile) s_initData[i][1] ); } } // External signature methods ////////////////////////////////// /** *

* Answer the singleton instance *

* * @return The singleton registry */ public static ProfileRegistry getInstance() { return s_instance; } /** *

* Add a language profile with the given URI key *

* * @param uri The URI denoting the language * @param profile The language profile for the language */ public void registerProfile( String uri, Profile profile ) { m_registry.put( uri, profile ); } /** *

* Answer the language profile for the given language URI, or null if not known. *

* * @param uri A URI denoting an ontology language * @return An ontology language profile for that language */ public Profile getProfile( String uri ) { return m_registry.get( uri ); } // Internal implementation methods ////////////////////////////////// //============================================================================== // Inner class definitions //============================================================================== } /* (c) Copyright 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009 Hewlett-Packard Development Company, LP All rights reserved. Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met: 1. Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer. 2. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution. 3. The name of the author may not be used to endorse or promote products derived from this software without specific prior written permission. THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */




© 2015 - 2024 Weber Informatics LLC | Privacy Policy