epoc32/include/uri16.h
author William Roberts <williamr@symbian.org>
Tue, 16 Mar 2010 16:12:26 +0000
branchSymbian2
changeset 2 2fe1408b6811
parent 0 061f57f2323e
child 4 837f303aceeb
permissions -rw-r--r--
Final list of Symbian^2 public API header files
     1 // Copyright (c) 2001-2009 Nokia Corporation and/or its subsidiary(-ies).
     2 // All rights reserved.
     3 // This component and the accompanying materials are made available
     4 // under the terms of the License "Symbian Foundation License v1.0" to Symbian Foundation members and "Symbian Foundation End User License Agreement v1.0" to non-members
     5 // which accompanies this distribution, and is available
     6 // at the URL "http://www.symbianfoundation.org/legal/licencesv10.html".
     7 //
     8 // Initial Contributors:
     9 // Nokia Corporation - initial contribution.
    10 //
    11 // Contributors:
    12 //
    13 // Description:
    14 // This file contains the API definition for the classes TUriC16 and 
    15 // CUri16. These classes provide non-modifying (TUriC16) and modifying
    16 // (CUri16) functionality for the components of a Uri as described in 
    17 // RFC2396.
    18 // 
    19 //
    20 
    21 
    22 
    23 /**
    24  @file Uri16.h
    25  @publishedAll
    26  @deprecated Deprecated in 9.1
    27 */
    28 
    29 #ifndef __URI16_H__
    30 #define __URI16_H__
    31 
    32 // System includes
    33 //
    34 #include <e32base.h>
    35 #include <f32file.h> 
    36 #include <uricommon.h>
    37 
    38 
    39 class TUriC16
    40 /**
    41 	Dependencies : TUriComponent.
    42 	Comments : Provides non-modifying functionality on the components of a uri object as
    43 	defined in RFC2396. There are 5 components; scheme, authority, path, query and fragment.
    44 
    45 The	object holds descriptor pointers to the parsed uri components and a descriptor pointer 
    46 to the uri. It is non-owning. It uses 16-bit descriptors.
    47 
    48 	The functionality provided by this API allows the uri components to be extracted from the 
    49 	parsed uri, checked for their presence in the uri and be compared with those in another 
    50 	TUriC16 object.
    51 	@publishedAll
    52 	@deprecated Deprecated in 9.1
    53 	@since 6.0
    54 */
    55 	{
    56 public:	// Methods
    57 
    58 	IMPORT_C HBufC* GetFileNameL() const;
    59 	IMPORT_C HBufC* GetFileNameL(TUriFileName aType) const;
    60 	IMPORT_C const TDesC16& Extract(TUriComponent aComponent) const;
    61 	IMPORT_C void UriWithoutFragment(TPtrC16& aUriNoFrag) const;
    62 
    63 	IMPORT_C TBool IsPresent(TUriComponent aComponent) const;
    64 	IMPORT_C TBool IsSchemeValid() const;
    65 
    66 	IMPORT_C TInt Compare(const TUriC16& aUri, TUriComponent aComponent) const;
    67 
    68 	IMPORT_C const TDesC16& UriDes() const;
    69 
    70 	IMPORT_C TInt Validate() const;
    71 	IMPORT_C TInt Equivalent(const TUriC16& aUri) const;
    72 	IMPORT_C HBufC* DisplayFormL(TUriComponent aComponent = EUriComplete) const;
    73 
    74 protected:	// Methods
    75 
    76 	IMPORT_C TUriC16();
    77 
    78 	void Reset();
    79 	
    80 private:	// Methods
    81 	
    82 	TInt ValidateL() const;
    83 	TInt EquivalentL(const TDesC16& aUri) const;
    84 
    85 protected:	// Attributes
    86 
    87 	/** The array of descriptor pointers to the uri components.
    88 	 */
    89 	TPtrC16		iComponent[EUriMaxComponents];
    90 
    91 	/** The descriptor pointer to the uri.
    92 	 */
    93 	TPtrC16		iUriDes;
    94 
    95 /**
    96 	A friend class.
    97 	@see		CUri16 
    98 	@since		6.0
    99  */
   100 	friend class CUri16;
   101 
   102 /**
   103 	A friend class used for testing.
   104 	@see		TUriC16StateAccessor
   105 	@since		6.0
   106 	@internalComponent
   107  */
   108 	friend class TUriC16StateAccessor;
   109 
   110 	};
   111 
   112 /**
   113 Dependencies : TUriC16
   114 Comments : Provides functionality to parse a descriptor into the components of a uri as 
   115 defined in RFC2396. There are 5 components; scheme, authority, path, query and fragment.
   116 
   117 It uses 16-bit descriptors.
   118 
   119 Format of a uri is; scheme://authority path?query\#fragment
   120 
   121 @warning The descriptor that is parsed by an object of this class will be referenced 
   122 by that object. If the original descriptor is no longer in scope there will be undefined 
   123 behaviour.
   124 @publishedAll
   125 @deprecated Deprecated in 9.1. Use UriUtils::CreateUriL() instead
   126 @since 6.0
   127 */
   128 class TUriParser16 : public TUriC16
   129 	{
   130 public:	// Methods
   131 
   132 	IMPORT_C TUriParser16();
   133 	IMPORT_C TInt Parse(const TDesC16& aUri);
   134 	};
   135 
   136 /**
   137 	Dependencies : CBase, TUriC16.
   138 	Comments : Provides modifying functionality on the components of a uri object, as
   139 	defined in RFC2396. There are 5 components; scheme. authority, path, query and fragment.
   140 
   141 	The	object holds parsed uri information. It is owning. It uses 16-bit descriptors.
   142 
   143 	The functionality provided by this API allows the uri components to be set or removed 
   144 	from this parsed uri. Also, it provides a reference to TUriC16 object so that the non-modifying 
   145 	functionality can be used.
   146 	@publishedAll
   147 	@deprecated Deprecated in 9.1
   148 	@since 6.0
   149 */
   150 class CUri16 : public CBase
   151 	{
   152 public: // Methods
   153 	IMPORT_C static CUri16* CreateFileUriL(const TDesC& aFullFileName, TUint aFlags = 0);
   154 	IMPORT_C static CUri16* CreatePrivateFileUriL(const TDesC& aRelativeFileName, TDriveNumber aDrive, TInt aFlags = 0);
   155 
   156 	IMPORT_C static CUri16* NewL(const TUriC16& aUri);
   157 	IMPORT_C static CUri16* NewLC(const TUriC16& aUri);
   158 	IMPORT_C static CUri16* NewL();
   159 	IMPORT_C static CUri16* NewLC();
   160 
   161 	IMPORT_C static CUri16* ResolveL(const TUriC16& aBaseUri, const TUriC16& aRefUri);
   162 
   163 	IMPORT_C ~CUri16();
   164 	IMPORT_C const TUriC16& Uri() const;
   165 	IMPORT_C void SetComponentL(const TDesC16& aData, TUriComponent aComponent);
   166 	IMPORT_C void RemoveComponentL(TUriComponent aComponent);
   167 
   168 private:	// Methods
   169 
   170 	CUri16(const TUriC16& aNewUri);
   171 	void ConstructL();
   172 	void FormUriL();
   173 	void InitializeFileUriComponentsL(const TDesC& aFileName, TDriveNumber aDrive, TUint aFlags);
   174 
   175 private:	// Attributes
   176 
   177 	/** The descriptor buffer that contains the uri.
   178 	 */
   179 	HBufC16*	iUriBuf;
   180 
   181 	/** The parsed uri object.
   182 	 */
   183 	TUriC16	iUri;
   184 
   185 /**
   186 	A friend class used for testing.
   187 	@see		TUri16StateAccessor
   188 	@since		6.0
   189 	@internalComponent
   190  */
   191 	friend class TUri16StateAccessor;
   192 
   193 	};
   194 
   195 /** 	
   196 Do not use. Use TUriC8 instead
   197 @publishedAll
   198 @deprecated Deprecated in 9.1 
   199  */
   200 typedef TUriC16			TUriC;
   201 
   202 /** 
   203 Do not use. Use TUriParser8 instead
   204 @publishedAll
   205 @deprecated Deprecated in 9.1 
   206  */
   207 typedef TUriParser16	TUriParser;
   208 
   209 /** 
   210 Do not use. Use CUri8 instead
   211 @publishedAll
   212 @deprecated Deprecated in 9.1 
   213  */
   214 typedef CUri16			CUri;
   215 
   216 #endif	// __URI16_H__