contentstorage/castorage/src/casqlquery.cpp
author hgs
Thu, 24 Jun 2010 16:18:29 +0300
changeset 99 7aaf39b772ac
parent 94 dbb8300717f7
child 119 50e220be30d1
permissions -rw-r--r--
201025
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
85
7feec50967db 201003_02
hgs
parents:
diff changeset
     1
/*
7feec50967db 201003_02
hgs
parents:
diff changeset
     2
 * Copyright (c) 2008 Nokia Corporation and/or its subsidiary(-ies).
7feec50967db 201003_02
hgs
parents:
diff changeset
     3
 * All rights reserved.
7feec50967db 201003_02
hgs
parents:
diff changeset
     4
 * This component and the accompanying materials are made available
7feec50967db 201003_02
hgs
parents:
diff changeset
     5
 * under the terms of "Eclipse Public License v1.0"
7feec50967db 201003_02
hgs
parents:
diff changeset
     6
 * which accompanies this distribution, and is available
7feec50967db 201003_02
hgs
parents:
diff changeset
     7
 * at the URL "http://www.eclipse.org/legal/epl-v10.html".
7feec50967db 201003_02
hgs
parents:
diff changeset
     8
 *
7feec50967db 201003_02
hgs
parents:
diff changeset
     9
 * Initial Contributors:
7feec50967db 201003_02
hgs
parents:
diff changeset
    10
 * Nokia Corporation - initial contribution.
7feec50967db 201003_02
hgs
parents:
diff changeset
    11
 *
7feec50967db 201003_02
hgs
parents:
diff changeset
    12
 * Contributors:
7feec50967db 201003_02
hgs
parents:
diff changeset
    13
 *
7feec50967db 201003_02
hgs
parents:
diff changeset
    14
 * Description: CCASqlQuery implementation
7feec50967db 201003_02
hgs
parents:
diff changeset
    15
 *
7feec50967db 201003_02
hgs
parents:
diff changeset
    16
 */
7feec50967db 201003_02
hgs
parents:
diff changeset
    17
7feec50967db 201003_02
hgs
parents:
diff changeset
    18
#include <sqldb.h>
7feec50967db 201003_02
hgs
parents:
diff changeset
    19
#include "casqlquery.h"
7feec50967db 201003_02
hgs
parents:
diff changeset
    20
#include "casqlcommands.h"
7feec50967db 201003_02
hgs
parents:
diff changeset
    21
#include "cainnerquery.h"
7feec50967db 201003_02
hgs
parents:
diff changeset
    22
#include "caentryattribute.h"
7feec50967db 201003_02
hgs
parents:
diff changeset
    23
#include "casqlquerycreator.h"
7feec50967db 201003_02
hgs
parents:
diff changeset
    24
#include "caoperationparams.h"
7feec50967db 201003_02
hgs
parents:
diff changeset
    25
#include "cadef.h"
7feec50967db 201003_02
hgs
parents:
diff changeset
    26
#include "calocalizationentry.h"
7feec50967db 201003_02
hgs
parents:
diff changeset
    27
7feec50967db 201003_02
hgs
parents:
diff changeset
    28
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
    29
//
7feec50967db 201003_02
hgs
parents:
diff changeset
    30
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
    31
//
7feec50967db 201003_02
hgs
parents:
diff changeset
    32
CCaSqlQuery::CCaSqlQuery( RSqlDatabase& aSql ) :
7feec50967db 201003_02
hgs
parents:
diff changeset
    33
    iSqlDb( aSql )
7feec50967db 201003_02
hgs
parents:
diff changeset
    34
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
    35
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
    36
7feec50967db 201003_02
hgs
parents:
diff changeset
    37
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
    38
//
7feec50967db 201003_02
hgs
parents:
diff changeset
    39
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
    40
//
7feec50967db 201003_02
hgs
parents:
diff changeset
    41
CCaSqlQuery::~CCaSqlQuery()
7feec50967db 201003_02
hgs
parents:
diff changeset
    42
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
    43
    iStatement.Close();
7feec50967db 201003_02
hgs
parents:
diff changeset
    44
    iQuery.Close();
7feec50967db 201003_02
hgs
parents:
diff changeset
    45
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
    46
7feec50967db 201003_02
hgs
parents:
diff changeset
    47
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
    48
//
7feec50967db 201003_02
hgs
parents:
diff changeset
    49
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
    50
//
7feec50967db 201003_02
hgs
parents:
diff changeset
    51
CCaSqlQuery* CCaSqlQuery::NewLC( RSqlDatabase& aSql )
7feec50967db 201003_02
hgs
parents:
diff changeset
    52
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
    53
    CCaSqlQuery* self = new ( ELeave ) CCaSqlQuery( aSql );
7feec50967db 201003_02
hgs
parents:
diff changeset
    54
    CleanupStack::PushL( self );
7feec50967db 201003_02
hgs
parents:
diff changeset
    55
    self->ConstructL();
7feec50967db 201003_02
hgs
parents:
diff changeset
    56
    return self;
7feec50967db 201003_02
hgs
parents:
diff changeset
    57
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
    58
7feec50967db 201003_02
hgs
parents:
diff changeset
    59
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
    60
//
7feec50967db 201003_02
hgs
parents:
diff changeset
    61
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
    62
//
7feec50967db 201003_02
hgs
parents:
diff changeset
    63
CCaSqlQuery* CCaSqlQuery::NewL( RSqlDatabase& aSql )
7feec50967db 201003_02
hgs
parents:
diff changeset
    64
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
    65
    CCaSqlQuery* self = CCaSqlQuery::NewLC( aSql );
7feec50967db 201003_02
hgs
parents:
diff changeset
    66
    CleanupStack::Pop( self );
7feec50967db 201003_02
hgs
parents:
diff changeset
    67
    return self;
7feec50967db 201003_02
hgs
parents:
diff changeset
    68
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
    69
7feec50967db 201003_02
hgs
parents:
diff changeset
    70
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
    71
//
7feec50967db 201003_02
hgs
parents:
diff changeset
    72
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
    73
//
7feec50967db 201003_02
hgs
parents:
diff changeset
    74
void CCaSqlQuery::ConstructL()
7feec50967db 201003_02
hgs
parents:
diff changeset
    75
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
    76
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
    77
7feec50967db 201003_02
hgs
parents:
diff changeset
    78
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
    79
//
7feec50967db 201003_02
hgs
parents:
diff changeset
    80
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
    81
//
7feec50967db 201003_02
hgs
parents:
diff changeset
    82
void CCaSqlQuery::PrepareL()
7feec50967db 201003_02
hgs
parents:
diff changeset
    83
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
    84
    User::LeaveIfError( iStatement.Prepare( iSqlDb, iQuery ) );
7feec50967db 201003_02
hgs
parents:
diff changeset
    85
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
    86
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
    87
//
7feec50967db 201003_02
hgs
parents:
diff changeset
    88
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
    89
//
7feec50967db 201003_02
hgs
parents:
diff changeset
    90
void CCaSqlQuery::CloseStatement()
7feec50967db 201003_02
hgs
parents:
diff changeset
    91
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
    92
    iStatement.Close();
7feec50967db 201003_02
hgs
parents:
diff changeset
    93
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
    94
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
    95
//
7feec50967db 201003_02
hgs
parents:
diff changeset
    96
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
    97
//
7feec50967db 201003_02
hgs
parents:
diff changeset
    98
void CCaSqlQuery::ResetStatement()
7feec50967db 201003_02
hgs
parents:
diff changeset
    99
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   100
    iStatement.Reset();
7feec50967db 201003_02
hgs
parents:
diff changeset
   101
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   102
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   103
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   104
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   105
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   106
void CCaSqlQuery::BindValuesForAddL( const CCaInnerEntry* aEntry )
7feec50967db 201003_02
hgs
parents:
diff changeset
   107
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   108
    switch ( Type() )
7feec50967db 201003_02
hgs
parents:
diff changeset
   109
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   110
        case EEntryTable: // = 1
7feec50967db 201003_02
hgs
parents:
diff changeset
   111
            {
7feec50967db 201003_02
hgs
parents:
diff changeset
   112
            BindValuesForAddEntryL( aEntry );
7feec50967db 201003_02
hgs
parents:
diff changeset
   113
            break;
7feec50967db 201003_02
hgs
parents:
diff changeset
   114
            }
7feec50967db 201003_02
hgs
parents:
diff changeset
   115
        case EIconTable:
7feec50967db 201003_02
hgs
parents:
diff changeset
   116
            {
7feec50967db 201003_02
hgs
parents:
diff changeset
   117
            BindValuesForAddIconL( aEntry );
7feec50967db 201003_02
hgs
parents:
diff changeset
   118
            break;
7feec50967db 201003_02
hgs
parents:
diff changeset
   119
            }
7feec50967db 201003_02
hgs
parents:
diff changeset
   120
        case EAttributeTable:
7feec50967db 201003_02
hgs
parents:
diff changeset
   121
            {
7feec50967db 201003_02
hgs
parents:
diff changeset
   122
            break;
7feec50967db 201003_02
hgs
parents:
diff changeset
   123
            }
7feec50967db 201003_02
hgs
parents:
diff changeset
   124
        default:
7feec50967db 201003_02
hgs
parents:
diff changeset
   125
            User::Leave( KErrNotSupported );
7feec50967db 201003_02
hgs
parents:
diff changeset
   126
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   127
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   128
7feec50967db 201003_02
hgs
parents:
diff changeset
   129
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   130
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   131
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   132
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   133
void CCaSqlQuery::BindValuesForAddEntryL( const CCaInnerEntry* aEntry )
7feec50967db 201003_02
hgs
parents:
diff changeset
   134
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   135
    if( iQuery.Find( KSQLEnText ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   136
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   137
        BindTextL( iStatement.ParameterIndex( KSQLEnText ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   138
                aEntry->GetText() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   139
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   140
    if( iQuery.Find( KSQLEnDescription )!= KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   141
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   142
        BindTextL( iStatement.ParameterIndex( KSQLEnDescription ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   143
                aEntry->GetDescription() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   144
        }    
7feec50967db 201003_02
hgs
parents:
diff changeset
   145
    if( iQuery.Find( KSQLEnRole ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   146
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   147
        BindIntL( iStatement.ParameterIndex( KSQLEnRole ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   148
                aEntry->GetRole() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   149
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   150
    if( iQuery.Find( KSQLEnTypeName ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   151
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   152
        BindTextL( iStatement.ParameterIndex( KSQLEnTypeName ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   153
                aEntry->GetEntryTypeName() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   154
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   155
    if( iQuery.Find( KSQLEnIdIcon ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   156
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   157
        BindIntL( iStatement.ParameterIndex( KSQLEnIdIcon ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   158
                aEntry->GetIconId() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   159
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   160
    if( iQuery.Find( KSQLEnCreationTime ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   161
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   162
        TTime currentTime( 0 );
7feec50967db 201003_02
hgs
parents:
diff changeset
   163
        currentTime.UniversalTime();
7feec50967db 201003_02
hgs
parents:
diff changeset
   164
        BindInt64L( iStatement.ParameterIndex( KSQLEnCreationTime ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   165
                currentTime.Int64() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   166
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   167
    if( iQuery.Find( KSQLEnUid ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   168
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   169
        BindIntL( iStatement.ParameterIndex( KSQLEnUid ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   170
                aEntry->GetUid() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   171
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   172
    if( iQuery.Find( KSQLEnFlags )!= KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   173
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   174
        BindIntL( iStatement.ParameterIndex( KSQLEnFlags ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   175
                aEntry->GetFlags() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   176
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   177
    if( iQuery.Find( KSQLEntryId ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   178
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   179
        BindIntL( iStatement.ParameterIndex( KSQLEntryId ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   180
                aEntry->GetId() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   181
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   182
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   183
7feec50967db 201003_02
hgs
parents:
diff changeset
   184
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   185
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   186
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   187
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   188
void CCaSqlQuery::BindValuesForAddIconL( const CCaInnerEntry* aEntry )
7feec50967db 201003_02
hgs
parents:
diff changeset
   189
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   190
    BindValuesForGetIconL( aEntry );
7feec50967db 201003_02
hgs
parents:
diff changeset
   191
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   192
7feec50967db 201003_02
hgs
parents:
diff changeset
   193
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   194
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   195
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   196
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   197
void CCaSqlQuery::BindValuesForAddAttributeL( const CCaInnerEntry* aEntry,
7feec50967db 201003_02
hgs
parents:
diff changeset
   198
        const CCaEntryAttribute* aAttr )
7feec50967db 201003_02
hgs
parents:
diff changeset
   199
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   200
    if( iQuery.Find( KSQLAttrEntryID ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   201
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   202
        BindIntL(iStatement.ParameterIndex( KSQLAttrEntryID ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   203
                aEntry->GetId() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   204
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   205
    if( iQuery.Find( KSQLAttrName ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   206
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   207
        BindTextL( iStatement.ParameterIndex( KSQLAttrName ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   208
                aAttr->Name() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   209
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   210
    if( iQuery.Find( KSQLAttrValue ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   211
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   212
        BindTextL( iStatement.ParameterIndex( KSQLAttrValue ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   213
                aAttr->Value() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   214
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   215
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   216
7feec50967db 201003_02
hgs
parents:
diff changeset
   217
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   218
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   219
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   220
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   221
void CCaSqlQuery::BindValuesForOrganizeL( const RArray<TInt>& aEntryIds,
7feec50967db 201003_02
hgs
parents:
diff changeset
   222
        TCaOperationParams& aParams, const TInt aEntryId )
7feec50967db 201003_02
hgs
parents:
diff changeset
   223
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   224
    if( aEntryIds.Count() > 0 )
7feec50967db 201003_02
hgs
parents:
diff changeset
   225
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   226
        BindIdsL( aEntryIds, KSQLEntryId );
7feec50967db 201003_02
hgs
parents:
diff changeset
   227
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   228
    if( iQuery.Find( KSQLGEIdGroup ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   229
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   230
        BindIntL( iStatement.ParameterIndex( KSQLGEIdGroup ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   231
                aParams.iGroupId );
7feec50967db 201003_02
hgs
parents:
diff changeset
   232
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   233
    if( iQuery.Find( KSQLEntryIdBefore ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   234
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   235
        BindIntL( iStatement.ParameterIndex( KSQLEntryIdBefore ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   236
                aParams.iBeforeEntryId );
7feec50967db 201003_02
hgs
parents:
diff changeset
   237
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   238
    if( iQuery.Find( KSQLGEEntryId ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   239
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   240
        BindIntL( iStatement.ParameterIndex( KSQLGEEntryId ), aEntryId );
7feec50967db 201003_02
hgs
parents:
diff changeset
   241
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   242
    if( iQuery.Find( KSQLShiftThreshold ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   243
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   244
        BindIntL( iStatement.ParameterIndex( KSQLShiftThreshold ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   245
                aEntryIds.Count() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   246
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   247
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   248
7feec50967db 201003_02
hgs
parents:
diff changeset
   249
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   250
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   251
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   252
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   253
void CCaSqlQuery::BindValuesForLaunchL( const TInt aEntryId,
7feec50967db 201003_02
hgs
parents:
diff changeset
   254
        const TInt64 aLaunchTime )
7feec50967db 201003_02
hgs
parents:
diff changeset
   255
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   256
    if( iQuery.Find( KSQLLaLaunchEntryId ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   257
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   258
        BindIntL( iStatement.ParameterIndex( 
7feec50967db 201003_02
hgs
parents:
diff changeset
   259
                KSQLLaLaunchEntryId ), aEntryId );
7feec50967db 201003_02
hgs
parents:
diff changeset
   260
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   261
    if( iQuery.Find( KSQLLaLaunchTime ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   262
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   263
        BindInt64L( iStatement.ParameterIndex( 
7feec50967db 201003_02
hgs
parents:
diff changeset
   264
                KSQLLaLaunchTime ), aLaunchTime );
7feec50967db 201003_02
hgs
parents:
diff changeset
   265
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   266
    if( iQuery.Find( KSQLEnFlags ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   267
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   268
        BindIntL( iStatement.ParameterIndex( KSQLEnFlags ), EUsed );
7feec50967db 201003_02
hgs
parents:
diff changeset
   269
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   270
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   271
7feec50967db 201003_02
hgs
parents:
diff changeset
   272
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   273
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   274
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   275
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   276
void CCaSqlQuery::BindValuesForRemoveL( const TInt aEntryId,
7feec50967db 201003_02
hgs
parents:
diff changeset
   277
        const TInt aIconId )
7feec50967db 201003_02
hgs
parents:
diff changeset
   278
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   279
    if( iQuery.Find( KSQLEntryId )!= KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   280
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   281
        BindIntL( iStatement.ParameterIndex( KSQLEntryId ), aEntryId );
7feec50967db 201003_02
hgs
parents:
diff changeset
   282
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   283
    if( iQuery.Find( KSQLIconId )!= KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   284
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   285
        BindIntL( iStatement.ParameterIndex( KSQLIconId ), aIconId );
7feec50967db 201003_02
hgs
parents:
diff changeset
   286
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   287
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   288
7feec50967db 201003_02
hgs
parents:
diff changeset
   289
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   290
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   291
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   292
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   293
void CCaSqlQuery::BindValuesForCustomSortL( const TInt aGroupId, const TInt aEntryId,
7feec50967db 201003_02
hgs
parents:
diff changeset
   294
        const TInt aNewPostion )
7feec50967db 201003_02
hgs
parents:
diff changeset
   295
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   296
    if( iQuery.Find( KSQLGEIdGroup )!= KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   297
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   298
        BindIntL( iStatement.ParameterIndex( KSQLGEIdGroup ), aGroupId );
7feec50967db 201003_02
hgs
parents:
diff changeset
   299
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   300
    if( iQuery.Find( KSQLGEEntryId )!= KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   301
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   302
        BindIntL( iStatement.ParameterIndex( KSQLGEEntryId ), aEntryId );
7feec50967db 201003_02
hgs
parents:
diff changeset
   303
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   304
    if( iQuery.Find( KSQLGEPosition )!= KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   305
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   306
        BindIntL( iStatement.ParameterIndex( KSQLGEPosition ), aNewPostion );
7feec50967db 201003_02
hgs
parents:
diff changeset
   307
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   308
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   309
7feec50967db 201003_02
hgs
parents:
diff changeset
   310
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   311
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   312
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   313
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   314
void CCaSqlQuery::BindTextL( TInt aParameterIndex,
7feec50967db 201003_02
hgs
parents:
diff changeset
   315
        const TDesC& aParameterValue )
7feec50967db 201003_02
hgs
parents:
diff changeset
   316
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   317
    User::LeaveIfError( iStatement.BindText( aParameterIndex,
7feec50967db 201003_02
hgs
parents:
diff changeset
   318
            aParameterValue ) );
7feec50967db 201003_02
hgs
parents:
diff changeset
   319
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   320
7feec50967db 201003_02
hgs
parents:
diff changeset
   321
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   322
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   323
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   324
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   325
void CCaSqlQuery::BindIntL( TInt aParameterIndex,
7feec50967db 201003_02
hgs
parents:
diff changeset
   326
        TInt aParameterValue )
7feec50967db 201003_02
hgs
parents:
diff changeset
   327
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   328
    User::LeaveIfError( aParameterIndex );
7feec50967db 201003_02
hgs
parents:
diff changeset
   329
    User::LeaveIfError( iStatement.BindInt( aParameterIndex,
7feec50967db 201003_02
hgs
parents:
diff changeset
   330
            aParameterValue ) );
7feec50967db 201003_02
hgs
parents:
diff changeset
   331
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   332
7feec50967db 201003_02
hgs
parents:
diff changeset
   333
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   334
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   335
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   336
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   337
void CCaSqlQuery::BindInt64L( TInt aParameterIndex,
7feec50967db 201003_02
hgs
parents:
diff changeset
   338
        TInt64 aParameterValue )
7feec50967db 201003_02
hgs
parents:
diff changeset
   339
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   340
    User::LeaveIfError( aParameterIndex );
7feec50967db 201003_02
hgs
parents:
diff changeset
   341
    User::LeaveIfError( iStatement.BindInt64( aParameterIndex,
7feec50967db 201003_02
hgs
parents:
diff changeset
   342
            aParameterValue ) );
7feec50967db 201003_02
hgs
parents:
diff changeset
   343
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   344
7feec50967db 201003_02
hgs
parents:
diff changeset
   345
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   346
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   347
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   348
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   349
void CCaSqlQuery::SetQueryL( const TDesC& aQuery )
7feec50967db 201003_02
hgs
parents:
diff changeset
   350
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   351
    iQuery.Close();
7feec50967db 201003_02
hgs
parents:
diff changeset
   352
    iQuery.CreateL( aQuery );
7feec50967db 201003_02
hgs
parents:
diff changeset
   353
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   354
7feec50967db 201003_02
hgs
parents:
diff changeset
   355
7feec50967db 201003_02
hgs
parents:
diff changeset
   356
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   357
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   358
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   359
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   360
void CCaSqlQuery::BindValuesForLocalizeL( CCaLocalizationEntry& aLocalization )
7feec50967db 201003_02
hgs
parents:
diff changeset
   361
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   362
    if( iQuery.Find( KSQLLocRowId ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   363
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   364
        BindIntL( iStatement.ParameterIndex( 
7feec50967db 201003_02
hgs
parents:
diff changeset
   365
        		KSQLLocRowId ), aLocalization.GetRowId() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   366
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   367
    if( iQuery.Find( KSQLLocTable ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   368
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   369
        BindTextL(iStatement.ParameterIndex( KSQLLocTable ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   370
                aLocalization.GetTableName() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   371
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   372
    if( iQuery.Find( KSQLLocAttribute ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   373
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   374
        BindTextL(iStatement.ParameterIndex( KSQLLocAttribute ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   375
                aLocalization.GetAttributeName() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   376
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   377
    if( iQuery.Find( KSQLLocString ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   378
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   379
        BindTextL(iStatement.ParameterIndex( KSQLLocString ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   380
                aLocalization.GetLocalizedString() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   381
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   382
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   383
7feec50967db 201003_02
hgs
parents:
diff changeset
   384
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   385
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   386
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   387
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   388
void CCaSqlQuery::BindValuesForPropertyL( const TDesC& aProperty )
7feec50967db 201003_02
hgs
parents:
diff changeset
   389
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   390
    if( iQuery.Find( KSQLDbProperty ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   391
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   392
        BindTextL( iStatement.ParameterIndex( 
7feec50967db 201003_02
hgs
parents:
diff changeset
   393
                KSQLDbProperty ), aProperty );
7feec50967db 201003_02
hgs
parents:
diff changeset
   394
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   395
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   396
7feec50967db 201003_02
hgs
parents:
diff changeset
   397
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   398
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   399
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   400
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   401
void CCaSqlQuery::BindValuesForPropertyUpdateL( const TDesC& aProperty, const TDesC& aPropertyValue )
7feec50967db 201003_02
hgs
parents:
diff changeset
   402
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   403
    BindValuesForPropertyL( aProperty );
7feec50967db 201003_02
hgs
parents:
diff changeset
   404
    
7feec50967db 201003_02
hgs
parents:
diff changeset
   405
    if( iQuery.Find( KSQLDbValue ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   406
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   407
        BindTextL( iStatement.ParameterIndex( 
7feec50967db 201003_02
hgs
parents:
diff changeset
   408
                KSQLDbValue ), aPropertyValue );
7feec50967db 201003_02
hgs
parents:
diff changeset
   409
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   410
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   411
7feec50967db 201003_02
hgs
parents:
diff changeset
   412
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   413
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   414
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   415
//
94
hgs
parents: 92
diff changeset
   416
void CCaSqlQuery::BindValuesForGetLocalizationEntryL(
hgs
parents: 92
diff changeset
   417
        const CCaLocalizationEntry& aLocalization)
hgs
parents: 92
diff changeset
   418
    {
hgs
parents: 92
diff changeset
   419
    BindIntL( iStatement.ParameterIndex( KSQLLocRowId ),
hgs
parents: 92
diff changeset
   420
            aLocalization.GetRowId() );
hgs
parents: 92
diff changeset
   421
    BindTextL( iStatement.ParameterIndex( KSQLLocTable ),
hgs
parents: 92
diff changeset
   422
            aLocalization.GetTableName() );
hgs
parents: 92
diff changeset
   423
    BindTextL( iStatement.ParameterIndex( KSQLLocAttribute ),
hgs
parents: 92
diff changeset
   424
            aLocalization.GetAttributeName() );
hgs
parents: 92
diff changeset
   425
    }
hgs
parents: 92
diff changeset
   426
hgs
parents: 92
diff changeset
   427
// ---------------------------------------------------------------------------
hgs
parents: 92
diff changeset
   428
//
hgs
parents: 92
diff changeset
   429
// ---------------------------------------------------------------------------
hgs
parents: 92
diff changeset
   430
//
hgs
parents: 92
diff changeset
   431
void CCaSqlQuery::BindValuesForLocalizationEntryL(
hgs
parents: 92
diff changeset
   432
        const CCaLocalizationEntry& aLocalization)
hgs
parents: 92
diff changeset
   433
    {
hgs
parents: 92
diff changeset
   434
    BindIntL( iStatement.ParameterIndex( KSQLLocRowId ),
hgs
parents: 92
diff changeset
   435
            aLocalization.GetRowId() );
hgs
parents: 92
diff changeset
   436
    BindTextL( iStatement.ParameterIndex( KSQLLocTable ),
hgs
parents: 92
diff changeset
   437
            aLocalization.GetTableName() );
hgs
parents: 92
diff changeset
   438
    BindTextL( iStatement.ParameterIndex( KSQLLocAttribute ),
hgs
parents: 92
diff changeset
   439
            aLocalization.GetAttributeName() );
hgs
parents: 92
diff changeset
   440
    BindTextL( iStatement.ParameterIndex( KSQLLocQmFilename ),
hgs
parents: 92
diff changeset
   441
            aLocalization.GetQmFilename() );
hgs
parents: 92
diff changeset
   442
    BindTextL( iStatement.ParameterIndex( KSQLLocString ),
hgs
parents: 92
diff changeset
   443
            aLocalization.GetStringId() );
hgs
parents: 92
diff changeset
   444
    }
hgs
parents: 92
diff changeset
   445
hgs
parents: 92
diff changeset
   446
hgs
parents: 92
diff changeset
   447
// ---------------------------------------------------------------------------
hgs
parents: 92
diff changeset
   448
//
hgs
parents: 92
diff changeset
   449
// ---------------------------------------------------------------------------
hgs
parents: 92
diff changeset
   450
//
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   451
void CCaSqlQuery::BindValuesForGetEntriesL( const CCaInnerQuery* aQuery )
7feec50967db 201003_02
hgs
parents:
diff changeset
   452
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   453
    if( aQuery->GetIds().Count() > 0 )
7feec50967db 201003_02
hgs
parents:
diff changeset
   454
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   455
        BindIdsL( aQuery->GetIds(), KSQLEntryId );
7feec50967db 201003_02
hgs
parents:
diff changeset
   456
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   457
    else
7feec50967db 201003_02
hgs
parents:
diff changeset
   458
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   459
        if( aQuery->GetFlagsOn() != 0 && iQuery.Find( KSQLFlagsOn )
7feec50967db 201003_02
hgs
parents:
diff changeset
   460
                != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   461
            {
7feec50967db 201003_02
hgs
parents:
diff changeset
   462
            BindIntL( iStatement.ParameterIndex( KSQLFlagsOn ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   463
                    aQuery->GetFlagsOn() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   464
            }
7feec50967db 201003_02
hgs
parents:
diff changeset
   465
        if( aQuery->GetFlagsOff() != 0 && iQuery.Find( KSQLFlagsOff )
7feec50967db 201003_02
hgs
parents:
diff changeset
   466
                != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   467
            {
7feec50967db 201003_02
hgs
parents:
diff changeset
   468
            BindIntL( iStatement.ParameterIndex( KSQLFlagsOff ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   469
                    aQuery->GetFlagsOff() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   470
            }
7feec50967db 201003_02
hgs
parents:
diff changeset
   471
        if( aQuery->GetRole() != -1 && iQuery.Find( KSQLEnRole )
7feec50967db 201003_02
hgs
parents:
diff changeset
   472
                != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   473
            {
7feec50967db 201003_02
hgs
parents:
diff changeset
   474
            BindIntL( iStatement.ParameterIndex( KSQLEnRole ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   475
                    aQuery->GetRole() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   476
            }
7feec50967db 201003_02
hgs
parents:
diff changeset
   477
        if( aQuery->GetParentId() != -1 && iQuery.Find( KSQLGEIdGroup )
7feec50967db 201003_02
hgs
parents:
diff changeset
   478
                != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   479
            {
7feec50967db 201003_02
hgs
parents:
diff changeset
   480
            BindIntL( iStatement.ParameterIndex( KSQLGEIdGroup ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   481
                    aQuery->GetParentId() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   482
            }
99
hgs
parents: 94
diff changeset
   483
        if( aQuery->GetChildId() != -1 && iQuery.Find( KSQLGEEntryId )
hgs
parents: 94
diff changeset
   484
                != KErrNotFound )
hgs
parents: 94
diff changeset
   485
            {
hgs
parents: 94
diff changeset
   486
            BindIntL( iStatement.ParameterIndex( KSQLGEEntryId ),
hgs
parents: 94
diff changeset
   487
                    aQuery->GetChildId() );
hgs
parents: 94
diff changeset
   488
            }
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   489
        if( aQuery->GetUid() != 0 && iQuery.Find( KSQLEnUid )
7feec50967db 201003_02
hgs
parents:
diff changeset
   490
                != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   491
            {
7feec50967db 201003_02
hgs
parents:
diff changeset
   492
            BindIntL( iStatement.ParameterIndex( KSQLEnUid ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   493
                    aQuery->GetUid() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   494
            }
7feec50967db 201003_02
hgs
parents:
diff changeset
   495
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   496
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   497
7feec50967db 201003_02
hgs
parents:
diff changeset
   498
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   499
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   500
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   501
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   502
void CCaSqlQuery::BindValuesForGetEntriesL( const CCaInnerEntry* aEntry )
7feec50967db 201003_02
hgs
parents:
diff changeset
   503
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   504
    if( iQuery.Find( KSQLEntryId ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   505
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   506
        BindIntL(iStatement.ParameterIndex( KSQLEntryId ), 
7feec50967db 201003_02
hgs
parents:
diff changeset
   507
                aEntry->GetId() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   508
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   509
    if( iQuery.Find( KSQLEnText) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   510
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   511
        BindTextL(iStatement.ParameterIndex( KSQLEnText ), 
7feec50967db 201003_02
hgs
parents:
diff changeset
   512
                aEntry->GetText() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   513
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   514
    if( iQuery.Find( KSQLEnDescription ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   515
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   516
        BindTextL(iStatement.ParameterIndex( KSQLEnDescription ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   517
                aEntry->GetDescription() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   518
        }    
7feec50967db 201003_02
hgs
parents:
diff changeset
   519
    if( iQuery.Find( KSQLEnRole ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   520
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   521
        BindIntL( iStatement.ParameterIndex( KSQLEnRole ), 
7feec50967db 201003_02
hgs
parents:
diff changeset
   522
                aEntry->GetRole() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   523
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   524
    if( iQuery.Find( KSQLEnTypeName ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   525
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   526
        BindTextL( iStatement.ParameterIndex( KSQLEnTypeName ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   527
                aEntry->GetEntryTypeName() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   528
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   529
    if( iQuery.Find( KSQLEnIdIcon ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   530
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   531
        BindIntL( iStatement.ParameterIndex( KSQLEnIdIcon ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   532
                aEntry->GetIconId() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   533
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   534
    if( iQuery.Find( KSQLEnUid ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   535
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   536
        BindIntL( iStatement.ParameterIndex(KSQLEnUid), aEntry->GetUid() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   537
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   538
    if( iQuery.Find( KSQLEnFlags ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   539
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   540
        BindIntL( iStatement.ParameterIndex( KSQLEnFlags ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   541
                aEntry->GetFlags() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   542
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   543
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   544
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   545
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   546
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   547
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   548
void CCaSqlQuery::BindValuesForGetIconL( const CCaInnerEntry* aEntry )
7feec50967db 201003_02
hgs
parents:
diff changeset
   549
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   550
    if( iQuery.Find( KSQLIconId ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   551
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   552
        BindIntL(iStatement.ParameterIndex( KSQLIconId ),
92
hgs
parents: 89
diff changeset
   553
                aEntry->Icon()->Id() );
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   554
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   555
    if( iQuery.Find( KSQLIcFileName ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   556
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   557
        BindTextL( iStatement.ParameterIndex( KSQLIcFileName ),
92
hgs
parents: 89
diff changeset
   558
                aEntry->Icon()->FileName() );
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   559
        }
88
hgs
parents: 85
diff changeset
   560
    if( iQuery.Find( KSQLIcSkinId ) != KErrNotFound )
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   561
        {
88
hgs
parents: 85
diff changeset
   562
        BindTextL( iStatement.ParameterIndex( KSQLIcSkinId ),
92
hgs
parents: 89
diff changeset
   563
                aEntry->Icon()->SkinId() );
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   564
        }
88
hgs
parents: 85
diff changeset
   565
    if( iQuery.Find( KSQLIcAppId ) != KErrNotFound )
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   566
        {
88
hgs
parents: 85
diff changeset
   567
        BindTextL( iStatement.ParameterIndex( KSQLIcAppId ),
92
hgs
parents: 89
diff changeset
   568
                aEntry->Icon()->ApplicationId() );
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   569
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   570
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   571
7feec50967db 201003_02
hgs
parents:
diff changeset
   572
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   573
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   574
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   575
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   576
void CCaSqlQuery::BindEntryIdsL(
7feec50967db 201003_02
hgs
parents:
diff changeset
   577
        const RPointerArray<CCaInnerEntry>& aEntryArray )
7feec50967db 201003_02
hgs
parents:
diff changeset
   578
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   579
    RArray<TInt> entryIdArray;
7feec50967db 201003_02
hgs
parents:
diff changeset
   580
    CleanupClosePushL( entryIdArray );
7feec50967db 201003_02
hgs
parents:
diff changeset
   581
7feec50967db 201003_02
hgs
parents:
diff changeset
   582
    for( TInt i = 0; i < aEntryArray.Count(); i++ )
7feec50967db 201003_02
hgs
parents:
diff changeset
   583
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   584
        entryIdArray.AppendL( aEntryArray[i]->GetId() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   585
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   586
    BindIdsL( entryIdArray, KSQLEntryId );
7feec50967db 201003_02
hgs
parents:
diff changeset
   587
    CleanupStack::PopAndDestroy( &entryIdArray );
7feec50967db 201003_02
hgs
parents:
diff changeset
   588
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   589
7feec50967db 201003_02
hgs
parents:
diff changeset
   590
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   591
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   592
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   593
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   594
void CCaSqlQuery::BindIdsL( const RArray<TInt>& aEntryIdArray,
7feec50967db 201003_02
hgs
parents:
diff changeset
   595
        const TDesC& aColName )
7feec50967db 201003_02
hgs
parents:
diff changeset
   596
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   597
    RBuf bindKey;
7feec50967db 201003_02
hgs
parents:
diff changeset
   598
    bindKey.CleanupClosePushL();
7feec50967db 201003_02
hgs
parents:
diff changeset
   599
    bindKey.CreateL( aColName.Length() + KMaxIntNumLength );
7feec50967db 201003_02
hgs
parents:
diff changeset
   600
    for( TInt i = 0; i < aEntryIdArray.Count() ; i++ )
7feec50967db 201003_02
hgs
parents:
diff changeset
   601
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   602
        bindKey.Copy( KNullDesC );
7feec50967db 201003_02
hgs
parents:
diff changeset
   603
        bindKey.Append( aColName );
7feec50967db 201003_02
hgs
parents:
diff changeset
   604
        bindKey.AppendNum( i );
7feec50967db 201003_02
hgs
parents:
diff changeset
   605
        if( iQuery.Find( bindKey ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   606
            {
7feec50967db 201003_02
hgs
parents:
diff changeset
   607
            BindIntL( iStatement.ParameterIndex( bindKey ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   608
                    aEntryIdArray[i] );
7feec50967db 201003_02
hgs
parents:
diff changeset
   609
            }
7feec50967db 201003_02
hgs
parents:
diff changeset
   610
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   611
    CleanupStack::PopAndDestroy( &bindKey );
7feec50967db 201003_02
hgs
parents:
diff changeset
   612
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   613
7feec50967db 201003_02
hgs
parents:
diff changeset
   614
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   615
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   616
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   617
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   618
void CCaSqlQuery::BindEntryIdL( const TInt& aEntryId )
7feec50967db 201003_02
hgs
parents:
diff changeset
   619
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   620
    if( iQuery.Find( KSQLEntryId ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   621
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   622
        BindIntL( iStatement.ParameterIndex( KSQLEntryId ), aEntryId );
7feec50967db 201003_02
hgs
parents:
diff changeset
   623
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   624
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   625
7feec50967db 201003_02
hgs
parents:
diff changeset
   626
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   627
// CCaSqlQuery::BindValuesForRemoveFromLocalizationL(  const TInt aEntryId )
7feec50967db 201003_02
hgs
parents:
diff changeset
   628
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   629
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   630
void CCaSqlQuery::BindValuesForRemoveFromLocalizationL(  const TInt aEntryId )
7feec50967db 201003_02
hgs
parents:
diff changeset
   631
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   632
    if( iQuery.Find( KSQLLocRowId ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   633
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   634
        BindIntL( iStatement.ParameterIndex( KSQLLocRowId ), aEntryId );
7feec50967db 201003_02
hgs
parents:
diff changeset
   635
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   636
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   637
7feec50967db 201003_02
hgs
parents:
diff changeset
   638
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   639
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   640
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   641
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   642
TInt CCaSqlQuery::ExecuteL()
7feec50967db 201003_02
hgs
parents:
diff changeset
   643
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   644
    User::LeaveIfError( iStatement.Exec() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   645
    TSqlScalarFullSelectQuery id_query( iSqlDb );
7feec50967db 201003_02
hgs
parents:
diff changeset
   646
    return id_query.SelectIntL( KSQLGetLastInsertId );
7feec50967db 201003_02
hgs
parents:
diff changeset
   647
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   648
7feec50967db 201003_02
hgs
parents:
diff changeset
   649
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   650
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   651
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   652
//
94
hgs
parents: 92
diff changeset
   653
TBool CCaSqlQuery::ExecuteEntryPresentL( )
hgs
parents: 92
diff changeset
   654
    {
hgs
parents: 92
diff changeset
   655
    if( iStatement.Next() == KSqlAtRow )
hgs
parents: 92
diff changeset
   656
        {
hgs
parents: 92
diff changeset
   657
        return ETrue;
hgs
parents: 92
diff changeset
   658
        }
hgs
parents: 92
diff changeset
   659
    return EFalse;
hgs
parents: 92
diff changeset
   660
    }
hgs
parents: 92
diff changeset
   661
hgs
parents: 92
diff changeset
   662
// ---------------------------------------------------------------------------
hgs
parents: 92
diff changeset
   663
//
hgs
parents: 92
diff changeset
   664
// ---------------------------------------------------------------------------
hgs
parents: 92
diff changeset
   665
//
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   666
TInt CCaSqlQuery::ExecuteL( TInt& aId )
7feec50967db 201003_02
hgs
parents:
diff changeset
   667
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   668
    if( iStatement.Next() == KSqlAtRow )
7feec50967db 201003_02
hgs
parents:
diff changeset
   669
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   670
        aId = iStatement.ColumnInt( ColumnIndexL( iStatement,
7feec50967db 201003_02
hgs
parents:
diff changeset
   671
                KColumnSingleData ) );
7feec50967db 201003_02
hgs
parents:
diff changeset
   672
        return 1;
7feec50967db 201003_02
hgs
parents:
diff changeset
   673
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   674
    return 0;
7feec50967db 201003_02
hgs
parents:
diff changeset
   675
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   676
7feec50967db 201003_02
hgs
parents:
diff changeset
   677
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   678
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   679
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   680
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   681
TInt CCaSqlQuery::ExecuteL( TInt64& aId )
7feec50967db 201003_02
hgs
parents:
diff changeset
   682
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   683
    if( iStatement.Next() == KSqlAtRow )
7feec50967db 201003_02
hgs
parents:
diff changeset
   684
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   685
        aId = iStatement.ColumnInt64(ColumnIndexL( iStatement,
7feec50967db 201003_02
hgs
parents:
diff changeset
   686
                KColumnSingleData ) );
7feec50967db 201003_02
hgs
parents:
diff changeset
   687
        return 1;
7feec50967db 201003_02
hgs
parents:
diff changeset
   688
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   689
    return 0;
7feec50967db 201003_02
hgs
parents:
diff changeset
   690
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   691
7feec50967db 201003_02
hgs
parents:
diff changeset
   692
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   693
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   694
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   695
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   696
TInt CCaSqlQuery::ExecuteL( RPointerArray<CCaInnerEntry>& result,
7feec50967db 201003_02
hgs
parents:
diff changeset
   697
        TQueryResultType aResultType )
7feec50967db 201003_02
hgs
parents:
diff changeset
   698
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   699
    TInt rowCount( 0 );
7feec50967db 201003_02
hgs
parents:
diff changeset
   700
    if( aResultType==CCaSqlQuery::EEntry )
7feec50967db 201003_02
hgs
parents:
diff changeset
   701
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   702
        rowCount = ExecuteEntryL( result );
7feec50967db 201003_02
hgs
parents:
diff changeset
   703
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   704
    else // aResultType==CCaSqlQuery::EAttribute
7feec50967db 201003_02
hgs
parents:
diff changeset
   705
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   706
        rowCount = ExecuteAttributeL( result );
7feec50967db 201003_02
hgs
parents:
diff changeset
   707
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   708
    return rowCount;
7feec50967db 201003_02
hgs
parents:
diff changeset
   709
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   710
7feec50967db 201003_02
hgs
parents:
diff changeset
   711
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   712
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   713
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   714
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   715
TInt CCaSqlQuery::ExecuteEntryL(
7feec50967db 201003_02
hgs
parents:
diff changeset
   716
        RPointerArray<CCaInnerEntry>& aResultInput )
7feec50967db 201003_02
hgs
parents:
diff changeset
   717
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   718
    TInt rowCount(0);
7feec50967db 201003_02
hgs
parents:
diff changeset
   719
    while( iStatement.Next() == KSqlAtRow )
7feec50967db 201003_02
hgs
parents:
diff changeset
   720
        {
89
hgs
parents: 88
diff changeset
   721
        TInt entryId = iStatement.ColumnInt( 
hgs
parents: 88
diff changeset
   722
        		ColumnIndexL( iStatement, KColumnEntryId ) );
hgs
parents: 88
diff changeset
   723
        TInt role = iStatement.ColumnInt( 
hgs
parents: 88
diff changeset
   724
        		ColumnIndexL( iStatement, KColumnEnRole ) );
hgs
parents: 88
diff changeset
   725
        TInt32 uid = iStatement.ColumnInt( 
hgs
parents: 88
diff changeset
   726
        		ColumnIndexL( iStatement, KColumnEnUid ) );
hgs
parents: 88
diff changeset
   727
        TUint flags = iStatement.ColumnInt( 
hgs
parents: 88
diff changeset
   728
        		ColumnIndexL( iStatement, KColumnEnFlags ) );
hgs
parents: 88
diff changeset
   729
        TInt idIcon = iStatement.ColumnInt( 
hgs
parents: 88
diff changeset
   730
        		ColumnIndexL( iStatement, KColumnEnIdIcon ) );
88
hgs
parents: 85
diff changeset
   731
        
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   732
        TPtrC text;
7feec50967db 201003_02
hgs
parents:
diff changeset
   733
        User::LeaveIfError( iStatement. ColumnText( ColumnIndexL(
7feec50967db 201003_02
hgs
parents:
diff changeset
   734
                iStatement, KColumnEnText ), text ) );
7feec50967db 201003_02
hgs
parents:
diff changeset
   735
        TPtrC description;
7feec50967db 201003_02
hgs
parents:
diff changeset
   736
        User::LeaveIfError( iStatement.
7feec50967db 201003_02
hgs
parents:
diff changeset
   737
                ColumnText( ColumnIndexL( iStatement, KColumnEnDescription ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   738
                description) );      
7feec50967db 201003_02
hgs
parents:
diff changeset
   739
        TPtrC typeName;
7feec50967db 201003_02
hgs
parents:
diff changeset
   740
        User::LeaveIfError( iStatement.ColumnText( 
7feec50967db 201003_02
hgs
parents:
diff changeset
   741
                ColumnIndexL(iStatement, KColumnEnTypeName ), typeName) );
88
hgs
parents: 85
diff changeset
   742
                
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   743
        TPtrC iconFilename;
7feec50967db 201003_02
hgs
parents:
diff changeset
   744
        User::LeaveIfError( iStatement.ColumnText( ColumnIndexL(
7feec50967db 201003_02
hgs
parents:
diff changeset
   745
                iStatement, KColumnIcFileName ), iconFilename ) );
7feec50967db 201003_02
hgs
parents:
diff changeset
   746
88
hgs
parents: 85
diff changeset
   747
        TPtrC iconSkinId;
hgs
parents: 85
diff changeset
   748
        User::LeaveIfError( iStatement.ColumnText( ColumnIndexL(
hgs
parents: 85
diff changeset
   749
                iStatement, KColumnIcSkinId ), iconSkinId ) );
hgs
parents: 85
diff changeset
   750
hgs
parents: 85
diff changeset
   751
        TPtrC iconApplicationId;
hgs
parents: 85
diff changeset
   752
        User::LeaveIfError( iStatement.ColumnText( ColumnIndexL(
hgs
parents: 85
diff changeset
   753
                iStatement, KColumnIcAppId ), iconApplicationId ) );
hgs
parents: 85
diff changeset
   754
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   755
        CCaInnerEntry* result = CCaInnerEntry::NewLC();
7feec50967db 201003_02
hgs
parents:
diff changeset
   756
        result->SetId( entryId );
7feec50967db 201003_02
hgs
parents:
diff changeset
   757
        result->SetRole( role );
88
hgs
parents: 85
diff changeset
   758
        result->SetIconDataL(
hgs
parents: 85
diff changeset
   759
                iconFilename, iconSkinId, iconApplicationId );
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   760
        result->SetIconId( idIcon );
7feec50967db 201003_02
hgs
parents:
diff changeset
   761
        result->SetFlags( flags );
7feec50967db 201003_02
hgs
parents:
diff changeset
   762
        result->SetUid( uid );
7feec50967db 201003_02
hgs
parents:
diff changeset
   763
        result->SetTextL( text );
7feec50967db 201003_02
hgs
parents:
diff changeset
   764
        result->SetDescriptionL( description );
7feec50967db 201003_02
hgs
parents:
diff changeset
   765
        result->SetEntryTypeNameL( typeName );
7feec50967db 201003_02
hgs
parents:
diff changeset
   766
7feec50967db 201003_02
hgs
parents:
diff changeset
   767
        aResultInput.AppendL( result );
7feec50967db 201003_02
hgs
parents:
diff changeset
   768
        CleanupStack::Pop( result );
7feec50967db 201003_02
hgs
parents:
diff changeset
   769
        rowCount++;
7feec50967db 201003_02
hgs
parents:
diff changeset
   770
        }//while
7feec50967db 201003_02
hgs
parents:
diff changeset
   771
7feec50967db 201003_02
hgs
parents:
diff changeset
   772
    return rowCount;
7feec50967db 201003_02
hgs
parents:
diff changeset
   773
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   774
7feec50967db 201003_02
hgs
parents:
diff changeset
   775
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   776
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   777
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   778
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   779
TInt CCaSqlQuery::ExecuteLocalizationsL(
7feec50967db 201003_02
hgs
parents:
diff changeset
   780
        RPointerArray<CCaLocalizationEntry>& aResultInput )
7feec50967db 201003_02
hgs
parents:
diff changeset
   781
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   782
    TInt rowCount(0);
7feec50967db 201003_02
hgs
parents:
diff changeset
   783
    while( iStatement.Next() == KSqlAtRow )
7feec50967db 201003_02
hgs
parents:
diff changeset
   784
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   785
        TInt locTextId = iStatement.ColumnInt(
7feec50967db 201003_02
hgs
parents:
diff changeset
   786
                ColumnIndexL( iStatement, KColumnLocTextId )
7feec50967db 201003_02
hgs
parents:
diff changeset
   787
                );
7feec50967db 201003_02
hgs
parents:
diff changeset
   788
        
7feec50967db 201003_02
hgs
parents:
diff changeset
   789
        TInt rowId = iStatement.ColumnInt(
7feec50967db 201003_02
hgs
parents:
diff changeset
   790
                ColumnIndexL( iStatement, KColumnLocRowId ) 
7feec50967db 201003_02
hgs
parents:
diff changeset
   791
                );
7feec50967db 201003_02
hgs
parents:
diff changeset
   792
         
7feec50967db 201003_02
hgs
parents:
diff changeset
   793
        TPtrC tableName;
7feec50967db 201003_02
hgs
parents:
diff changeset
   794
        User::LeaveIfError(
7feec50967db 201003_02
hgs
parents:
diff changeset
   795
                iStatement.ColumnText(
7feec50967db 201003_02
hgs
parents:
diff changeset
   796
                        ColumnIndexL( iStatement, KColumnLocTableName ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   797
                        tableName )
7feec50967db 201003_02
hgs
parents:
diff changeset
   798
                        );
7feec50967db 201003_02
hgs
parents:
diff changeset
   799
        
94
hgs
parents: 92
diff changeset
   800
        TPtrC qmFilename;
hgs
parents: 92
diff changeset
   801
        User::LeaveIfError(
hgs
parents: 92
diff changeset
   802
                iStatement.ColumnText(
hgs
parents: 92
diff changeset
   803
                        ColumnIndexL( iStatement, KColumnQmFile ),
hgs
parents: 92
diff changeset
   804
                        qmFilename )
hgs
parents: 92
diff changeset
   805
                        );
hgs
parents: 92
diff changeset
   806
        
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   807
        TPtrC attribute;
7feec50967db 201003_02
hgs
parents:
diff changeset
   808
        User::LeaveIfError(
7feec50967db 201003_02
hgs
parents:
diff changeset
   809
                iStatement.ColumnText(
7feec50967db 201003_02
hgs
parents:
diff changeset
   810
                        ColumnIndexL( iStatement, KColumnLocAttrName ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   811
                        attribute )
7feec50967db 201003_02
hgs
parents:
diff changeset
   812
                        );  
7feec50967db 201003_02
hgs
parents:
diff changeset
   813
        
7feec50967db 201003_02
hgs
parents:
diff changeset
   814
        TPtrC stringId;
7feec50967db 201003_02
hgs
parents:
diff changeset
   815
        User::LeaveIfError(
7feec50967db 201003_02
hgs
parents:
diff changeset
   816
                iStatement.ColumnText(
7feec50967db 201003_02
hgs
parents:
diff changeset
   817
                        ColumnIndexL( iStatement, KColumnLocStringId ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   818
                        stringId )
7feec50967db 201003_02
hgs
parents:
diff changeset
   819
                        );
7feec50967db 201003_02
hgs
parents:
diff changeset
   820
        
7feec50967db 201003_02
hgs
parents:
diff changeset
   821
        CCaLocalizationEntry* result = CCaLocalizationEntry::NewLC( );
7feec50967db 201003_02
hgs
parents:
diff changeset
   822
        result->SetTextId( locTextId );
7feec50967db 201003_02
hgs
parents:
diff changeset
   823
        result->SetAttributeNameL( attribute );
7feec50967db 201003_02
hgs
parents:
diff changeset
   824
        result->SetStringIdL( stringId );
7feec50967db 201003_02
hgs
parents:
diff changeset
   825
        result->SetRowId( rowId );
7feec50967db 201003_02
hgs
parents:
diff changeset
   826
        result->SetTableNameL( tableName );
94
hgs
parents: 92
diff changeset
   827
        result->SetQmFilenameL( qmFilename );
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   828
        
7feec50967db 201003_02
hgs
parents:
diff changeset
   829
        aResultInput.AppendL( result );
7feec50967db 201003_02
hgs
parents:
diff changeset
   830
        CleanupStack::Pop( result );
7feec50967db 201003_02
hgs
parents:
diff changeset
   831
        rowCount++;
7feec50967db 201003_02
hgs
parents:
diff changeset
   832
        }//while
7feec50967db 201003_02
hgs
parents:
diff changeset
   833
7feec50967db 201003_02
hgs
parents:
diff changeset
   834
    return rowCount;
7feec50967db 201003_02
hgs
parents:
diff changeset
   835
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   836
7feec50967db 201003_02
hgs
parents:
diff changeset
   837
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   838
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   839
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   840
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   841
TInt CCaSqlQuery::ExecutePropertyL( TDes& aPropertyValue )
7feec50967db 201003_02
hgs
parents:
diff changeset
   842
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   843
    TInt rowCount(0);
7feec50967db 201003_02
hgs
parents:
diff changeset
   844
    while( iStatement.Next() == KSqlAtRow )
7feec50967db 201003_02
hgs
parents:
diff changeset
   845
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   846
        TPtrC propertyValue;
7feec50967db 201003_02
hgs
parents:
diff changeset
   847
        User::LeaveIfError( iStatement. ColumnText(
7feec50967db 201003_02
hgs
parents:
diff changeset
   848
                ColumnIndexL( iStatement, KColumnDbValue ), propertyValue ) );
7feec50967db 201003_02
hgs
parents:
diff changeset
   849
        
7feec50967db 201003_02
hgs
parents:
diff changeset
   850
        aPropertyValue.Copy( propertyValue );
7feec50967db 201003_02
hgs
parents:
diff changeset
   851
        
7feec50967db 201003_02
hgs
parents:
diff changeset
   852
        rowCount++;
7feec50967db 201003_02
hgs
parents:
diff changeset
   853
        }//while
7feec50967db 201003_02
hgs
parents:
diff changeset
   854
7feec50967db 201003_02
hgs
parents:
diff changeset
   855
    return rowCount;
7feec50967db 201003_02
hgs
parents:
diff changeset
   856
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   857
7feec50967db 201003_02
hgs
parents:
diff changeset
   858
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   859
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   860
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   861
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   862
TInt CCaSqlQuery::ExecuteAttributeL(
7feec50967db 201003_02
hgs
parents:
diff changeset
   863
        RPointerArray<CCaInnerEntry>& aEntryArray )
7feec50967db 201003_02
hgs
parents:
diff changeset
   864
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   865
    TInt rowCount( 0 );
7feec50967db 201003_02
hgs
parents:
diff changeset
   866
    while( iStatement.Next() == KSqlAtRow )
7feec50967db 201003_02
hgs
parents:
diff changeset
   867
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   868
        TInt idEntry = iStatement.ColumnInt(
7feec50967db 201003_02
hgs
parents:
diff changeset
   869
                ColumnIndexL( iStatement, KColumnAttrEntryID ) );
7feec50967db 201003_02
hgs
parents:
diff changeset
   870
        TPtrC name;
7feec50967db 201003_02
hgs
parents:
diff changeset
   871
        User::LeaveIfError(iStatement.ColumnText(
7feec50967db 201003_02
hgs
parents:
diff changeset
   872
                ColumnIndexL( iStatement, KColumnAttrName), name ) );
7feec50967db 201003_02
hgs
parents:
diff changeset
   873
        TPtrC value;
7feec50967db 201003_02
hgs
parents:
diff changeset
   874
        User::LeaveIfError(iStatement.ColumnText(
7feec50967db 201003_02
hgs
parents:
diff changeset
   875
                ColumnIndexL( iStatement, KColumnAttrValue), value ) );
7feec50967db 201003_02
hgs
parents:
diff changeset
   876
        for( TInt i = 0; i < aEntryArray.Count(); i++ )
7feec50967db 201003_02
hgs
parents:
diff changeset
   877
            {
7feec50967db 201003_02
hgs
parents:
diff changeset
   878
            if( idEntry == aEntryArray[i]->GetId() )
7feec50967db 201003_02
hgs
parents:
diff changeset
   879
                {
7feec50967db 201003_02
hgs
parents:
diff changeset
   880
                aEntryArray[i]->AddAttributeL( name, value );
7feec50967db 201003_02
hgs
parents:
diff changeset
   881
                }
7feec50967db 201003_02
hgs
parents:
diff changeset
   882
            }
7feec50967db 201003_02
hgs
parents:
diff changeset
   883
        rowCount++;
7feec50967db 201003_02
hgs
parents:
diff changeset
   884
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   885
    return rowCount;
7feec50967db 201003_02
hgs
parents:
diff changeset
   886
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   887
7feec50967db 201003_02
hgs
parents:
diff changeset
   888
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   889
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   890
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   891
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   892
TInt CCaSqlQuery::ExecuteL( RArray<TInt>& aResultIdArray,
7feec50967db 201003_02
hgs
parents:
diff changeset
   893
        TTableType aType )
7feec50967db 201003_02
hgs
parents:
diff changeset
   894
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   895
    TInt rowCount( 0 );
7feec50967db 201003_02
hgs
parents:
diff changeset
   896
    TPtrC columnId;
7feec50967db 201003_02
hgs
parents:
diff changeset
   897
    if( aType == CCaSqlQuery::EEntryTable )
7feec50967db 201003_02
hgs
parents:
diff changeset
   898
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   899
        columnId.Set( KColumnEntryId );
7feec50967db 201003_02
hgs
parents:
diff changeset
   900
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   901
    else // aType==CCaSqlQuery::EGroupTable
7feec50967db 201003_02
hgs
parents:
diff changeset
   902
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   903
        columnId.Set( KColumnGEIdGroup );
7feec50967db 201003_02
hgs
parents:
diff changeset
   904
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   905
    while( iStatement.Next() == KSqlAtRow )
7feec50967db 201003_02
hgs
parents:
diff changeset
   906
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   907
        aResultIdArray.AppendL( iStatement.ColumnInt( ColumnIndexL(
7feec50967db 201003_02
hgs
parents:
diff changeset
   908
                iStatement, columnId ) ) );
7feec50967db 201003_02
hgs
parents:
diff changeset
   909
        rowCount++;
7feec50967db 201003_02
hgs
parents:
diff changeset
   910
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   911
    return rowCount;
7feec50967db 201003_02
hgs
parents:
diff changeset
   912
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   913
7feec50967db 201003_02
hgs
parents:
diff changeset
   914
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   915
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   916
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   917
//
92
hgs
parents: 89
diff changeset
   918
TInt CCaSqlQuery::ExecuteL( CCaInnerIconDescription* aInnerIconDescription )
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   919
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   920
    TInt columnCount( 0 );
92
hgs
parents: 89
diff changeset
   921
    
hgs
parents: 89
diff changeset
   922
   RBuf description;
hgs
parents: 89
diff changeset
   923
   description.CleanupClosePushL();
hgs
parents: 89
diff changeset
   924
   description.CreateL(KMaxFileName);
hgs
parents: 89
diff changeset
   925
    
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   926
    while( iStatement.Next() == KSqlAtRow )
7feec50967db 201003_02
hgs
parents:
diff changeset
   927
        {
92
hgs
parents: 89
diff changeset
   928
        aInnerIconDescription->SetId( iStatement.ColumnInt(
hgs
parents: 89
diff changeset
   929
                ColumnIndexL( iStatement, KColumnIconId ) ) );
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   930
        User::LeaveIfError(iStatement.ColumnText(
7feec50967db 201003_02
hgs
parents:
diff changeset
   931
                ColumnIndexL( iStatement, KColumnIcFileName),
92
hgs
parents: 89
diff changeset
   932
                description));
hgs
parents: 89
diff changeset
   933
        aInnerIconDescription->SetFileNameL(description);
hgs
parents: 89
diff changeset
   934
        
88
hgs
parents: 85
diff changeset
   935
        User::LeaveIfError(iStatement.ColumnText(
hgs
parents: 85
diff changeset
   936
                ColumnIndexL( iStatement, KColumnIcSkinId),
92
hgs
parents: 89
diff changeset
   937
                description));
hgs
parents: 89
diff changeset
   938
        aInnerIconDescription->SetSkinIdL(description);
hgs
parents: 89
diff changeset
   939
        
88
hgs
parents: 85
diff changeset
   940
        User::LeaveIfError(iStatement.ColumnText(
hgs
parents: 85
diff changeset
   941
                ColumnIndexL( iStatement, KColumnIcAppId),
92
hgs
parents: 89
diff changeset
   942
                description));
hgs
parents: 89
diff changeset
   943
        aInnerIconDescription->SetApplicationIdL(description);
hgs
parents: 89
diff changeset
   944
        
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   945
        columnCount++;
7feec50967db 201003_02
hgs
parents:
diff changeset
   946
        }
92
hgs
parents: 89
diff changeset
   947
    CleanupStack::PopAndDestroy(&description);
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   948
    return columnCount;
7feec50967db 201003_02
hgs
parents:
diff changeset
   949
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   950
7feec50967db 201003_02
hgs
parents:
diff changeset
   951
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   952
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   953
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   954
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   955
TInt CCaSqlQuery::ColumnIndexL( RSqlStatement& aStmt,
7feec50967db 201003_02
hgs
parents:
diff changeset
   956
        const TDesC& aColumnName ) const
7feec50967db 201003_02
hgs
parents:
diff changeset
   957
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   958
    TInt ret( aStmt.ColumnIndex( aColumnName ) );
7feec50967db 201003_02
hgs
parents:
diff changeset
   959
    User::LeaveIfError( ret );
7feec50967db 201003_02
hgs
parents:
diff changeset
   960
    return ret;
7feec50967db 201003_02
hgs
parents:
diff changeset
   961
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   962