/* * The contents of this file are subject to the Mozilla Public * License Version 1.1 (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.mozilla.org/MPL/ * * Software distributed under the License is distributed on an "AS * IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or * implied. See the License for the specific language governing * rights and limitations under the License. * * The Original Code is TransforMiiX XSLT processor. * * The Initial Developer of the Original Code is The MITRE Corporation. * Portions created by MITRE are Copyright (C) 1999 The MITRE Corporation. * * Portions created by Keith Visco as a Non MITRE employee, * (C) 1999 Keith Visco. All Rights Reserved. * * Contributor(s): * * Keith Visco, kvisco@ziplink.net * -- original author. * * Larry Fitzpatrick, OpenText, lef@opentext.com * -- 19990806 * -- moved initialization of constant shorts and chars to * URIUtils.cpp * $Id: URIUtils.h,v 1.2 1999-11-15 07:12:48 nisheeth%netscape.com Exp $ */ #include "String.h" #include "baseutils.h" #include #include /** * A utility class for URI handling * Not yet finished, only handles file URI at this point * @author Keith Visco * @version $Revision: 1.2 $ $Date: 1999-11-15 07:12:48 $ * **/ class URIUtils { public: static const String HTTP_PROTOCOL; static const String FILE_PROTOCOL; /** * the path separator for an URI **/ static const char HREF_PATH_SEP; /** * The Device separator for an URI **/ static const char DEVICE_SEP; /** * The Port separator for an URI **/ static const char PORT_SEP; /** * The Protocal separator for an URI **/ static const char PROTOCOL_SEP; static istream* URIUtils::getInputStream (String& href, String& documentBase, String& errMsg); /** * Returns the document base of the href argument * The document base will be appended to the given dest String **/ static void getDocumentBase(String& href, String& dest); /** * Resolves the given href argument, using the given documentBase * if necessary. * The new resolved href will be appended to the given dest String **/ static void resolveHref(String& href, String& documentBase, String& dest); private: static const short PROTOCOL_MODE; static const short HOST_MODE; static const short PORT_MODE; static const short PATH_MODE; struct ParsedURI { MBool isMalformed; String fragmentIdentifier; String host; String protocol; String port; String path; }; static istream* openStream(ParsedURI* uri); static ParsedURI* parseURI(const String& uri); }; //-- URIUtils