epoc32/include/bsul/inifile.h
author William Roberts <williamr@symbian.org>
Wed, 31 Mar 2010 12:33:34 +0100
branchSymbian3
changeset 4 837f303aceeb
permissions -rw-r--r--
Current Symbian^3 public API header files (from PDK 3.0.h)
This is the epoc32/include tree with the "platform" subtrees removed, and
all but a selected few mbg and rsg files removed.
williamr@4
     1
// Copyright (c) 2005-2009 Nokia Corporation and/or its subsidiary(-ies).
williamr@4
     2
// All rights reserved.
williamr@4
     3
// This component and the accompanying materials are made available
williamr@4
     4
// under the terms of "Eclipse Public License v1.0"
williamr@4
     5
// which accompanies this distribution, and is available
williamr@4
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
williamr@4
     7
//
williamr@4
     8
// Initial Contributors:
williamr@4
     9
// Nokia Corporation - initial contribution.
williamr@4
    10
//
williamr@4
    11
// Contributors:
williamr@4
    12
//
williamr@4
    13
// Description:
williamr@4
    14
// Ini file parser header file
williamr@4
    15
// 
williamr@4
    16
//
williamr@4
    17
williamr@4
    18
/**
williamr@4
    19
 @file
williamr@4
    20
 @internalAll
williamr@4
    21
*/
williamr@4
    22
williamr@4
    23
#ifndef __INIFILE_H__
williamr@4
    24
#define __INIFILE_H__
williamr@4
    25
williamr@4
    26
#include <e32std.h>
williamr@4
    27
#include <e32base.h>
williamr@4
    28
williamr@4
    29
//Forward declaration
williamr@4
    30
class RFs;
williamr@4
    31
williamr@4
    32
namespace BSUL
williamr@4
    33
	{
williamr@4
    34
williamr@4
    35
class CIniDocument8;
williamr@4
    36
class CIniDocument16;
williamr@4
    37
williamr@4
    38
class CIniSecIter8Impl;
williamr@4
    39
/** 
williamr@4
    40
Section iterator for 8 bit ini file. This class provides an iterator
williamr@4
    41
to navigate through the settings within a section inside an 8 bit ini file.
williamr@4
    42
*/
williamr@4
    43
NONSHARABLE_CLASS(CIniSecIter8): public CBase
williamr@4
    44
{
williamr@4
    45
public:
williamr@4
    46
	IMPORT_C static CIniSecIter8* NewL(const TDesC8& aSectionName,const CIniDocument8* aIniDocument);
williamr@4
    47
	IMPORT_C ~CIniSecIter8();
williamr@4
    48
		
williamr@4
    49
	IMPORT_C TBool Next(TPtrC8& aKey,TPtrC8& aValue);
williamr@4
    50
	IMPORT_C TBool End();
williamr@4
    51
	IMPORT_C void Reset();
williamr@4
    52
private:
williamr@4
    53
	CIniSecIter8();
williamr@4
    54
	CIniSecIter8Impl* iImpl;
williamr@4
    55
};
williamr@4
    56
williamr@4
    57
class CIniDocument8Impl;
williamr@4
    58
/**
williamr@4
    59
Dom parser for 8 bit ini file. This class provides the functionality to read
williamr@4
    60
and write settings of an 8 bit ini file.
williamr@4
    61
*/
williamr@4
    62
NONSHARABLE_CLASS(CIniDocument8): public CBase
williamr@4
    63
{
williamr@4
    64
public:
williamr@4
    65
	IMPORT_C static CIniDocument8* NewL(RFs& aFs,const TDesC& aFileName);
williamr@4
    66
	IMPORT_C ~CIniDocument8();
williamr@4
    67
	IMPORT_C TInt Externalise(const TDesC& aFileName);
williamr@4
    68
williamr@4
    69
	//read api
williamr@4
    70
	IMPORT_C TInt GetSectionList(RArray<TPtrC8>& aSectionList) const;
williamr@4
    71
	IMPORT_C TInt GetKeyValue(const TDesC8& aSectionName,const TDesC8& aKey,TPtrC8& aValue) const;
williamr@4
    72
williamr@4
    73
	//write api
williamr@4
    74
	IMPORT_C TInt AddSection(const TDesC8& aSectionName);
williamr@4
    75
	IMPORT_C TInt RemoveSection(const TDesC8& aSectionName);
williamr@4
    76
	IMPORT_C TInt SetKey(const TDesC8& aSectionName,const TDesC8& aKey,const TDesC8& aValue);
williamr@4
    77
	IMPORT_C TInt RemoveKey(const TDesC8& aSectionName,const TDesC8& aKey);
williamr@4
    78
	IMPORT_C TBool CompareDocs(CIniDocument8& aDoc);
williamr@4
    79
private:
williamr@4
    80
	friend class CIniSecIter8Impl;
williamr@4
    81
	CIniDocument8();
williamr@4
    82
	CIniDocument8Impl* iImpl;
williamr@4
    83
};
williamr@4
    84
williamr@4
    85
class CIniSecIter16Impl;
williamr@4
    86
/** 
williamr@4
    87
Section iterator for 16 bit ini file. This class provides an iterator
williamr@4
    88
to navigate through the settings within a section inside an 16 bit ini file.
williamr@4
    89
*/
williamr@4
    90
NONSHARABLE_CLASS(CIniSecIter16): public CBase
williamr@4
    91
{
williamr@4
    92
public:
williamr@4
    93
	IMPORT_C static CIniSecIter16* NewL(const TDesC16& aSectionName,const CIniDocument16* aIniDocument);
williamr@4
    94
	IMPORT_C ~CIniSecIter16();
williamr@4
    95
		
williamr@4
    96
	IMPORT_C TBool Next(TPtrC16& aKey,TPtrC16& aValue);
williamr@4
    97
	IMPORT_C TBool End();
williamr@4
    98
	IMPORT_C void Reset();
williamr@4
    99
private:
williamr@4
   100
	CIniSecIter16();
williamr@4
   101
	CIniSecIter16Impl* iImpl;
williamr@4
   102
};
williamr@4
   103
williamr@4
   104
class CIniDocument16Impl;
williamr@4
   105
/**
williamr@4
   106
Dom parser for 16 bit ini file. This class provides the functionality to read
williamr@4
   107
and write settings of an 16 bit ini file.
williamr@4
   108
*/
williamr@4
   109
NONSHARABLE_CLASS(CIniDocument16): public CBase
williamr@4
   110
{
williamr@4
   111
public:
williamr@4
   112
	IMPORT_C static CIniDocument16* NewL(RFs& aFs,const TDesC& aFileName);
williamr@4
   113
	IMPORT_C ~CIniDocument16();
williamr@4
   114
	IMPORT_C TInt Externalise(const TDesC& aFileName);
williamr@4
   115
williamr@4
   116
	//read api
williamr@4
   117
	IMPORT_C TInt GetSectionList(RArray<TPtrC16>& aSectionList) const;
williamr@4
   118
	IMPORT_C TInt GetKeyValue(const TDesC16& aSectionName,const TDesC16& aKey,TPtrC16& aValue) const;
williamr@4
   119
williamr@4
   120
	//write api
williamr@4
   121
	IMPORT_C TInt AddSection(const TDesC16& aSectionName);
williamr@4
   122
	IMPORT_C TInt RemoveSection(const TDesC16& aSectionName);
williamr@4
   123
	IMPORT_C TInt SetKey(const TDesC16& aSectionName,const TDesC16& aKey,const TDesC16& aValue);
williamr@4
   124
	IMPORT_C TInt RemoveKey(const TDesC16& aSectionName,const TDesC16& aKey);
williamr@4
   125
	IMPORT_C TBool CompareDocs(CIniDocument16& aDoc);
williamr@4
   126
private:
williamr@4
   127
	friend class CIniSecIter16Impl;
williamr@4
   128
	CIniDocument16();
williamr@4
   129
	CIniDocument16Impl* iImpl;
williamr@4
   130
};
williamr@4
   131
williamr@4
   132
class CIniFile8Impl;
williamr@4
   133
/**
williamr@4
   134
A light weight parser for reading setting values from an 8 bit ini file. Note that this does not 
williamr@4
   135
guarantee checking that the ini file is wellformed. See CIniFile16 for a class that handles both 
williamr@4
   136
8 and 16 bit files.  
williamr@4
   137
*/
williamr@4
   138
NONSHARABLE_CLASS(CIniFile8): public CBase
williamr@4
   139
{
williamr@4
   140
public:
williamr@4
   141
	IMPORT_C static CIniFile8* NewL(RFs& aFs,const TDesC& aFileName);
williamr@4
   142
	IMPORT_C ~CIniFile8();
williamr@4
   143
	IMPORT_C TInt FindVar(const TDesC8& aSectionName,const TDesC8& aKeyName,TPtrC8& aValue)	const;
williamr@4
   144
private:
williamr@4
   145
	CIniFile8();
williamr@4
   146
	CIniFile8Impl* iImpl;
williamr@4
   147
};
williamr@4
   148
williamr@4
   149
class CIniFile16Impl;
williamr@4
   150
/**
williamr@4
   151
A light weight parser for reading setting values from a 16 or 8 bit ini file. The aConvert8To16
williamr@4
   152
parameter of NewL controls whether or not 8 bit files are accepted. Note that this does
williamr@4
   153
not guarantee checking that the ini file is wellformed.
williamr@4
   154
*/
williamr@4
   155
NONSHARABLE_CLASS(CIniFile16): public CBase
williamr@4
   156
{
williamr@4
   157
public:
williamr@4
   158
	IMPORT_C static CIniFile16* NewL(RFs& aFs,const TDesC& aFileName);
williamr@4
   159
	IMPORT_C static CIniFile16* NewL(RFs& aFs,const TDesC& aFileName,TBool aConvert8To16);
williamr@4
   160
	IMPORT_C ~CIniFile16();
williamr@4
   161
	IMPORT_C TInt FindVar(const TDesC16& aSectionName,const TDesC16& aKeyName,TPtrC16& aValue) const;
williamr@4
   162
private:
williamr@4
   163
	CIniFile16();
williamr@4
   164
	CIniFile16Impl* iImpl;
williamr@4
   165
};
williamr@4
   166
williamr@4
   167
}//namespace BSUL
williamr@4
   168
williamr@4
   169
#endif