services/terminalmodeservice/src/upnptmserverdevicexmlparser.cpp
author hgs
Fri, 03 Sep 2010 09:13:04 +0300
changeset 31 b51a6f4f15ba
parent 24 e9457ebcc4df
permissions -rw-r--r--
201035
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
24
hgs
parents:
diff changeset
     1
/**
hgs
parents:
diff changeset
     2
* Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies).
hgs
parents:
diff changeset
     3
* All rights reserved.
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
hgs
parents:
diff changeset
     8
*
hgs
parents:
diff changeset
     9
* Initial Contributors:
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
hgs
parents:
diff changeset
    11
*
hgs
parents:
diff changeset
    12
* Contributors:
hgs
parents:
diff changeset
    13
*
hgs
parents:
diff changeset
    14
* Description: CUpnpTmServerDeviceXmlParser class implementation.
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
// System Includes
hgs
parents:
diff changeset
    19
#include <xml/parserfeature.h>
hgs
parents:
diff changeset
    20
#include <xml/taginfo.h>
hgs
parents:
diff changeset
    21
hgs
parents:
diff changeset
    22
// User Includes
hgs
parents:
diff changeset
    23
#include "upnptmserverdevicexmlparser.h"
hgs
parents:
diff changeset
    24
#include "upnpterminalmodeicon.h"
hgs
parents:
diff changeset
    25
#include "OstTraceDefinitions.h"
hgs
parents:
diff changeset
    26
#ifdef OST_TRACE_COMPILER_IN_USE
hgs
parents:
diff changeset
    27
#include "upnptmserverdevicexmlparserTraces.h"
hgs
parents:
diff changeset
    28
#endif
hgs
parents:
diff changeset
    29
hgs
parents:
diff changeset
    30
hgs
parents:
diff changeset
    31
//Literals
hgs
parents:
diff changeset
    32
_LIT8(KTextXml,           "text/xml");
hgs
parents:
diff changeset
    33
_LIT8(KRootDeviceXmlLead, "<?xml version=\"1.0\" encoding=\"utf-8\"?><root xmlns=\"urn:schemas-upnp-org:device-1-0\"><specVersion><major>1</major><minor>0</minor></specVersion><device><deviceType>urn:schemas-upnp-org:device:TmServerDevice:1</deviceType><friendlyName>S60</friendlyName><manufacturer /><manufacturerURL>http://www.nokia.com</manufacturerURL><modelName /><serialNumber /><UDN /><X_connectivity><bluetooth><btAddr /><startConnection /></bluetooth></X_connectivity>");
hgs
parents:
diff changeset
    34
_LIT8(KRootDeviceXmlTrail,"<serviceList><service><serviceType>urn:schemas-upnp-org:service:TmApplicationServer:1</serviceType><serviceId>urn:upnp-org:serviceId:TmApplicationServer1</serviceId><SCPDURL>/tmserverdevice1/tmapplicationserver1.xml</SCPDURL><controlURL>/tmserverdevice1/tmapplicationserver1/control</controlURL><eventSubURL>/tmserverdevice1/tmapplicationserver1/eventing</eventSubURL></service><service><serviceType>urn:schemas-upnp-org:service:TmClientProfile:1</serviceType>"
hgs
parents:
diff changeset
    35
    "<serviceId>urn:upnp-org:serviceId:TmClientProfile1</serviceId><SCPDURL>/tmserverdevice1/tmclientprofile1.xml</SCPDURL><controlURL>/tmserverdevice1/tmclientprofile1/control</controlURL><eventSubURL>/tmserverdevice1/tmclientprofile1/eventing</eventSubURL></service></serviceList></device></root>");
hgs
parents:
diff changeset
    36
_LIT8(KAppServerSrvXml,   "<?xml version=\"1.0\" encoding=\"utf-8\"?><scpd xmlns=\"urn:schemas-upnp-org:service-1-0\"><specVersion><major>1</major> <minor>0</minor> </specVersion><actionList><action><name>GetApplicationList</name><argumentList><argument><name>AppListingFilter</name><direction>in</direction> <relatedStateVariable>A_ARG_TYPE_String</relatedStateVariable> </argument><argument><name>ProfileID</name><direction>in</direction> <relatedStateVariable>A_ARG_TYPE_ProfileID</relatedStateVariable> "
hgs
parents:
diff changeset
    37
    "</argument><argument><name>AppListing</name><direction>out</direction><relatedStateVariable>A_ARG_TYPE_AppList</relatedStateVariable></argument></argumentList></action><action><name>LaunchApplication</name><argumentList><argument><name>AppID</name><direction>in</direction><relatedStateVariable>A_ARG_TYPE_AppID</relatedStateVariable></argument><argument><name>ProfileID</name><direction>in</direction><relatedStateVariable>A_ARG_TYPE_ProfileID</relatedStateVariable></argument><argument><name>AppURI</name>"
hgs
parents:
diff changeset
    38
    "<direction>out</direction><relatedStateVariable>A_ARG_TYPE_URI</relatedStateVariable></argument></argumentList></action><action><name>TerminateApplication</name><argumentList><argument><name>AppID</name><direction>in</direction><relatedStateVariable>A_ARG_TYPE_AppID</relatedStateVariable></argument><argument><name>ProfileID</name><direction>in</direction><relatedStateVariable>A_ARG_TYPE_ProfileID</relatedStateVariable></argument><argument><name>TerminationResult</name><direction>out</direction>"
hgs
parents:
diff changeset
    39
    "<relatedStateVariable>A_ARG_TYPE_Bool</relatedStateVariable></argument></argumentList></action><action><name>GetApplicationStatus</name><argumentList><argument><name>AppID</name><direction>in</direction><relatedStateVariable>A_ARG_TYPE_AppID</relatedStateVariable></argument><argument><name>AppStatus</name><direction>out</direction><relatedStateVariable>A_ARG_TYPE_AppStatus</relatedStateVariable></argument></argumentList></action></actionList><serviceStateTable><stateVariable sendEvents=\"yes\">"
hgs
parents:
diff changeset
    40
    "<name>AppStatusUpdate</name> <dataType>string</dataType></stateVariable><stateVariable sendEvents=\"yes\"><name>AppListUpdate</name> <dataType>string</dataType></stateVariable><stateVariable sendEvents=\"no\"><name>A_ARG_TYPE_AppStatus</name> <dataType>string</dataType> </stateVariable><stateVariable sendEvents=\"no\"><name>A_ARG_TYPE_AppList</name><dataType>string</dataType></stateVariable><stateVariable sendEvents=\"no\"><name>A_ARG_TYPE_AppID</name><dataType>string</dataType></stateVariable>"
hgs
parents:
diff changeset
    41
    "<stateVariable sendEvents=\"no\"><name>A_ARG_TYPE_ProfileID</name><dataType>ui4</dataType><defaultValue>0</defaultValue></stateVariable><stateVariable sendEvents=\"no\"><name>A_ARG_TYPE_URI</name> <dataType>uri</dataType> </stateVariable><stateVariable sendEvents=\"no\"><name>A_ARG_TYPE_String</name><dataType>string</dataType></stateVariable><stateVariable sendEvents=\"no\"><name>A_ARG_TYPE_Bool</name><dataType>string</dataType><defaultValue>false</defaultValue><allowedValueList><allowedValue>false</allowedValue>"
hgs
parents:
diff changeset
    42
    "<allowedValue>true</allowedValue></allowedValueList></stateVariable></serviceStateTable></scpd>");
hgs
parents:
diff changeset
    43
_LIT8(KClientProfSrvXml,  "<?xml version=\"1.0\" encoding=\"utf-8\"?><scpd xmlns=\"urn:schemas-upnp-org:service-1-0\"><specVersion><major>1</major> <minor>0</minor> </specVersion><actionList><action><name>GetMaxNumProfiles</name><argumentList><argument><name>numProfilesAllowed</name><direction>out</direction> <relatedStateVariable>MaxNumProfiles</relatedStateVariable> </argument></argumentList></action><action><name>SetClientProfile</name><argumentList><argument><name>profileID</name><direction>in</direction>"
hgs
parents:
diff changeset
    44
    "<relatedStateVariable>A_ARG_TYPE_ProfileID</relatedStateVariable></argument><argument><name>clientProfile</name><direction>in</direction><relatedStateVariable>A_ARG_TYPE_ClientProfile</relatedStateVariable></argument><argument><name>resultProfile</name><direction>out</direction><relatedStateVariable>A_ARG_TYPE_ClientProfile</relatedStateVariable></argument></argumentList></action><action><name>GetClientProfile</name><argumentList><argument><name>profileID</name><direction>in</direction>"
hgs
parents:
diff changeset
    45
    "<relatedStateVariable>A_ARG_TYPE_ProfileID</relatedStateVariable></argument><argument><name>clientProfile</name><direction>out</direction><relatedStateVariable>A_ARG_TYPE_ClientProfile</relatedStateVariable></argument></argumentList></action></actionList><serviceStateTable><stateVariable sendEvents=\"yes\"><name>UnusedProfileIDs</name> <dataType>string</dataType></stateVariable><stateVariable sendEvents=\"no\"><name>A_ARG_TYPE_ClientProfile</name> <dataType>string</dataType></stateVariable>"
hgs
parents:
diff changeset
    46
    "<stateVariable sendEvents=\"no\"><name>A_ARG_TYPE_ProfileID</name><dataType>ui4</dataType><defaultValue>0</defaultValue></stateVariable><stateVariable sendEvents=\"no\"><name>MaxNumProfiles</name> <dataType>ui2</dataType> <defaultValue>1</defaultValue> </stateVariable> </serviceStateTable></scpd>");
hgs
parents:
diff changeset
    47
_LIT8(KStartLine,         "<?xml version=\"1.0\" encoding=\"utf-8\"?>\n");
hgs
parents:
diff changeset
    48
_LIT8(KRootAttrb,         " xmlns=\"urn:schemas-upnp-org:device-1-0\"");
hgs
parents:
diff changeset
    49
_LIT8(KScpdUrl,           "/tmserverdevice1/");
hgs
parents:
diff changeset
    50
_LIT8(KUpnpDeviceRoot,    "root" );
hgs
parents:
diff changeset
    51
_LIT8(KStartIconList,     "<iconList>" );
hgs
parents:
diff changeset
    52
_LIT8(KEndIconList,       "</iconList>" );
hgs
parents:
diff changeset
    53
_LIT8(KStartIcon,         "<icon>" );
hgs
parents:
diff changeset
    54
_LIT8(KEndIcon,           "</icon>" );
hgs
parents:
diff changeset
    55
_LIT8(KStartMimeType,     "<mimetype>" );
hgs
parents:
diff changeset
    56
_LIT8(KEndMimeType,       "</mimetype>" );
hgs
parents:
diff changeset
    57
_LIT8(KStartWidth,        "<width>" );
hgs
parents:
diff changeset
    58
_LIT8(KEndWidth,          "</width>" );
hgs
parents:
diff changeset
    59
_LIT8(KStartHeight,       "<height>" );
hgs
parents:
diff changeset
    60
_LIT8(KEndHeight,         "</height>" );
hgs
parents:
diff changeset
    61
_LIT8(KStartDepth,        "<depth>" );
hgs
parents:
diff changeset
    62
_LIT8(KEndDepth,          "</depth>" );
hgs
parents:
diff changeset
    63
_LIT8(KStartUrl,          "<url>" );
hgs
parents:
diff changeset
    64
_LIT8(KEndUrl,            "</url>" );
hgs
parents:
diff changeset
    65
_LIT8(KPhoneManufacturer, "manufacturer" );
hgs
parents:
diff changeset
    66
_LIT8(KPhoneModel,        "modelName" );
hgs
parents:
diff changeset
    67
_LIT8(KPhoneSerialNumber, "serialNumber" );
hgs
parents:
diff changeset
    68
_LIT8(KBtAddress,         "btAddr" );
hgs
parents:
diff changeset
    69
_LIT8(KStartConnection,   "startConnection" );
hgs
parents:
diff changeset
    70
_LIT8(KIconPath,          "icon/");
hgs
parents:
diff changeset
    71
_LIT8(KConnTrue,          "true");
hgs
parents:
diff changeset
    72
_LIT8(KConnFalse,         "false");
hgs
parents:
diff changeset
    73
_LIT(KPublicDevicePath,   "public\\TmServerDevice1\\");
hgs
parents:
diff changeset
    74
_LIT(KDeviceName,         "TmServerDevice1.xml");
hgs
parents:
diff changeset
    75
_LIT(KAppServerSrvName,   "TmApplicationServer1.xml");
hgs
parents:
diff changeset
    76
_LIT(KClientProfSrvName,  "TmClientProfile1.xml");
hgs
parents:
diff changeset
    77
_LIT(KIconDirectory,      "icon\\");
hgs
parents:
diff changeset
    78
hgs
parents:
diff changeset
    79
hgs
parents:
diff changeset
    80
// ============================ MEMBER FUNCTIONS ===================================
hgs
parents:
diff changeset
    81
hgs
parents:
diff changeset
    82
// ---------------------------------------------------------------------------------
hgs
parents:
diff changeset
    83
// CUpnpTmServerDeviceXmlParser::NewL
hgs
parents:
diff changeset
    84
// Two-phased constructor.
hgs
parents:
diff changeset
    85
// ---------------------------------------------------------------------------------
hgs
parents:
diff changeset
    86
//
hgs
parents:
diff changeset
    87
CUpnpTmServerDeviceXmlParser* CUpnpTmServerDeviceXmlParser::NewL( CUpnpTmServerDeviceInfo& aDeviceInfo )
hgs
parents:
diff changeset
    88
	{
hgs
parents:
diff changeset
    89
	OstTraceFunctionEntry0( CUPNPTMSERVERDEVICEXMLPARSER_NEWL_ENTRY );
hgs
parents:
diff changeset
    90
	CUpnpTmServerDeviceXmlParser* self = new (ELeave) CUpnpTmServerDeviceXmlParser( aDeviceInfo );
hgs
parents:
diff changeset
    91
	CleanupStack::PushL(self);
hgs
parents:
diff changeset
    92
	self->ConstructL();
hgs
parents:
diff changeset
    93
	CleanupStack::Pop(self);
hgs
parents:
diff changeset
    94
	OstTraceFunctionExit0( CUPNPTMSERVERDEVICEXMLPARSER_NEWL_EXIT );
hgs
parents:
diff changeset
    95
	return self;	
hgs
parents:
diff changeset
    96
	}
hgs
parents:
diff changeset
    97
hgs
parents:
diff changeset
    98
// ---------------------------------------------------------------------------------
hgs
parents:
diff changeset
    99
// CUpnpTmServerDeviceXmlParser::~CUpnpTmServerDeviceXmlParser
hgs
parents:
diff changeset
   100
// Destructor
hgs
parents:
diff changeset
   101
// ---------------------------------------------------------------------------------
hgs
parents:
diff changeset
   102
//
hgs
parents:
diff changeset
   103
CUpnpTmServerDeviceXmlParser::~CUpnpTmServerDeviceXmlParser()	
hgs
parents:
diff changeset
   104
	{
hgs
parents:
diff changeset
   105
	OstTraceFunctionEntry0( CUPNPTMSERVERDEVICEXMLPARSER_CUPNPTMSERVERDEVICEXMLPARSER_ENTRY );
hgs
parents:
diff changeset
   106
	DeleteDirectory();
hgs
parents:
diff changeset
   107
	iPhone.Close();
hgs
parents:
diff changeset
   108
	iEtelSrv.Close();
hgs
parents:
diff changeset
   109
	delete iParser;
hgs
parents:
diff changeset
   110
	iAppServerSrvDescription.Close();
hgs
parents:
diff changeset
   111
	iClientProfSrvDescription.Close();
hgs
parents:
diff changeset
   112
	iReadBuf.Close();
hgs
parents:
diff changeset
   113
	iDeviceDescription.Close();
hgs
parents:
diff changeset
   114
	iDescFilePath.Close();
hgs
parents:
diff changeset
   115
	iClientProfSrvFilePath.Close();
hgs
parents:
diff changeset
   116
	iAppServerSrvFilePath.Close();
hgs
parents:
diff changeset
   117
	iDescriptionUri.Close();
hgs
parents:
diff changeset
   118
	iFs.Close();
hgs
parents:
diff changeset
   119
	iDeviceDir.Close();
hgs
parents:
diff changeset
   120
	iIconDirectory.Close();
hgs
parents:
diff changeset
   121
	delete iFileMan;
hgs
parents:
diff changeset
   122
	OstTraceFunctionExit0( CUPNPTMSERVERDEVICEXMLPARSER_CUPNPTMSERVERDEVICEXMLPARSER_EXIT );
hgs
parents:
diff changeset
   123
	}
hgs
parents:
diff changeset
   124
hgs
parents:
diff changeset
   125
// ---------------------------------------------------------------------------------
hgs
parents:
diff changeset
   126
// CUpnpTmServerDeviceXmlParser::DeleteDirectory
hgs
parents:
diff changeset
   127
// Deletes device and service description files and device icon files related to  
hgs
parents:
diff changeset
   128
// Terminal Mode Service located in the private directory.
hgs
parents:
diff changeset
   129
// ---------------------------------------------------------------------------------
hgs
parents:
diff changeset
   130
//
hgs
parents:
diff changeset
   131
void CUpnpTmServerDeviceXmlParser::DeleteDirectory()   
hgs
parents:
diff changeset
   132
    {
hgs
parents:
diff changeset
   133
    OstTraceFunctionEntry0( CUPNPTMSERVERDEVICEXMLPARSER_DELETEDIRECTORY_ENTRY );
hgs
parents:
diff changeset
   134
    iFs.Delete(iDescFilePath);
hgs
parents:
diff changeset
   135
    iFs.Delete(iAppServerSrvFilePath);
hgs
parents:
diff changeset
   136
    iFs.Delete(iClientProfSrvFilePath); 
hgs
parents:
diff changeset
   137
    iFileMan->RmDir(iIconDirectory);
hgs
parents:
diff changeset
   138
    OstTraceFunctionExit0( CUPNPTMSERVERDEVICEXMLPARSER_DELETEDIRECTORY_EXIT );
hgs
parents:
diff changeset
   139
    }
hgs
parents:
diff changeset
   140
// ---------------------------------------------------------------------------------
hgs
parents:
diff changeset
   141
// CUpnpTmServerDeviceXmlParser::CUpnpTmServerDeviceXmlParser
hgs
parents:
diff changeset
   142
// C++ default constructor can NOT contain any code, that
hgs
parents:
diff changeset
   143
// might leave.
hgs
parents:
diff changeset
   144
// ---------------------------------------------------------------------------------
hgs
parents:
diff changeset
   145
//
hgs
parents:
diff changeset
   146
CUpnpTmServerDeviceXmlParser::CUpnpTmServerDeviceXmlParser( CUpnpTmServerDeviceInfo& aDeviceInfo )
hgs
parents:
diff changeset
   147
    :iDeviceInfo(aDeviceInfo)
hgs
parents:
diff changeset
   148
	{		
hgs
parents:
diff changeset
   149
	}
hgs
parents:
diff changeset
   150
hgs
parents:
diff changeset
   151
// ---------------------------------------------------------------------------------
hgs
parents:
diff changeset
   152
// CUpnpTmServerDeviceXmlParser::ConstructL
hgs
parents:
diff changeset
   153
// Symbian 2nd phase constructor can leave.
hgs
parents:
diff changeset
   154
// ---------------------------------------------------------------------------------
hgs
parents:
diff changeset
   155
//
hgs
parents:
diff changeset
   156
void CUpnpTmServerDeviceXmlParser::ConstructL( )
hgs
parents:
diff changeset
   157
	{
hgs
parents:
diff changeset
   158
    OstTraceFunctionEntry0( CUPNPTMSERVERDEVICEXMLPARSER_CONSTRUCTL_ENTRY );
hgs
parents:
diff changeset
   159
    User::LeaveIfError(iEtelSrv.Connect());
hgs
parents:
diff changeset
   160
    User::LeaveIfError(iEtelSrv.LoadPhoneModule( KMmTsyModuleName ));
hgs
parents:
diff changeset
   161
    User::LeaveIfError(iPhone.Open( iEtelSrv, KMmTsyPhoneName ));
hgs
parents:
diff changeset
   162
    TRequestStatus status;
hgs
parents:
diff changeset
   163
    iPhone.GetPhoneId(status, iPhoneId); 
hgs
parents:
diff changeset
   164
    User::WaitForRequest(status);
hgs
parents:
diff changeset
   165
	User::LeaveIfError(iFs.Connect());
hgs
parents:
diff changeset
   166
    iAppServerSrvDescription.CreateL( KAppServerSrvXml() );
hgs
parents:
diff changeset
   167
    iClientProfSrvDescription.CreateL( KClientProfSrvXml() );
hgs
parents:
diff changeset
   168
	iParser = CParser::NewL(KTextXml(), *this);
hgs
parents:
diff changeset
   169
	iParser->EnableFeature(ESendFullContentInOneChunk);
hgs
parents:
diff changeset
   170
	iReadBuf.CreateMaxL(KBufSize);
hgs
parents:
diff changeset
   171
	iDeviceDescription.CreateMaxL(KBufSize);
hgs
parents:
diff changeset
   172
	iDeviceDescription.SetLength(KErrNone);
hgs
parents:
diff changeset
   173
	OstTraceFunctionExit0( CUPNPTMSERVERDEVICEXMLPARSER_CONSTRUCTL_EXIT );
hgs
parents:
diff changeset
   174
	}
hgs
parents:
diff changeset
   175
hgs
parents:
diff changeset
   176
// ---------------------------------------------------------------------------------
hgs
parents:
diff changeset
   177
// CUpnpTmServerDeviceXmlParser::OnStartDocumentL
hgs
parents:
diff changeset
   178
// Called when parser hits the start of the document
hgs
parents:
diff changeset
   179
// ---------------------------------------------------------------------------------
hgs
parents:
diff changeset
   180
//
hgs
parents:
diff changeset
   181
void CUpnpTmServerDeviceXmlParser::OnStartDocumentL(const RDocumentParameters& /*aDocParam*/,
hgs
parents:
diff changeset
   182
                                                                             TInt aErrorCode )
hgs
parents:
diff changeset
   183
	{
hgs
parents:
diff changeset
   184
	OstTraceFunctionEntry0( CUPNPTMSERVERDEVICEXMLPARSER_ONSTARTDOCUMENTL_ENTRY );
hgs
parents:
diff changeset
   185
	User::LeaveIfError(aErrorCode);
hgs
parents:
diff changeset
   186
    
hgs
parents:
diff changeset
   187
    TBuf<KMaxBufLength> tmpBuf(iDeviceDir);
hgs
parents:
diff changeset
   188
    tmpBuf.Append(KDeviceName());
hgs
parents:
diff changeset
   189
    iDescFilePath.CreateL(tmpBuf);
hgs
parents:
diff changeset
   190
    tmpBuf.Zero();
hgs
parents:
diff changeset
   191
    
hgs
parents:
diff changeset
   192
    // Create TmAppServer service xml
hgs
parents:
diff changeset
   193
    tmpBuf.Copy(iDeviceDir);
hgs
parents:
diff changeset
   194
    tmpBuf.Append(KAppServerSrvName());
hgs
parents:
diff changeset
   195
    RFile appServerSrvFile;
hgs
parents:
diff changeset
   196
    CleanupClosePushL(appServerSrvFile);
hgs
parents:
diff changeset
   197
    TInt err(KErrNone);
hgs
parents:
diff changeset
   198
    err = appServerSrvFile.Create(iFs, tmpBuf, EFileWrite);
hgs
parents:
diff changeset
   199
    if ( err == KErrAlreadyExists )
hgs
parents:
diff changeset
   200
        {
hgs
parents:
diff changeset
   201
        User::LeaveIfError(appServerSrvFile.Open(iFs, tmpBuf, EFileWrite));
hgs
parents:
diff changeset
   202
        }
hgs
parents:
diff changeset
   203
    else
hgs
parents:
diff changeset
   204
        {
hgs
parents:
diff changeset
   205
        User::LeaveIfError(err);
hgs
parents:
diff changeset
   206
        }
hgs
parents:
diff changeset
   207
    User::LeaveIfError(appServerSrvFile.Write(iAppServerSrvDescription));
hgs
parents:
diff changeset
   208
    CleanupStack::PopAndDestroy( &appServerSrvFile );
hgs
parents:
diff changeset
   209
    iAppServerSrvFilePath.CreateL(tmpBuf);
hgs
parents:
diff changeset
   210
    tmpBuf.Zero();
hgs
parents:
diff changeset
   211
    
hgs
parents:
diff changeset
   212
    // Create TmClientProfile service xml
hgs
parents:
diff changeset
   213
    tmpBuf.Copy(iDeviceDir);
hgs
parents:
diff changeset
   214
    tmpBuf.Append(KClientProfSrvName());
hgs
parents:
diff changeset
   215
    RFile clientProfSrvFile;
hgs
parents:
diff changeset
   216
    CleanupClosePushL(clientProfSrvFile);
hgs
parents:
diff changeset
   217
    err = clientProfSrvFile.Create(iFs, tmpBuf, EFileWrite);
hgs
parents:
diff changeset
   218
    if ( err == KErrAlreadyExists )
hgs
parents:
diff changeset
   219
        {
hgs
parents:
diff changeset
   220
        User::LeaveIfError(clientProfSrvFile.Open(iFs, tmpBuf, EFileWrite));
hgs
parents:
diff changeset
   221
        }
hgs
parents:
diff changeset
   222
    else
hgs
parents:
diff changeset
   223
        {
hgs
parents:
diff changeset
   224
        User::LeaveIfError(err);
hgs
parents:
diff changeset
   225
        }
hgs
parents:
diff changeset
   226
    User::LeaveIfError(clientProfSrvFile.Write(iClientProfSrvDescription));
hgs
parents:
diff changeset
   227
    CleanupStack::PopAndDestroy( &clientProfSrvFile );
hgs
parents:
diff changeset
   228
    iClientProfSrvFilePath.CreateL(tmpBuf);
hgs
parents:
diff changeset
   229
    
hgs
parents:
diff changeset
   230
    iDeviceDescription.Append(KStartLine());
hgs
parents:
diff changeset
   231
    iDescriptionUri.CreateMaxL(UpnpString::KDefaultStringLength);
hgs
parents:
diff changeset
   232
    iDescriptionUri.SetLength(KErrNone);
hgs
parents:
diff changeset
   233
    iDescriptionUri.Append(KScpdUrl());
hgs
parents:
diff changeset
   234
    iDescriptionUri.Append(KDeviceName());
hgs
parents:
diff changeset
   235
	OstTraceFunctionExit0( CUPNPTMSERVERDEVICEXMLPARSER_ONSTARTDOCUMENTL_EXIT );
hgs
parents:
diff changeset
   236
	}
hgs
parents:
diff changeset
   237
hgs
parents:
diff changeset
   238
// ---------------------------------------------------------------------------------
hgs
parents:
diff changeset
   239
// CUpnpTmServerDeviceXmlParser::OnEndDocumentL
hgs
parents:
diff changeset
   240
// Called when parser hits the end of the document
hgs
parents:
diff changeset
   241
// ---------------------------------------------------------------------------------
hgs
parents:
diff changeset
   242
//
hgs
parents:
diff changeset
   243
void CUpnpTmServerDeviceXmlParser::OnEndDocumentL(TInt aErrorCode)
hgs
parents:
diff changeset
   244
	{
hgs
parents:
diff changeset
   245
	OstTraceFunctionEntry0( CUPNPTMSERVERDEVICEXMLPARSER_ONENDDOCUMENTL_ENTRY );
hgs
parents:
diff changeset
   246
	User::LeaveIfError(aErrorCode);
hgs
parents:
diff changeset
   247
	
hgs
parents:
diff changeset
   248
	RFile deviceFile;
hgs
parents:
diff changeset
   249
	CleanupClosePushL(deviceFile);
hgs
parents:
diff changeset
   250
	TInt err = deviceFile.Create(iFs, iDescFilePath, EFileWrite);
hgs
parents:
diff changeset
   251
	OstTrace1( TRACE_NORMAL, CUPNPTMSERVERDEVICEXMLPARSER_ONENDDOCUMENTL, "CUpnpTmServerDeviceXmlParser::OnEndDocumentL;err=%d", err );
hgs
parents:
diff changeset
   252
    if ( err == KErrAlreadyExists )
hgs
parents:
diff changeset
   253
        {
hgs
parents:
diff changeset
   254
        User::LeaveIfError(deviceFile.Open(iFs, iDescFilePath, EFileWrite));
hgs
parents:
diff changeset
   255
        }
hgs
parents:
diff changeset
   256
    else
hgs
parents:
diff changeset
   257
        {
hgs
parents:
diff changeset
   258
        User::LeaveIfError(err);
hgs
parents:
diff changeset
   259
        }
hgs
parents:
diff changeset
   260
	User::LeaveIfError(deviceFile.Write(iDeviceDescription));
hgs
parents:
diff changeset
   261
	CleanupStack::PopAndDestroy(&deviceFile);
hgs
parents:
diff changeset
   262
	OstTraceFunctionExit0( CUPNPTMSERVERDEVICEXMLPARSER_ONENDDOCUMENTL_EXIT );
hgs
parents:
diff changeset
   263
	}
hgs
parents:
diff changeset
   264
hgs
parents:
diff changeset
   265
// ---------------------------------------------------------------------------------
hgs
parents:
diff changeset
   266
// CUpnpTmServerDeviceXmlParser::OnStartElementL
hgs
parents:
diff changeset
   267
// Called when parser hits the opening tag
hgs
parents:
diff changeset
   268
// ---------------------------------------------------------------------------------
hgs
parents:
diff changeset
   269
//
hgs
parents:
diff changeset
   270
void CUpnpTmServerDeviceXmlParser::OnStartElementL(const RTagInfo& aElement, const RAttributeArray& /*aAttributes*/, TInt aErrorCode)
hgs
parents:
diff changeset
   271
	{
hgs
parents:
diff changeset
   272
	OstTraceFunctionEntry0( CUPNPTMSERVERDEVICEXMLPARSER_ONSTARTELEMENTL_ENTRY );
hgs
parents:
diff changeset
   273
	User::LeaveIfError(aErrorCode);
hgs
parents:
diff changeset
   274
hgs
parents:
diff changeset
   275
	iDeviceDescription.Append(UpnpCD::KKorp);
hgs
parents:
diff changeset
   276
	iDeviceDescription.Append(aElement.LocalName().DesC());
hgs
parents:
diff changeset
   277
	
hgs
parents:
diff changeset
   278
    if(aElement.LocalName().DesC().Compare(KUpnpDeviceRoot) == 0)
hgs
parents:
diff changeset
   279
        {
hgs
parents:
diff changeset
   280
        iDeviceDescription.Append(KRootAttrb());    
hgs
parents:
diff changeset
   281
        }       
hgs
parents:
diff changeset
   282
    iDeviceDescription.Append(UpnpCD::KProk);
hgs
parents:
diff changeset
   283
hgs
parents:
diff changeset
   284
    if(aElement.LocalName().DesC().Compare(KPhoneManufacturer) == 0)
hgs
parents:
diff changeset
   285
        {
hgs
parents:
diff changeset
   286
        iDeviceDescription.Append(iPhoneId.iManufacturer);   
hgs
parents:
diff changeset
   287
        }
hgs
parents:
diff changeset
   288
	else if(aElement.LocalName().DesC().Compare(KPhoneModel) == 0)
hgs
parents:
diff changeset
   289
        {
hgs
parents:
diff changeset
   290
        iDeviceDescription.Append(iPhoneId.iModel);   
hgs
parents:
diff changeset
   291
        }
hgs
parents:
diff changeset
   292
	else if(aElement.LocalName().DesC().Compare(KPhoneSerialNumber) == 0)
hgs
parents:
diff changeset
   293
        {
hgs
parents:
diff changeset
   294
        iDeviceDescription.Append(iPhoneId.iSerialNumber);   
hgs
parents:
diff changeset
   295
        }
hgs
parents:
diff changeset
   296
    else if(aElement.LocalName().DesC().Compare(KBtAddress) == 0)
hgs
parents:
diff changeset
   297
        {
hgs
parents:
diff changeset
   298
        iDeviceDescription.Append(iDeviceInfo.BtAddress());   
hgs
parents:
diff changeset
   299
        }
hgs
parents:
diff changeset
   300
    else if(aElement.LocalName().DesC().Compare(KStartConnection) == 0)
hgs
parents:
diff changeset
   301
        {
hgs
parents:
diff changeset
   302
        if ( iDeviceInfo.StartConn() )
hgs
parents:
diff changeset
   303
            {
hgs
parents:
diff changeset
   304
            iDeviceDescription.Append(KConnTrue);    
hgs
parents:
diff changeset
   305
            }
hgs
parents:
diff changeset
   306
        else
hgs
parents:
diff changeset
   307
            {
hgs
parents:
diff changeset
   308
            iDeviceDescription.Append(KConnFalse);    
hgs
parents:
diff changeset
   309
            }       
hgs
parents:
diff changeset
   310
        }
hgs
parents:
diff changeset
   311
	OstTraceFunctionExit0( CUPNPTMSERVERDEVICEXMLPARSER_ONSTARTELEMENTL_EXIT );
hgs
parents:
diff changeset
   312
	}
hgs
parents:
diff changeset
   313
hgs
parents:
diff changeset
   314
// ---------------------------------------------------------------------------------
hgs
parents:
diff changeset
   315
// CUpnpTmServerDeviceXmlParser::OnEndElementL
hgs
parents:
diff changeset
   316
// Called when parser hits the closing tag
hgs
parents:
diff changeset
   317
// ---------------------------------------------------------------------------------
hgs
parents:
diff changeset
   318
//
hgs
parents:
diff changeset
   319
void CUpnpTmServerDeviceXmlParser::OnEndElementL( const RTagInfo& aElement, TInt aErrorCode )
hgs
parents:
diff changeset
   320
	{
hgs
parents:
diff changeset
   321
	OstTraceFunctionEntry0( CUPNPTMSERVERDEVICEXMLPARSER_ONENDELEMENTL_ENTRY );
hgs
parents:
diff changeset
   322
	User::LeaveIfError(aErrorCode);
hgs
parents:
diff changeset
   323
	
hgs
parents:
diff changeset
   324
	iDeviceDescription.Append( UpnpCD::KKorp );
hgs
parents:
diff changeset
   325
	iDeviceDescription.Append( UpnpString::KSlash );
hgs
parents:
diff changeset
   326
	iDeviceDescription.Append( aElement.LocalName().DesC() );
hgs
parents:
diff changeset
   327
	iDeviceDescription.Append( UpnpCD::KProk );
hgs
parents:
diff changeset
   328
	OstTraceFunctionExit0( CUPNPTMSERVERDEVICEXMLPARSER_ONENDELEMENTL_EXIT );
hgs
parents:
diff changeset
   329
	}
hgs
parents:
diff changeset
   330
hgs
parents:
diff changeset
   331
// ---------------------------------------------------------------------------------
hgs
parents:
diff changeset
   332
// CUpnpTmServerDeviceXmlParser::OnContentL
hgs
parents:
diff changeset
   333
// Provides the content/value of the element/tag
hgs
parents:
diff changeset
   334
// ---------------------------------------------------------------------------------
hgs
parents:
diff changeset
   335
//	
hgs
parents:
diff changeset
   336
void CUpnpTmServerDeviceXmlParser::OnContentL( const TDesC8& aBytes, TInt aErrorCode )
hgs
parents:
diff changeset
   337
	{
hgs
parents:
diff changeset
   338
	User::LeaveIfError(aErrorCode);
hgs
parents:
diff changeset
   339
	iDeviceDescription.Append(aBytes);
hgs
parents:
diff changeset
   340
	}
hgs
parents:
diff changeset
   341
hgs
parents:
diff changeset
   342
// ---------------------------------------------------------------------------------
hgs
parents:
diff changeset
   343
// CUpnpTmServerDeviceXmlParser::StartL
hgs
parents:
diff changeset
   344
// Method which inputs xml formatted buffer content to the XML Parser 
hgs
parents:
diff changeset
   345
// and invokes parsing
hgs
parents:
diff changeset
   346
// ---------------------------------------------------------------------------------
hgs
parents:
diff changeset
   347
// 
hgs
parents:
diff changeset
   348
void CUpnpTmServerDeviceXmlParser::StartL()
hgs
parents:
diff changeset
   349
	{
hgs
parents:
diff changeset
   350
    OstTraceFunctionEntry0( CUPNPTMSERVERDEVICEXMLPARSER_STARTL_ENTRY );
hgs
parents:
diff changeset
   351
    TDriveNumber drive = RFs::GetSystemDrive();   //Find system's drive
hgs
parents:
diff changeset
   352
    TBuf<UpnpString::KMaxFilenameLength> privatePath;  
hgs
parents:
diff changeset
   353
    TInt err = iFs.PrivatePath(privatePath); //Find the application's private path
hgs
parents:
diff changeset
   354
    // a) If the Private Path is not found (for whatever reasons),
hgs
parents:
diff changeset
   355
    //      Create a private path in the System Drive
hgs
parents:
diff changeset
   356
    if( err == KErrNotFound )
hgs
parents:
diff changeset
   357
        {
hgs
parents:
diff changeset
   358
        User::LeaveIfError( iFs.CreatePrivatePath(drive) );
hgs
parents:
diff changeset
   359
        }
hgs
parents:
diff changeset
   360
    // b) If Private Path is found but is a read-only or non-persistent drive
hgs
parents:
diff changeset
   361
    //      Create a private path in the system drive else use it
hgs
parents:
diff changeset
   362
    else if( err == KErrNone )
hgs
parents:
diff changeset
   363
        {
hgs
parents:
diff changeset
   364
        TDriveInfo driveInfo;
hgs
parents:
diff changeset
   365
        User::LeaveIfError( iFs.Drive(driveInfo));
hgs
parents:
diff changeset
   366
        TUint driveAttr = driveInfo.iDriveAtt;
hgs
parents:
diff changeset
   367
        if ( driveAttr == KDriveAttRom )
hgs
parents:
diff changeset
   368
            {
hgs
parents:
diff changeset
   369
            User::LeaveIfError( iFs.CreatePrivatePath(drive) );
hgs
parents:
diff changeset
   370
            }
hgs
parents:
diff changeset
   371
        }
hgs
parents:
diff changeset
   372
    else
hgs
parents:
diff changeset
   373
        {
hgs
parents:
diff changeset
   374
        OstTrace1( TRACE_ERROR, CUPNPTMSERVERDEVICEXMLPARSER_STARTL, "CUpnpTmServerDeviceXmlParser::StartL;err=%d", err );     
hgs
parents:
diff changeset
   375
        User::Leave(err);
hgs
parents:
diff changeset
   376
        }
hgs
parents:
diff changeset
   377
    privatePath.Append(KPublicDevicePath());
hgs
parents:
diff changeset
   378
    err = iFs.MkDirAll(privatePath);
hgs
parents:
diff changeset
   379
    if( err && err != KErrAlreadyExists )
hgs
parents:
diff changeset
   380
        {
hgs
parents:
diff changeset
   381
        OstTrace1( TRACE_ERROR, DUP1_CUPNPTMSERVERDEVICEXMLPARSER_STARTL, "CUpnpTmServerDeviceXmlParser::StartL;err=%d", err );
hgs
parents:
diff changeset
   382
        User::LeaveIfError(err);
hgs
parents:
diff changeset
   383
        }
hgs
parents:
diff changeset
   384
    iDeviceDir.CreateL(privatePath);
hgs
parents:
diff changeset
   385
    RBuf8 rootDeviceBuf;
hgs
parents:
diff changeset
   386
    CleanupClosePushL(rootDeviceBuf);
hgs
parents:
diff changeset
   387
    rootDeviceBuf.CreateL(KBufSize);
hgs
parents:
diff changeset
   388
    rootDeviceBuf.Append(KRootDeviceXmlLead());
hgs
parents:
diff changeset
   389
    // Appends the device icon list to the device xml buffer
hgs
parents:
diff changeset
   390
    const RPointerArray<CUpnpTerminalModeIcon>& deviceList = iDeviceInfo.DeviceIconList();
hgs
parents:
diff changeset
   391
    TInt iconCount = deviceList.Count();
hgs
parents:
diff changeset
   392
    if ( iconCount > KErrNone )
hgs
parents:
diff changeset
   393
        {
hgs
parents:
diff changeset
   394
        privatePath.Append(KIconDirectory());
hgs
parents:
diff changeset
   395
        err = iFs.MkDir(privatePath);  // Creates icon directory 
hgs
parents:
diff changeset
   396
        if( err && err != KErrAlreadyExists )
hgs
parents:
diff changeset
   397
            {
hgs
parents:
diff changeset
   398
            OstTrace1( TRACE_ERROR, DUP2_CUPNPTMSERVERDEVICEXMLPARSER_STARTL, "CUpnpTmServerDeviceXmlParser::StartL;err=%d", err );
hgs
parents:
diff changeset
   399
            User::LeaveIfError(err);
hgs
parents:
diff changeset
   400
            }
hgs
parents:
diff changeset
   401
        iIconDirectory.CreateL(privatePath);
hgs
parents:
diff changeset
   402
        OstTrace1( TRACE_ERROR, DUP3_CUPNPTMSERVERDEVICEXMLPARSER_STARTL, "CUpnpTmServerDeviceXmlParser::StartL;iconCount=%d", iconCount );
hgs
parents:
diff changeset
   403
        rootDeviceBuf.Append(KStartIconList);
hgs
parents:
diff changeset
   404
        for ( TInt i(0); i < iconCount; i++ )
hgs
parents:
diff changeset
   405
            {
hgs
parents:
diff changeset
   406
            rootDeviceBuf.Append(KStartIcon);
hgs
parents:
diff changeset
   407
            rootDeviceBuf.Append(KStartMimeType);
hgs
parents:
diff changeset
   408
            rootDeviceBuf.Append(deviceList[i]->MimeType());
hgs
parents:
diff changeset
   409
            rootDeviceBuf.Append(KEndMimeType);
hgs
parents:
diff changeset
   410
            rootDeviceBuf.Append(KStartWidth);
hgs
parents:
diff changeset
   411
            rootDeviceBuf.AppendNum(deviceList[i]->Width());
hgs
parents:
diff changeset
   412
            rootDeviceBuf.Append(KEndWidth);
hgs
parents:
diff changeset
   413
            rootDeviceBuf.Append(KStartHeight);
hgs
parents:
diff changeset
   414
            rootDeviceBuf.AppendNum(deviceList[i]->Height());
hgs
parents:
diff changeset
   415
            rootDeviceBuf.Append(KEndHeight);
hgs
parents:
diff changeset
   416
            rootDeviceBuf.Append(KStartDepth);
hgs
parents:
diff changeset
   417
            rootDeviceBuf.AppendNum(deviceList[i]->Depth());
hgs
parents:
diff changeset
   418
            rootDeviceBuf.Append(KEndDepth);
hgs
parents:
diff changeset
   419
            rootDeviceBuf.Append(KStartUrl);
hgs
parents:
diff changeset
   420
            
hgs
parents:
diff changeset
   421
            TBuf8<KMaxPath> iconBuf;
hgs
parents:
diff changeset
   422
            const TDesC& fileName = deviceList[i]->IconFilename();
hgs
parents:
diff changeset
   423
            iconBuf.Copy(fileName);
hgs
parents:
diff changeset
   424
            TBuf8<UpnpString::KDefaultStringLength> iconRelativeUrl(KScpdUrl());
hgs
parents:
diff changeset
   425
            // Extracts the actual input filepath and creates the relative url for the icon
hgs
parents:
diff changeset
   426
            // to be provided in the device xml file
hgs
parents:
diff changeset
   427
            iconRelativeUrl.Append(KIconPath());
hgs
parents:
diff changeset
   428
            // Extracts only filename and appends the same to url
hgs
parents:
diff changeset
   429
            iconRelativeUrl.Append(iconBuf.Mid((iconBuf.LocateReverse(KDirectorySeparator))+1));
hgs
parents:
diff changeset
   430
            rootDeviceBuf.Append(iconRelativeUrl);
hgs
parents:
diff changeset
   431
            delete iFileMan;
hgs
parents:
diff changeset
   432
            iFileMan = NULL;
hgs
parents:
diff changeset
   433
            iFileMan = CFileMan::NewL(iFs) ;
hgs
parents:
diff changeset
   434
            // copies icon files to the private device directory
hgs
parents:
diff changeset
   435
            User::LeaveIfError(iFileMan->Copy(fileName,iIconDirectory));  
hgs
parents:
diff changeset
   436
            rootDeviceBuf.Append(KEndUrl);
hgs
parents:
diff changeset
   437
            rootDeviceBuf.Append(KEndIcon);
hgs
parents:
diff changeset
   438
            }
hgs
parents:
diff changeset
   439
        rootDeviceBuf.Append(KEndIconList);
hgs
parents:
diff changeset
   440
        }
hgs
parents:
diff changeset
   441
    rootDeviceBuf.Append( iDeviceInfo.DeviceInfo());
hgs
parents:
diff changeset
   442
    rootDeviceBuf.Append( KRootDeviceXmlTrail() );
hgs
parents:
diff changeset
   443
       
hgs
parents:
diff changeset
   444
	ParseL(*iParser, rootDeviceBuf );
hgs
parents:
diff changeset
   445
	CleanupStack::PopAndDestroy(&rootDeviceBuf);
hgs
parents:
diff changeset
   446
hgs
parents:
diff changeset
   447
	OstTraceFunctionExit0( CUPNPTMSERVERDEVICEXMLPARSER_STARTL_EXIT );
hgs
parents:
diff changeset
   448
	}
hgs
parents:
diff changeset
   449
hgs
parents:
diff changeset
   450
// ---------------------------------------------------------------------------------
hgs
parents:
diff changeset
   451
// CUpnpTmServerDeviceXmlParser::OnStartPrefixMappingL
hgs
parents:
diff changeset
   452
// ---------------------------------------------------------------------------------
hgs
parents:
diff changeset
   453
//  
hgs
parents:
diff changeset
   454
void CUpnpTmServerDeviceXmlParser::OnStartPrefixMappingL(const RString& /*aPrefix*/, const RString& /*aUri*/, TInt aErrorCode)
hgs
parents:
diff changeset
   455
    {
hgs
parents:
diff changeset
   456
    OstTraceFunctionEntry0( CUPNPTMSERVERDEVICEXMLPARSER_ONSTARTPREFIXMAPPINGL_ENTRY );
hgs
parents:
diff changeset
   457
    User::LeaveIfError(aErrorCode);
hgs
parents:
diff changeset
   458
    OstTraceFunctionExit0( CUPNPTMSERVERDEVICEXMLPARSER_ONSTARTPREFIXMAPPINGL_EXIT );
hgs
parents:
diff changeset
   459
    }
hgs
parents:
diff changeset
   460
hgs
parents:
diff changeset
   461
// ---------------------------------------------------------------------------------
hgs
parents:
diff changeset
   462
// CUpnpTmServerDeviceXmlParser::OnEndPrefixMappingL
hgs
parents:
diff changeset
   463
// ---------------------------------------------------------------------------------
hgs
parents:
diff changeset
   464
// 
hgs
parents:
diff changeset
   465
void CUpnpTmServerDeviceXmlParser::OnEndPrefixMappingL(const RString& /*aPrefix*/, TInt aErrorCode)
hgs
parents:
diff changeset
   466
    {
hgs
parents:
diff changeset
   467
    OstTraceFunctionEntry0( CUPNPTMSERVERDEVICEXMLPARSER_ONENDPREFIXMAPPINGL_ENTRY );
hgs
parents:
diff changeset
   468
    User::LeaveIfError(aErrorCode);
hgs
parents:
diff changeset
   469
    OstTraceFunctionExit0( CUPNPTMSERVERDEVICEXMLPARSER_ONENDPREFIXMAPPINGL_EXIT );
hgs
parents:
diff changeset
   470
    }
hgs
parents:
diff changeset
   471
hgs
parents:
diff changeset
   472
// ---------------------------------------------------------------------------------
hgs
parents:
diff changeset
   473
// CUpnpTmServerDeviceXmlParser::OnIgnorableWhiteSpaceL
hgs
parents:
diff changeset
   474
// ---------------------------------------------------------------------------------
hgs
parents:
diff changeset
   475
// 
hgs
parents:
diff changeset
   476
void CUpnpTmServerDeviceXmlParser::OnIgnorableWhiteSpaceL(const TDesC8& /*aBytes*/, TInt aErrorCode)
hgs
parents:
diff changeset
   477
    {
hgs
parents:
diff changeset
   478
    OstTraceFunctionEntry0( CUPNPTMSERVERDEVICEXMLPARSER_ONIGNORABLEWHITESPACEL_ENTRY );
hgs
parents:
diff changeset
   479
    User::LeaveIfError(aErrorCode);
hgs
parents:
diff changeset
   480
    OstTraceFunctionExit0( CUPNPTMSERVERDEVICEXMLPARSER_ONIGNORABLEWHITESPACEL_EXIT );
hgs
parents:
diff changeset
   481
    }
hgs
parents:
diff changeset
   482
hgs
parents:
diff changeset
   483
// ---------------------------------------------------------------------------------
hgs
parents:
diff changeset
   484
// CUpnpTmServerDeviceXmlParser::OnSkippedEntityL
hgs
parents:
diff changeset
   485
// ---------------------------------------------------------------------------------
hgs
parents:
diff changeset
   486
// 
hgs
parents:
diff changeset
   487
void CUpnpTmServerDeviceXmlParser::OnSkippedEntityL(const RString& /*aName*/, TInt aErrorCode)
hgs
parents:
diff changeset
   488
    {
hgs
parents:
diff changeset
   489
    OstTraceFunctionEntry0( CUPNPTMSERVERDEVICEXMLPARSER_ONSKIPPEDENTITYL_ENTRY );
hgs
parents:
diff changeset
   490
    User::LeaveIfError(aErrorCode);
hgs
parents:
diff changeset
   491
    OstTraceFunctionExit0( CUPNPTMSERVERDEVICEXMLPARSER_ONSKIPPEDENTITYL_EXIT );
hgs
parents:
diff changeset
   492
    }
hgs
parents:
diff changeset
   493
hgs
parents:
diff changeset
   494
// ---------------------------------------------------------------------------------
hgs
parents:
diff changeset
   495
// CUpnpTmServerDeviceXmlParser::OnProcessingInstructionL
hgs
parents:
diff changeset
   496
// ---------------------------------------------------------------------------------
hgs
parents:
diff changeset
   497
// 
hgs
parents:
diff changeset
   498
void CUpnpTmServerDeviceXmlParser::OnProcessingInstructionL(const TDesC8& /*aTarget*/, const TDesC8& /*aData*/, TInt aErrorCode)
hgs
parents:
diff changeset
   499
    {
hgs
parents:
diff changeset
   500
    OstTraceFunctionEntry0( CUPNPTMSERVERDEVICEXMLPARSER_ONPROCESSINGINSTRUCTIONL_ENTRY );
hgs
parents:
diff changeset
   501
    User::LeaveIfError(aErrorCode);
hgs
parents:
diff changeset
   502
    OstTraceFunctionExit0( CUPNPTMSERVERDEVICEXMLPARSER_ONPROCESSINGINSTRUCTIONL_EXIT );
hgs
parents:
diff changeset
   503
    }
hgs
parents:
diff changeset
   504
hgs
parents:
diff changeset
   505