mmserv/metadatautility/Src/MetaDataParserDcf.cpp
changeset 0 71ca22bcf22a
equal deleted inserted replaced
-1:000000000000 0:71ca22bcf22a
       
     1 /*
       
     2 * Copyright (c) 2004 Nokia Corporation and/or its subsidiary(-ies).
       
     3 * All rights reserved.
       
     4 * This component and the accompanying materials are made available
       
     5 * under the terms of "Eclipse Public License v1.0"
       
     6 * which accompanies this distribution, and is available
       
     7 * at the URL "http://www.eclipse.org/legal/epl-v10.html".
       
     8 *
       
     9 * Initial Contributors:
       
    10 * Nokia Corporation - initial contribution.
       
    11 *
       
    12 * Contributors:
       
    13 *
       
    14 * Description:  This class implements an 3gp metadata parser as specified in
       
    15 *                www.3gpp.org (specification 3GPP TS 26.244 V6.0.0).
       
    16 *
       
    17 */
       
    18 
       
    19 
       
    20 
       
    21 // INCLUDE FILES
       
    22 #include <Oma2Agent.h>
       
    23 #include	"MetaDataParserDcf.h"
       
    24 #ifdef _DEBUG
       
    25 #include	<e32svr.h>
       
    26 #endif
       
    27 
       
    28 // ============================ MEMBER FUNCTIONS ===============================
       
    29 
       
    30 // -----------------------------------------------------------------------------
       
    31 // CMetaDataParserDcf::CMetaDataParserDcf
       
    32 // C++ default constructor can NOT contain any code, that
       
    33 // might leave.
       
    34 // -----------------------------------------------------------------------------
       
    35 //
       
    36 CMetaDataParserDcf::CMetaDataParserDcf()
       
    37 	{
       
    38     }
       
    39 
       
    40 // -----------------------------------------------------------------------------
       
    41 // CMetaDataParserDcf::ConstructL
       
    42 // Symbian 2nd phase constructor can leave.
       
    43 // -----------------------------------------------------------------------------
       
    44 //
       
    45 void CMetaDataParserDcf::ConstructL()
       
    46     {
       
    47 	}
       
    48 
       
    49 // -----------------------------------------------------------------------------
       
    50 // CMetaDataParserDcf::NewL
       
    51 // Two-phased constructor.
       
    52 // -----------------------------------------------------------------------------
       
    53 //
       
    54 CMetaDataParserDcf* CMetaDataParserDcf::NewL()
       
    55     {
       
    56 #ifdef _DEBUG
       
    57 	RDebug::Print(_L("CMetaDataParserDcf::NewL"));
       
    58 #endif
       
    59 	CMetaDataParserDcf* self = new( ELeave ) CMetaDataParserDcf;
       
    60     CleanupStack::PushL( self );
       
    61     self->ConstructL();
       
    62     CleanupStack::Pop();
       
    63     return self;
       
    64     }
       
    65 
       
    66 // Destructor
       
    67 CMetaDataParserDcf::~CMetaDataParserDcf()
       
    68 	{
       
    69 	}
       
    70 
       
    71 // -----------------------------------------------------------------------------
       
    72 // CMetaDataParserDcf::ParseL
       
    73 // -----------------------------------------------------------------------------
       
    74 //
       
    75 void CMetaDataParserDcf::ParseL(
       
    76 	const RArray<TMetaDataFieldId>& aWantedFields,
       
    77 	CMetaDataFieldContainer& aContainer )
       
    78     {
       
    79 #ifdef _DEBUG
       
    80 	RDebug::Print(_L("CMetaDataParserDcf::ParseL"));
       
    81 #endif
       
    82 	iContainer = &aContainer;
       
    83 
       
    84 	if ( aWantedFields.Count() == 0 )
       
    85 		{
       
    86 		ReadMetaDataEntryL(ContentAccess::ETitle, EMetaDataSongTitle);
       
    87 		ReadMetaDataEntryL(ContentAccess::EDescription, EMetaDataComment);
       
    88 		ReadMetaDataEntryL(ContentAccess::EAuthor, EMetaDataComposer);
       
    89 		ReadMetaDataEntryL(ContentAccess::EContentURI, EMetaDataUrl);
       
    90 		ReadMetaDataEntryL(EPerformer, EMetaDataArtist);
       
    91 		ReadMetaDataEntryL(EAlbumTitle, EMetaDataAlbum);
       
    92 		ReadMetaDataEntryL(EAlbumTrack, EMetaDataAlbumTrack);
       
    93 		ReadMetaDataEntryL(EContentVendor, EMetaDataVendor);
       
    94 		ReadMetaDataEntryL(ECopyright, EMetaDataCopyright);
       
    95 		ReadMetaDataEntryL(EGenre, EMetaDataGenre);
       
    96 		ReadMetaDataEntryL(ERatingInfo, EMetaDataRating);
       
    97 		}
       
    98 	else
       
    99 		{
       
   100 		// Look for it in the wanted field array
       
   101 		TInt count( aWantedFields.Count() );
       
   102 		for ( TInt i = 0; i < count; i++ )
       
   103 			{
       
   104 			switch ( aWantedFields[ i ] )
       
   105 				{
       
   106 				case EMetaDataSongTitle:
       
   107 					ReadMetaDataEntryL(ContentAccess::ETitle, EMetaDataSongTitle);
       
   108 					break;
       
   109 				case EMetaDataComment:
       
   110 					ReadMetaDataEntryL(ContentAccess::EDescription, EMetaDataComment);
       
   111 					break;
       
   112 				case EMetaDataComposer:
       
   113 					ReadMetaDataEntryL(ContentAccess::EAuthor, EMetaDataComposer);
       
   114 				    break;
       
   115 				case EMetaDataUrl:
       
   116                     ReadMetaDataEntryL(ContentAccess::EContentURI, EMetaDataUrl);
       
   117 					break;
       
   118 				case EMetaDataArtist:
       
   119                     ReadMetaDataEntryL(EPerformer, EMetaDataArtist);
       
   120 					break;
       
   121 				case EMetaDataAlbum:
       
   122                     ReadMetaDataEntryL(EAlbumTitle, EMetaDataAlbum);
       
   123 					break;
       
   124 				case EMetaDataAlbumTrack:
       
   125                     ReadMetaDataEntryL(EAlbumTrack, EMetaDataAlbumTrack);
       
   126 					break;
       
   127 				case EMetaDataVendor:
       
   128 					ReadMetaDataEntryL(EContentVendor, EMetaDataVendor);
       
   129 					break;
       
   130 				case EMetaDataCopyright:
       
   131 					ReadMetaDataEntryL(ECopyright, EMetaDataCopyright);
       
   132 					break;
       
   133 				case EMetaDataGenre:
       
   134                     ReadMetaDataEntryL(EGenre, EMetaDataGenre);
       
   135 					break;
       
   136 				case EMetaDataRating:
       
   137                     ReadMetaDataEntryL(ERatingInfo, EMetaDataRating);
       
   138 					break;
       
   139 				default:
       
   140 					break;
       
   141 				}
       
   142 			}
       
   143 		}
       
   144  	}
       
   145 
       
   146 // -----------------------------------------------------------------------------
       
   147 // CMetaDataParserDcf::InitializeFileL
       
   148 // Symbian 2nd phase constructor can leave.
       
   149 // -----------------------------------------------------------------------------
       
   150 //
       
   151 void CMetaDataParserDcf::InitializeFileL(CMetaDataSource* aSource)
       
   152     {
       
   153 #ifdef _DEBUG
       
   154 	RDebug::Print(_L("CMetaDataParserDcf::InitializeFileL"));
       
   155 #endif
       
   156 	iSource = aSource;
       
   157 	ValidateL();
       
   158 #ifdef _DEBUG
       
   159 	RDebug::Print(_L("CMetaDataParserDcf::InitializeFileL - Done"));
       
   160 #endif
       
   161     }
       
   162 
       
   163 // -----------------------------------------------------------------------------
       
   164 // CMetaDataParserDcf::ValidateL
       
   165 // -----------------------------------------------------------------------------
       
   166 //
       
   167 TBool CMetaDataParserDcf::ValidateL()
       
   168 	{
       
   169 	iExists = ETrue;
       
   170 	return ETrue;
       
   171 	}
       
   172 
       
   173 void CMetaDataParserDcf::ReadMetaDataEntryL(TInt aEntryName, 
       
   174 	TMetaDataFieldId aFieldId)
       
   175 	{
       
   176 	TInt err = KErrNone;
       
   177 	TBuf <256> headerValue;
       
   178 	err = ((CMetaDataSourceFile*)iSource)->GetStringAttribute(aEntryName, headerValue);
       
   179 
       
   180 	if(err != KErrNone)
       
   181 		{
       
   182 		return;
       
   183 		}
       
   184 	TPtrC info = StripTrailingZeroes(headerValue);
       
   185 	if(info.Length() > 0)
       
   186 		{
       
   187 		iContainer->AppendL( aFieldId, info );
       
   188 		}
       
   189 }
       
   190 
       
   191 //  End of File