telutils/phoneparser/inc/cphonegsmphonenumberparser.h
author hgs
Mon, 23 Aug 2010 15:50:31 +0300
changeset 42 35488577e233
parent 33 8d5d7fcf9b59
permissions -rw-r--r--
201033
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
33
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2002-2009 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:  It is parser for phone numbers.
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
hgs
parents:
diff changeset
    19
#ifndef CPHONEGSMPHONENUMBERPARSER_H
hgs
parents:
diff changeset
    20
#define CPHONEGSMPHONENUMBERPARSER_H
hgs
parents:
diff changeset
    21
hgs
parents:
diff changeset
    22
// INCLUDES
hgs
parents:
diff changeset
    23
#include    "cphonegsmparserbase.h" 
hgs
parents:
diff changeset
    24
hgs
parents:
diff changeset
    25
// FORWARD DECLARATIONS
hgs
parents:
diff changeset
    26
class CPhoneGsmOptionContainer;
hgs
parents:
diff changeset
    27
// CONSTANTS
hgs
parents:
diff changeset
    28
hgs
parents:
diff changeset
    29
/*
hgs
parents:
diff changeset
    30
* PHONE NUMBER UIDS
hgs
parents:
diff changeset
    31
*/
hgs
parents:
diff changeset
    32
hgs
parents:
diff changeset
    33
const TUint32 KPhoneUidPhoneNumber = 
hgs
parents:
diff changeset
    34
    PHONE_MAKE_UID( KPhoneGsmUidDialPhoneNumber, 0 );
hgs
parents:
diff changeset
    35
hgs
parents:
diff changeset
    36
/*
hgs
parents:
diff changeset
    37
* Dial phone number related constants, store to aux information field.
hgs
parents:
diff changeset
    38
*/
hgs
parents:
diff changeset
    39
hgs
parents:
diff changeset
    40
/*
hgs
parents:
diff changeset
    41
* There was no prefix, use default clir.
hgs
parents:
diff changeset
    42
*/
hgs
parents:
diff changeset
    43
const TUint KPhoneDialDefaultClir = 0;
hgs
parents:
diff changeset
    44
hgs
parents:
diff changeset
    45
/*
hgs
parents:
diff changeset
    46
* There was clir suppress prefix.
hgs
parents:
diff changeset
    47
*/
hgs
parents:
diff changeset
    48
const TUint KPhoneDialSuppressClir = 1;
hgs
parents:
diff changeset
    49
hgs
parents:
diff changeset
    50
/*
hgs
parents:
diff changeset
    51
* There was clir invoke prefix.
hgs
parents:
diff changeset
    52
*/
hgs
parents:
diff changeset
    53
const TUint KPhoneDialInvokeClir = 2;
hgs
parents:
diff changeset
    54
hgs
parents:
diff changeset
    55
// CLASS DECLARATION
hgs
parents:
diff changeset
    56
hgs
parents:
diff changeset
    57
/**
hgs
parents:
diff changeset
    58
* It is parser for phone numbers.
hgs
parents:
diff changeset
    59
*
hgs
parents:
diff changeset
    60
* @since 1.0
hgs
parents:
diff changeset
    61
* @lib phoneparser.lib
hgs
parents:
diff changeset
    62
*/
hgs
parents:
diff changeset
    63
NONSHARABLE_CLASS( CPhoneGsmPhoneNumberParser )
hgs
parents:
diff changeset
    64
    : public CPhoneGsmParserBase
hgs
parents:
diff changeset
    65
    {
hgs
parents:
diff changeset
    66
    public:  // Constructors and destructor      
hgs
parents:
diff changeset
    67
        
hgs
parents:
diff changeset
    68
        /**
hgs
parents:
diff changeset
    69
        * Two-phased constructor.
hgs
parents:
diff changeset
    70
        */
hgs
parents:
diff changeset
    71
        static CPhoneGsmPhoneNumberParser* NewLC();
hgs
parents:
diff changeset
    72
hgs
parents:
diff changeset
    73
    public: // Functions from base classes
hgs
parents:
diff changeset
    74
hgs
parents:
diff changeset
    75
        /**
hgs
parents:
diff changeset
    76
        * From CPhoneGsmParserBase.
hgs
parents:
diff changeset
    77
        * Parse string.
hgs
parents:
diff changeset
    78
        *
hgs
parents:
diff changeset
    79
        * @param aString It is string to be parsed.
hgs
parents:
diff changeset
    80
        * @param aResult It will contain result.
hgs
parents:
diff changeset
    81
        * @param aOptionUid It is the uid of the option.
hgs
parents:
diff changeset
    82
        * @return It returns boolean value indicating success of parsing.
hgs
parents:
diff changeset
    83
        */
hgs
parents:
diff changeset
    84
        TBool ParseL( 
hgs
parents:
diff changeset
    85
            const TDesC& aString,
hgs
parents:
diff changeset
    86
            CPhoneGsmParserResult& aResult,
hgs
parents:
diff changeset
    87
            CPhoneGsmOptionContainerBase& aOptions );
hgs
parents:
diff changeset
    88
            
hgs
parents:
diff changeset
    89
    private:
hgs
parents:
diff changeset
    90
hgs
parents:
diff changeset
    91
        /**
hgs
parents:
diff changeset
    92
        * C++ default constructor.
hgs
parents:
diff changeset
    93
        */
hgs
parents:
diff changeset
    94
        CPhoneGsmPhoneNumberParser();
hgs
parents:
diff changeset
    95
hgs
parents:
diff changeset
    96
        /**
hgs
parents:
diff changeset
    97
        * Parse.
hgs
parents:
diff changeset
    98
        * 
hgs
parents:
diff changeset
    99
        * @param aString It is string to be parsed.
hgs
parents:
diff changeset
   100
        * @param aResult It will contain result.
hgs
parents:
diff changeset
   101
        * @param aOptionUid It is the uid of the option.
hgs
parents:
diff changeset
   102
        * @return It returns boolean value indicating success of parsing.
hgs
parents:
diff changeset
   103
        */
hgs
parents:
diff changeset
   104
        TBool DoParseL( 
hgs
parents:
diff changeset
   105
            const TDesC& aString,
hgs
parents:
diff changeset
   106
            CPhoneGsmParserResult& aResult,
hgs
parents:
diff changeset
   107
            CPhoneGsmOptionContainer& aOptions );
hgs
parents:
diff changeset
   108
hgs
parents:
diff changeset
   109
hgs
parents:
diff changeset
   110
        /**
hgs
parents:
diff changeset
   111
        * Handle supplementary service prefixes.
hgs
parents:
diff changeset
   112
        * Checks is there clir suppress/invoke prefix in the string.
hgs
parents:
diff changeset
   113
        * @param aLex Contains string to be handled.
hgs
parents:
diff changeset
   114
        * @param aResult It will contain result.
hgs
parents:
diff changeset
   115
        */
hgs
parents:
diff changeset
   116
        TBool HandleServicePrefix( 
hgs
parents:
diff changeset
   117
            TLex& aLex, 
hgs
parents:
diff changeset
   118
            CPhoneGsmParserResult& aResult );
hgs
parents:
diff changeset
   119
hgs
parents:
diff changeset
   120
        /**
hgs
parents:
diff changeset
   121
        * Takes a main part of the phone number( before 'p','w' or 
hgs
parents:
diff changeset
   122
        * second '+' marks ). 
hgs
parents:
diff changeset
   123
        * And add it to parameter of the aResult with or without optional 
hgs
parents:
diff changeset
   124
        * international prefix.
hgs
parents:
diff changeset
   125
        * @param aLex Contains string to be handled.
hgs
parents:
diff changeset
   126
        * @param aResult It will contain result.
hgs
parents:
diff changeset
   127
        */
hgs
parents:
diff changeset
   128
        TBool TakeNumberPartL(
hgs
parents:
diff changeset
   129
            TLex& aLex,
hgs
parents:
diff changeset
   130
            CPhoneGsmParserResult& aResult );
hgs
parents:
diff changeset
   131
hgs
parents:
diff changeset
   132
        /**
hgs
parents:
diff changeset
   133
        * Takes Dtmf postfix and add it to parameter of the aResult.
hgs
parents:
diff changeset
   134
        * @param aLex Contains string to be handled.
hgs
parents:
diff changeset
   135
        * @param aResult It will contain result.
hgs
parents:
diff changeset
   136
        */
hgs
parents:
diff changeset
   137
        TBool TakeDtmfPostfixL(
hgs
parents:
diff changeset
   138
            TLex& aLex,
hgs
parents:
diff changeset
   139
            CPhoneGsmParserResult& aResult );
hgs
parents:
diff changeset
   140
hgs
parents:
diff changeset
   141
        /**
hgs
parents:
diff changeset
   142
        * Checks if param aLeft is prefix of param aDest.
hgs
parents:
diff changeset
   143
        */
hgs
parents:
diff changeset
   144
        static TBool EqualsLeft( const TDesC& aDest, const TDesC& aLeft );
hgs
parents:
diff changeset
   145
hgs
parents:
diff changeset
   146
        /**
hgs
parents:
diff changeset
   147
        * Checks if string contains p or w characters.
hgs
parents:
diff changeset
   148
        *
hgs
parents:
diff changeset
   149
        * @param aString It is string to be checked.
hgs
parents:
diff changeset
   150
        * @return ETrue if string contains p or w characters.
hgs
parents:
diff changeset
   151
        */
hgs
parents:
diff changeset
   152
        TBool ContainsPauseOrWaitChars( const TDesC& aString ) const;
hgs
parents:
diff changeset
   153
hgs
parents:
diff changeset
   154
        /**
hgs
parents:
diff changeset
   155
        * Checks if rightmost character in string is #.
hgs
parents:
diff changeset
   156
        *
hgs
parents:
diff changeset
   157
        * @param aString It is string to be checked.
hgs
parents:
diff changeset
   158
        * @return ETrue if string is hash string.
hgs
parents:
diff changeset
   159
        */
hgs
parents:
diff changeset
   160
        TBool IsHashString( const TDesC& aString ) const;
hgs
parents:
diff changeset
   161
hgs
parents:
diff changeset
   162
        /**
hgs
parents:
diff changeset
   163
        * Checks if string is zero and zero dialling is on and
hgs
parents:
diff changeset
   164
        * it is not in call situation.
hgs
parents:
diff changeset
   165
        *
hgs
parents:
diff changeset
   166
        * @param aString It is string to be checked.
hgs
parents:
diff changeset
   167
        * @param aOptions Is call options
hgs
parents:
diff changeset
   168
        * @return ETrue if zero dialling.
hgs
parents:
diff changeset
   169
        */
hgs
parents:
diff changeset
   170
        TBool IsZeroDialling( const TDesC& aString, 
hgs
parents:
diff changeset
   171
            CPhoneGsmOptionContainer& aOptions ) const;
hgs
parents:
diff changeset
   172
hgs
parents:
diff changeset
   173
        /**
hgs
parents:
diff changeset
   174
        * Checks if two digit dialling is on and string 
hgs
parents:
diff changeset
   175
        * is two digit string.
hgs
parents:
diff changeset
   176
        *
hgs
parents:
diff changeset
   177
        * @param aString It is string to be checked.
hgs
parents:
diff changeset
   178
        * @return ETrue if two digit dialling.
hgs
parents:
diff changeset
   179
        */
hgs
parents:
diff changeset
   180
        TBool IsTwoDigitDialling( const TDesC& aString ) const;
hgs
parents:
diff changeset
   181
hgs
parents:
diff changeset
   182
        /**
hgs
parents:
diff changeset
   183
        * Checks if Input string is a 2 digit starting with a "1"
hgs
parents:
diff changeset
   184
        * and it is not in call situation.
hgs
parents:
diff changeset
   185
        *
hgs
parents:
diff changeset
   186
        * @param aString It is string to be checked.
hgs
parents:
diff changeset
   187
        * @param aOptions Is call options
hgs
parents:
diff changeset
   188
        * @return ETrue if 1x dialling situation.
hgs
parents:
diff changeset
   189
        */
hgs
parents:
diff changeset
   190
        TBool Is1xDialling( const TDesC& aString,
hgs
parents:
diff changeset
   191
            CPhoneGsmOptionContainer& aOptions ) const;
hgs
parents:
diff changeset
   192
        
hgs
parents:
diff changeset
   193
    };
hgs
parents:
diff changeset
   194
hgs
parents:
diff changeset
   195
#endif      // CPHONEGSMPHONENUMBERPARSER_H
hgs
parents:
diff changeset
   196
            
hgs
parents:
diff changeset
   197
// End of File