Quellcodebibliothek Statistik Leitseite products/Sources/formale Sprachen/C/LibreOffice/udkapi/com/sun/star/uri/   (Office von Apache Version 25.8.3.2©)  Datei vom 5.10.2025 mit Größe 7 kB image not shown  

Quelle  XUriReference.idl   Sprache: unbekannt

 
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/*
 * This file is part of the LibreOffice project.
 *
 * This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
 *
 * This file incorporates work covered by the following license notice:
 *
 *   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 .
 */

module com { module sun { module star { module uri {

/**
   represents generic, mutable URI references.

   <p>See <a href="http://www.ietf.org/rfc/rfc3986.txt">RFC 3986</a> for a
   description of URI references and related terms.</p>

   <p>This interface only handles generic URI references (both absolute and
   relative).  For specific URI schemes, there will be additional interfaces
   that offer extra, scheme-specific functionality.</p>

   @see com::sun::star::uri::UriReferenceFactory
   which allows to create URI reference objects that support
   com::sun::star::uri::XUriReference and additional,
   scheme-specific interfaces.

   @since OOo 2.0
 */
published interface XUriReference: com::sun::star::uno::XInterface {
    /**
       returns the textual representation of the complete URI reference.

       @returns
       the textual representation of the complete URI reference.  The exact
       spelling of the URI reference is retained.
     */
    string getUriReference();

    /**
       returns whether this URI reference is absolute or relative.

       <p>A URI is absolute if it has a scheme.</p>

       @returns
       `TRUE` if this URI reference is absolute, `FALSE` if it is relative.
     */
    boolean isAbsolute();

    /**
       returns the scheme part of this (absolute) URI reference.

       @returns
       the textual representation of the scheme part (with the exact spelling
       retained; without the delimiting “<code>:</code>”), if this
       is an absolute URI reference; otherwise, an empty `string` is
       returned.
     */
    string getScheme();

    /**
       returns the scheme-specific part of this URI reference.

       <p>For an absolute URI reference, the scheme-specific part is everything
       after the scheme part and the delimiting “<code>:</code>”,
       and before the optional “<code>#</code>” and fragment part.
       For a relative URI reference, the scheme-specific part is everything
       before the optional “<code>#</code>” and fragment part.</p>

       @returns
       the textual representation of the scheme-specific part (with the exact
       spelling retained).
     */
    string getSchemeSpecificPart();

    /**
       returns whether this URI reference is hierarchical or opaque, in the sense of RFC 2396.

       <p>An absolute URI reference is hierarchical if its scheme-specific part
       starts with “<code>/</code>”.  A relative URI reference is
       always hierarchical.</p>

       @returns
       `TRUE` if this URI reference is hierarchical, `FALSE` if it is opaque.

       @deprecated RFC 3986 no longer differentiates between hierarchical and opaque URIs.
     */
    boolean isHierarchical();

    /**
       returns whether this URI reference has an authority part.

       @returns
       `TRUE` if this URI reference has an authority part.
     */
    boolean hasAuthority();

    /**
       returns the authority part of this URI reference.

       @returns
       the textual representation of the authority part (with the exact spelling
       retained), if this is a URI reference that has an authority
       part; otherwise, an empty `string` is returned.
     */
    string getAuthority();

    /**
       returns the path part of this URI reference.

       @returns
       the textual representation of the path part (with the exact spelling
       retained).
     */
    string getPath();

    /**
       returns whether this URI reference has a relative path.

       @returns
       `TRUE` if this URI reference has a relative path.
     */
    boolean hasRelativePath();

    /**
       returns the number of path segments of this URI reference.

       <p>For a URI reference with
       an empty path, the number of path segments is zero.  For a
       URI reference with an absolute, non-empty path, the number of path
       segments equals the number of “<code>/</code>” delimiters.
       For a URI reference with a relative, non-empty path, the
       number of path segments equals the number of “<code>/</code>”
       delimiters, plus one.</p>

       @returns
       the number of path segments.
     */
    long getPathSegmentCount();

    /**
       returns a given path segment of this URI reference.

       @param index
       the index of the path segment, starting at zero.

       @returns
       the textual representation of the given path segment (with the exact
       spelling retained, without any delimiting “<code>/</code>”),
       if this URI reference has that many path segments;
       otherwise, and in particular if <code>index</code> is negative, an empty
       `string` is returned.
     */
    string getPathSegment([in] long index);

    /**
       returns whether this URI reference has a query part.

       @returns
       `TRUE` if this URI reference has a query part.
     */
    boolean hasQuery();

    /**
       returns the query part of this URI reference.

       @returns
       the textual representation of the query part (with the exact spelling
       retained; without the delimiting “<code>?</code>”), if this
       is a URI reference that has a query part; otherwise, an
       empty `string` is returned.
     */
    string getQuery();

    /**
       returns whether this URI reference has a fragment part.

       @returns
       `TRUE` if this URI reference has a fragment part.
     */
    boolean hasFragment();

    /**
       returns the fragment part of this URI reference.

       @returns
       the textual representation of the fragment part (with the exact spelling
       retained; without the delimiting “<code>#</code>”), if this
       is a URI reference that has a fragment part; otherwise, an empty
       `string` is returned.
     */
    string getFragment();

    /**
       sets the fragment part of this URI reference.

       @param fragment
       the textual representation of the new fragment part.  The exact spelling
       will be preserved, and no escaping is performed.
     */
    void setFragment([in] string fragment);

    /**
       clears the fragment part of this URI reference.
     */
    void clearFragment();
};

}; }; }; };

/* vim:set shiftwidth=4 softtabstop=4 expandtab: */

[ Dauer der Verarbeitung: 0.24 Sekunden  (vorverarbeitet)  ]