contentstorage/castorage/src/casqlquery.cpp
author hgs
Mon, 20 Sep 2010 10:22:22 +0300
changeset 119 50e220be30d1
parent 99 7aaf39b772ac
child 127 7b66bc3c6dc9
permissions -rw-r--r--
201037
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
    {
119
hgs
parents: 99
diff changeset
   317
    if( aParameterValue.Length() )
hgs
parents: 99
diff changeset
   318
        {
hgs
parents: 99
diff changeset
   319
        User::LeaveIfError( iStatement.BindText( aParameterIndex, 
hgs
parents: 99
diff changeset
   320
                aParameterValue ) );
hgs
parents: 99
diff changeset
   321
        }
hgs
parents: 99
diff changeset
   322
    else
hgs
parents: 99
diff changeset
   323
        {
hgs
parents: 99
diff changeset
   324
        User::LeaveIfError( iStatement.BindNull( aParameterIndex) );
hgs
parents: 99
diff changeset
   325
        }
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   326
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   327
7feec50967db 201003_02
hgs
parents:
diff changeset
   328
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   329
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   330
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   331
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   332
void CCaSqlQuery::BindIntL( TInt aParameterIndex,
7feec50967db 201003_02
hgs
parents:
diff changeset
   333
        TInt aParameterValue )
7feec50967db 201003_02
hgs
parents:
diff changeset
   334
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   335
    User::LeaveIfError( aParameterIndex );
7feec50967db 201003_02
hgs
parents:
diff changeset
   336
    User::LeaveIfError( iStatement.BindInt( aParameterIndex,
7feec50967db 201003_02
hgs
parents:
diff changeset
   337
            aParameterValue ) );
7feec50967db 201003_02
hgs
parents:
diff changeset
   338
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   339
7feec50967db 201003_02
hgs
parents:
diff changeset
   340
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   341
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   342
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   343
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   344
void CCaSqlQuery::BindInt64L( TInt aParameterIndex,
7feec50967db 201003_02
hgs
parents:
diff changeset
   345
        TInt64 aParameterValue )
7feec50967db 201003_02
hgs
parents:
diff changeset
   346
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   347
    User::LeaveIfError( aParameterIndex );
7feec50967db 201003_02
hgs
parents:
diff changeset
   348
    User::LeaveIfError( iStatement.BindInt64( aParameterIndex,
7feec50967db 201003_02
hgs
parents:
diff changeset
   349
            aParameterValue ) );
7feec50967db 201003_02
hgs
parents:
diff changeset
   350
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   351
7feec50967db 201003_02
hgs
parents:
diff changeset
   352
// ---------------------------------------------------------------------------
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
void CCaSqlQuery::SetQueryL( const TDesC& aQuery )
7feec50967db 201003_02
hgs
parents:
diff changeset
   357
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   358
    iQuery.Close();
7feec50967db 201003_02
hgs
parents:
diff changeset
   359
    iQuery.CreateL( aQuery );
7feec50967db 201003_02
hgs
parents:
diff changeset
   360
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   361
7feec50967db 201003_02
hgs
parents:
diff changeset
   362
7feec50967db 201003_02
hgs
parents:
diff changeset
   363
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   364
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   365
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   366
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   367
void CCaSqlQuery::BindValuesForLocalizeL( CCaLocalizationEntry& aLocalization )
7feec50967db 201003_02
hgs
parents:
diff changeset
   368
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   369
    if( iQuery.Find( KSQLLocRowId ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   370
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   371
        BindIntL( iStatement.ParameterIndex( 
7feec50967db 201003_02
hgs
parents:
diff changeset
   372
        		KSQLLocRowId ), aLocalization.GetRowId() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   373
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   374
    if( iQuery.Find( KSQLLocTable ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   375
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   376
        BindTextL(iStatement.ParameterIndex( KSQLLocTable ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   377
                aLocalization.GetTableName() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   378
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   379
    if( iQuery.Find( KSQLLocAttribute ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   380
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   381
        BindTextL(iStatement.ParameterIndex( KSQLLocAttribute ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   382
                aLocalization.GetAttributeName() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   383
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   384
    if( iQuery.Find( KSQLLocString ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   385
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   386
        BindTextL(iStatement.ParameterIndex( KSQLLocString ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   387
                aLocalization.GetLocalizedString() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   388
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   389
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   390
7feec50967db 201003_02
hgs
parents:
diff changeset
   391
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   392
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   393
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   394
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   395
void CCaSqlQuery::BindValuesForPropertyL( const TDesC& aProperty )
7feec50967db 201003_02
hgs
parents:
diff changeset
   396
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   397
    if( iQuery.Find( KSQLDbProperty ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   398
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   399
        BindTextL( iStatement.ParameterIndex( 
7feec50967db 201003_02
hgs
parents:
diff changeset
   400
                KSQLDbProperty ), aProperty );
7feec50967db 201003_02
hgs
parents:
diff changeset
   401
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   402
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   403
7feec50967db 201003_02
hgs
parents:
diff changeset
   404
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   405
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   406
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   407
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   408
void CCaSqlQuery::BindValuesForPropertyUpdateL( const TDesC& aProperty, const TDesC& aPropertyValue )
7feec50967db 201003_02
hgs
parents:
diff changeset
   409
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   410
    BindValuesForPropertyL( aProperty );
7feec50967db 201003_02
hgs
parents:
diff changeset
   411
    
7feec50967db 201003_02
hgs
parents:
diff changeset
   412
    if( iQuery.Find( KSQLDbValue ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   413
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   414
        BindTextL( iStatement.ParameterIndex( 
7feec50967db 201003_02
hgs
parents:
diff changeset
   415
                KSQLDbValue ), aPropertyValue );
7feec50967db 201003_02
hgs
parents:
diff changeset
   416
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   417
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   418
7feec50967db 201003_02
hgs
parents:
diff changeset
   419
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   420
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   421
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   422
//
94
hgs
parents: 92
diff changeset
   423
void CCaSqlQuery::BindValuesForGetLocalizationEntryL(
hgs
parents: 92
diff changeset
   424
        const CCaLocalizationEntry& aLocalization)
hgs
parents: 92
diff changeset
   425
    {
hgs
parents: 92
diff changeset
   426
    BindIntL( iStatement.ParameterIndex( KSQLLocRowId ),
hgs
parents: 92
diff changeset
   427
            aLocalization.GetRowId() );
hgs
parents: 92
diff changeset
   428
    BindTextL( iStatement.ParameterIndex( KSQLLocTable ),
hgs
parents: 92
diff changeset
   429
            aLocalization.GetTableName() );
hgs
parents: 92
diff changeset
   430
    BindTextL( iStatement.ParameterIndex( KSQLLocAttribute ),
hgs
parents: 92
diff changeset
   431
            aLocalization.GetAttributeName() );
hgs
parents: 92
diff changeset
   432
    }
hgs
parents: 92
diff changeset
   433
hgs
parents: 92
diff changeset
   434
// ---------------------------------------------------------------------------
hgs
parents: 92
diff changeset
   435
//
hgs
parents: 92
diff changeset
   436
// ---------------------------------------------------------------------------
hgs
parents: 92
diff changeset
   437
//
hgs
parents: 92
diff changeset
   438
void CCaSqlQuery::BindValuesForLocalizationEntryL(
hgs
parents: 92
diff changeset
   439
        const CCaLocalizationEntry& aLocalization)
hgs
parents: 92
diff changeset
   440
    {
hgs
parents: 92
diff changeset
   441
    BindIntL( iStatement.ParameterIndex( KSQLLocRowId ),
hgs
parents: 92
diff changeset
   442
            aLocalization.GetRowId() );
hgs
parents: 92
diff changeset
   443
    BindTextL( iStatement.ParameterIndex( KSQLLocTable ),
hgs
parents: 92
diff changeset
   444
            aLocalization.GetTableName() );
hgs
parents: 92
diff changeset
   445
    BindTextL( iStatement.ParameterIndex( KSQLLocAttribute ),
hgs
parents: 92
diff changeset
   446
            aLocalization.GetAttributeName() );
hgs
parents: 92
diff changeset
   447
    BindTextL( iStatement.ParameterIndex( KSQLLocQmFilename ),
hgs
parents: 92
diff changeset
   448
            aLocalization.GetQmFilename() );
hgs
parents: 92
diff changeset
   449
    BindTextL( iStatement.ParameterIndex( KSQLLocString ),
hgs
parents: 92
diff changeset
   450
            aLocalization.GetStringId() );
hgs
parents: 92
diff changeset
   451
    }
hgs
parents: 92
diff changeset
   452
hgs
parents: 92
diff changeset
   453
hgs
parents: 92
diff changeset
   454
// ---------------------------------------------------------------------------
hgs
parents: 92
diff changeset
   455
//
hgs
parents: 92
diff changeset
   456
// ---------------------------------------------------------------------------
hgs
parents: 92
diff changeset
   457
//
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   458
void CCaSqlQuery::BindValuesForGetEntriesL( const CCaInnerQuery* aQuery )
7feec50967db 201003_02
hgs
parents:
diff changeset
   459
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   460
    if( aQuery->GetIds().Count() > 0 )
7feec50967db 201003_02
hgs
parents:
diff changeset
   461
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   462
        BindIdsL( aQuery->GetIds(), KSQLEntryId );
7feec50967db 201003_02
hgs
parents:
diff changeset
   463
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   464
    else
7feec50967db 201003_02
hgs
parents:
diff changeset
   465
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   466
        if( aQuery->GetFlagsOn() != 0 && iQuery.Find( KSQLFlagsOn )
7feec50967db 201003_02
hgs
parents:
diff changeset
   467
                != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   468
            {
7feec50967db 201003_02
hgs
parents:
diff changeset
   469
            BindIntL( iStatement.ParameterIndex( KSQLFlagsOn ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   470
                    aQuery->GetFlagsOn() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   471
            }
7feec50967db 201003_02
hgs
parents:
diff changeset
   472
        if( aQuery->GetFlagsOff() != 0 && iQuery.Find( KSQLFlagsOff )
7feec50967db 201003_02
hgs
parents:
diff changeset
   473
                != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   474
            {
7feec50967db 201003_02
hgs
parents:
diff changeset
   475
            BindIntL( iStatement.ParameterIndex( KSQLFlagsOff ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   476
                    aQuery->GetFlagsOff() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   477
            }
7feec50967db 201003_02
hgs
parents:
diff changeset
   478
        if( aQuery->GetRole() != -1 && iQuery.Find( KSQLEnRole )
7feec50967db 201003_02
hgs
parents:
diff changeset
   479
                != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   480
            {
7feec50967db 201003_02
hgs
parents:
diff changeset
   481
            BindIntL( iStatement.ParameterIndex( KSQLEnRole ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   482
                    aQuery->GetRole() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   483
            }
7feec50967db 201003_02
hgs
parents:
diff changeset
   484
        if( aQuery->GetParentId() != -1 && iQuery.Find( KSQLGEIdGroup )
7feec50967db 201003_02
hgs
parents:
diff changeset
   485
                != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   486
            {
7feec50967db 201003_02
hgs
parents:
diff changeset
   487
            BindIntL( iStatement.ParameterIndex( KSQLGEIdGroup ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   488
                    aQuery->GetParentId() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   489
            }
99
hgs
parents: 94
diff changeset
   490
        if( aQuery->GetChildId() != -1 && iQuery.Find( KSQLGEEntryId )
hgs
parents: 94
diff changeset
   491
                != KErrNotFound )
hgs
parents: 94
diff changeset
   492
            {
hgs
parents: 94
diff changeset
   493
            BindIntL( iStatement.ParameterIndex( KSQLGEEntryId ),
hgs
parents: 94
diff changeset
   494
                    aQuery->GetChildId() );
hgs
parents: 94
diff changeset
   495
            }
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   496
        if( aQuery->GetUid() != 0 && iQuery.Find( KSQLEnUid )
7feec50967db 201003_02
hgs
parents:
diff changeset
   497
                != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   498
            {
7feec50967db 201003_02
hgs
parents:
diff changeset
   499
            BindIntL( iStatement.ParameterIndex( KSQLEnUid ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   500
                    aQuery->GetUid() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   501
            }
7feec50967db 201003_02
hgs
parents:
diff changeset
   502
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   503
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   504
7feec50967db 201003_02
hgs
parents:
diff changeset
   505
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   506
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   507
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   508
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   509
void CCaSqlQuery::BindValuesForGetEntriesL( const CCaInnerEntry* aEntry )
7feec50967db 201003_02
hgs
parents:
diff changeset
   510
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   511
    if( iQuery.Find( KSQLEntryId ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   512
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   513
        BindIntL(iStatement.ParameterIndex( KSQLEntryId ), 
7feec50967db 201003_02
hgs
parents:
diff changeset
   514
                aEntry->GetId() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   515
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   516
    if( iQuery.Find( KSQLEnText) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   517
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   518
        BindTextL(iStatement.ParameterIndex( KSQLEnText ), 
7feec50967db 201003_02
hgs
parents:
diff changeset
   519
                aEntry->GetText() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   520
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   521
    if( iQuery.Find( KSQLEnDescription ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   522
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   523
        BindTextL(iStatement.ParameterIndex( KSQLEnDescription ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   524
                aEntry->GetDescription() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   525
        }    
7feec50967db 201003_02
hgs
parents:
diff changeset
   526
    if( iQuery.Find( KSQLEnRole ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   527
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   528
        BindIntL( iStatement.ParameterIndex( KSQLEnRole ), 
7feec50967db 201003_02
hgs
parents:
diff changeset
   529
                aEntry->GetRole() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   530
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   531
    if( iQuery.Find( KSQLEnTypeName ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   532
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   533
        BindTextL( iStatement.ParameterIndex( KSQLEnTypeName ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   534
                aEntry->GetEntryTypeName() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   535
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   536
    if( iQuery.Find( KSQLEnIdIcon ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   537
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   538
        BindIntL( iStatement.ParameterIndex( KSQLEnIdIcon ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   539
                aEntry->GetIconId() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   540
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   541
    if( iQuery.Find( KSQLEnUid ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   542
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   543
        BindIntL( iStatement.ParameterIndex(KSQLEnUid), aEntry->GetUid() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   544
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   545
    if( iQuery.Find( KSQLEnFlags ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   546
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   547
        BindIntL( iStatement.ParameterIndex( KSQLEnFlags ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   548
                aEntry->GetFlags() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   549
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   550
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   551
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   552
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   553
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   554
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   555
void CCaSqlQuery::BindValuesForGetIconL( const CCaInnerEntry* aEntry )
7feec50967db 201003_02
hgs
parents:
diff changeset
   556
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   557
    if( iQuery.Find( KSQLIconId ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   558
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   559
        BindIntL(iStatement.ParameterIndex( KSQLIconId ),
92
hgs
parents: 89
diff changeset
   560
                aEntry->Icon()->Id() );
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   561
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   562
    if( iQuery.Find( KSQLIcFileName ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   563
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   564
        BindTextL( iStatement.ParameterIndex( KSQLIcFileName ),
92
hgs
parents: 89
diff changeset
   565
                aEntry->Icon()->FileName() );
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   566
        }
88
hgs
parents: 85
diff changeset
   567
    if( iQuery.Find( KSQLIcSkinId ) != KErrNotFound )
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   568
        {
88
hgs
parents: 85
diff changeset
   569
        BindTextL( iStatement.ParameterIndex( KSQLIcSkinId ),
92
hgs
parents: 89
diff changeset
   570
                aEntry->Icon()->SkinId() );
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   571
        }
88
hgs
parents: 85
diff changeset
   572
    if( iQuery.Find( KSQLIcAppId ) != KErrNotFound )
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   573
        {
88
hgs
parents: 85
diff changeset
   574
        BindTextL( iStatement.ParameterIndex( KSQLIcAppId ),
92
hgs
parents: 89
diff changeset
   575
                aEntry->Icon()->ApplicationId() );
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   576
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   577
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   578
7feec50967db 201003_02
hgs
parents:
diff changeset
   579
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   580
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   581
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   582
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   583
void CCaSqlQuery::BindEntryIdsL(
7feec50967db 201003_02
hgs
parents:
diff changeset
   584
        const RPointerArray<CCaInnerEntry>& aEntryArray )
7feec50967db 201003_02
hgs
parents:
diff changeset
   585
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   586
    RArray<TInt> entryIdArray;
7feec50967db 201003_02
hgs
parents:
diff changeset
   587
    CleanupClosePushL( entryIdArray );
7feec50967db 201003_02
hgs
parents:
diff changeset
   588
7feec50967db 201003_02
hgs
parents:
diff changeset
   589
    for( TInt i = 0; i < aEntryArray.Count(); i++ )
7feec50967db 201003_02
hgs
parents:
diff changeset
   590
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   591
        entryIdArray.AppendL( aEntryArray[i]->GetId() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   592
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   593
    BindIdsL( entryIdArray, KSQLEntryId );
7feec50967db 201003_02
hgs
parents:
diff changeset
   594
    CleanupStack::PopAndDestroy( &entryIdArray );
7feec50967db 201003_02
hgs
parents:
diff changeset
   595
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   596
7feec50967db 201003_02
hgs
parents:
diff changeset
   597
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   598
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   599
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   600
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   601
void CCaSqlQuery::BindIdsL( const RArray<TInt>& aEntryIdArray,
7feec50967db 201003_02
hgs
parents:
diff changeset
   602
        const TDesC& aColName )
7feec50967db 201003_02
hgs
parents:
diff changeset
   603
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   604
    RBuf bindKey;
7feec50967db 201003_02
hgs
parents:
diff changeset
   605
    bindKey.CleanupClosePushL();
7feec50967db 201003_02
hgs
parents:
diff changeset
   606
    bindKey.CreateL( aColName.Length() + KMaxIntNumLength );
7feec50967db 201003_02
hgs
parents:
diff changeset
   607
    for( TInt i = 0; i < aEntryIdArray.Count() ; i++ )
7feec50967db 201003_02
hgs
parents:
diff changeset
   608
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   609
        bindKey.Copy( KNullDesC );
7feec50967db 201003_02
hgs
parents:
diff changeset
   610
        bindKey.Append( aColName );
7feec50967db 201003_02
hgs
parents:
diff changeset
   611
        bindKey.AppendNum( i );
7feec50967db 201003_02
hgs
parents:
diff changeset
   612
        if( iQuery.Find( bindKey ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   613
            {
7feec50967db 201003_02
hgs
parents:
diff changeset
   614
            BindIntL( iStatement.ParameterIndex( bindKey ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   615
                    aEntryIdArray[i] );
7feec50967db 201003_02
hgs
parents:
diff changeset
   616
            }
7feec50967db 201003_02
hgs
parents:
diff changeset
   617
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   618
    CleanupStack::PopAndDestroy( &bindKey );
7feec50967db 201003_02
hgs
parents:
diff changeset
   619
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   620
7feec50967db 201003_02
hgs
parents:
diff changeset
   621
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   622
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   623
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   624
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   625
void CCaSqlQuery::BindEntryIdL( const TInt& aEntryId )
7feec50967db 201003_02
hgs
parents:
diff changeset
   626
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   627
    if( iQuery.Find( KSQLEntryId ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   628
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   629
        BindIntL( iStatement.ParameterIndex( KSQLEntryId ), aEntryId );
7feec50967db 201003_02
hgs
parents:
diff changeset
   630
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   631
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   632
7feec50967db 201003_02
hgs
parents:
diff changeset
   633
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   634
// CCaSqlQuery::BindValuesForRemoveFromLocalizationL(  const TInt 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
void CCaSqlQuery::BindValuesForRemoveFromLocalizationL(  const TInt aEntryId )
7feec50967db 201003_02
hgs
parents:
diff changeset
   638
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   639
    if( iQuery.Find( KSQLLocRowId ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   640
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   641
        BindIntL( iStatement.ParameterIndex( KSQLLocRowId ), aEntryId );
7feec50967db 201003_02
hgs
parents:
diff changeset
   642
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   643
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   644
7feec50967db 201003_02
hgs
parents:
diff changeset
   645
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   646
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   647
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   648
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   649
TInt CCaSqlQuery::ExecuteL()
7feec50967db 201003_02
hgs
parents:
diff changeset
   650
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   651
    User::LeaveIfError( iStatement.Exec() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   652
    TSqlScalarFullSelectQuery id_query( iSqlDb );
7feec50967db 201003_02
hgs
parents:
diff changeset
   653
    return id_query.SelectIntL( KSQLGetLastInsertId );
7feec50967db 201003_02
hgs
parents:
diff changeset
   654
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   655
7feec50967db 201003_02
hgs
parents:
diff changeset
   656
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   657
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   658
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   659
//
94
hgs
parents: 92
diff changeset
   660
TBool CCaSqlQuery::ExecuteEntryPresentL( )
hgs
parents: 92
diff changeset
   661
    {
hgs
parents: 92
diff changeset
   662
    if( iStatement.Next() == KSqlAtRow )
hgs
parents: 92
diff changeset
   663
        {
hgs
parents: 92
diff changeset
   664
        return ETrue;
hgs
parents: 92
diff changeset
   665
        }
hgs
parents: 92
diff changeset
   666
    return EFalse;
hgs
parents: 92
diff changeset
   667
    }
hgs
parents: 92
diff changeset
   668
hgs
parents: 92
diff changeset
   669
// ---------------------------------------------------------------------------
hgs
parents: 92
diff changeset
   670
//
hgs
parents: 92
diff changeset
   671
// ---------------------------------------------------------------------------
hgs
parents: 92
diff changeset
   672
//
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   673
TInt CCaSqlQuery::ExecuteL( TInt& aId )
7feec50967db 201003_02
hgs
parents:
diff changeset
   674
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   675
    if( iStatement.Next() == KSqlAtRow )
7feec50967db 201003_02
hgs
parents:
diff changeset
   676
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   677
        aId = iStatement.ColumnInt( ColumnIndexL( iStatement,
7feec50967db 201003_02
hgs
parents:
diff changeset
   678
                KColumnSingleData ) );
7feec50967db 201003_02
hgs
parents:
diff changeset
   679
        return 1;
7feec50967db 201003_02
hgs
parents:
diff changeset
   680
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   681
    return 0;
7feec50967db 201003_02
hgs
parents:
diff changeset
   682
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   683
7feec50967db 201003_02
hgs
parents:
diff changeset
   684
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   685
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   686
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   687
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   688
TInt CCaSqlQuery::ExecuteL( TInt64& aId )
7feec50967db 201003_02
hgs
parents:
diff changeset
   689
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   690
    if( iStatement.Next() == KSqlAtRow )
7feec50967db 201003_02
hgs
parents:
diff changeset
   691
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   692
        aId = iStatement.ColumnInt64(ColumnIndexL( iStatement,
7feec50967db 201003_02
hgs
parents:
diff changeset
   693
                KColumnSingleData ) );
7feec50967db 201003_02
hgs
parents:
diff changeset
   694
        return 1;
7feec50967db 201003_02
hgs
parents:
diff changeset
   695
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   696
    return 0;
7feec50967db 201003_02
hgs
parents:
diff changeset
   697
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   698
7feec50967db 201003_02
hgs
parents:
diff changeset
   699
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   700
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   701
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   702
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   703
TInt CCaSqlQuery::ExecuteL( RPointerArray<CCaInnerEntry>& result,
7feec50967db 201003_02
hgs
parents:
diff changeset
   704
        TQueryResultType aResultType )
7feec50967db 201003_02
hgs
parents:
diff changeset
   705
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   706
    TInt rowCount( 0 );
7feec50967db 201003_02
hgs
parents:
diff changeset
   707
    if( aResultType==CCaSqlQuery::EEntry )
7feec50967db 201003_02
hgs
parents:
diff changeset
   708
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   709
        rowCount = ExecuteEntryL( result );
7feec50967db 201003_02
hgs
parents:
diff changeset
   710
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   711
    else // aResultType==CCaSqlQuery::EAttribute
7feec50967db 201003_02
hgs
parents:
diff changeset
   712
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   713
        rowCount = ExecuteAttributeL( result );
7feec50967db 201003_02
hgs
parents:
diff changeset
   714
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   715
    return rowCount;
7feec50967db 201003_02
hgs
parents:
diff changeset
   716
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   717
7feec50967db 201003_02
hgs
parents:
diff changeset
   718
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   719
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   720
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   721
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   722
TInt CCaSqlQuery::ExecuteEntryL(
7feec50967db 201003_02
hgs
parents:
diff changeset
   723
        RPointerArray<CCaInnerEntry>& aResultInput )
7feec50967db 201003_02
hgs
parents:
diff changeset
   724
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   725
    TInt rowCount(0);
7feec50967db 201003_02
hgs
parents:
diff changeset
   726
    while( iStatement.Next() == KSqlAtRow )
7feec50967db 201003_02
hgs
parents:
diff changeset
   727
        {
89
hgs
parents: 88
diff changeset
   728
        TInt entryId = iStatement.ColumnInt( 
hgs
parents: 88
diff changeset
   729
        		ColumnIndexL( iStatement, KColumnEntryId ) );
hgs
parents: 88
diff changeset
   730
        TInt role = iStatement.ColumnInt( 
hgs
parents: 88
diff changeset
   731
        		ColumnIndexL( iStatement, KColumnEnRole ) );
hgs
parents: 88
diff changeset
   732
        TInt32 uid = iStatement.ColumnInt( 
hgs
parents: 88
diff changeset
   733
        		ColumnIndexL( iStatement, KColumnEnUid ) );
hgs
parents: 88
diff changeset
   734
        TUint flags = iStatement.ColumnInt( 
hgs
parents: 88
diff changeset
   735
        		ColumnIndexL( iStatement, KColumnEnFlags ) );
hgs
parents: 88
diff changeset
   736
        TInt idIcon = iStatement.ColumnInt( 
hgs
parents: 88
diff changeset
   737
        		ColumnIndexL( iStatement, KColumnEnIdIcon ) );
88
hgs
parents: 85
diff changeset
   738
        
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   739
        TPtrC text;
7feec50967db 201003_02
hgs
parents:
diff changeset
   740
        User::LeaveIfError( iStatement. ColumnText( ColumnIndexL(
7feec50967db 201003_02
hgs
parents:
diff changeset
   741
                iStatement, KColumnEnText ), text ) );
7feec50967db 201003_02
hgs
parents:
diff changeset
   742
        TPtrC description;
7feec50967db 201003_02
hgs
parents:
diff changeset
   743
        User::LeaveIfError( iStatement.
7feec50967db 201003_02
hgs
parents:
diff changeset
   744
                ColumnText( ColumnIndexL( iStatement, KColumnEnDescription ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   745
                description) );      
7feec50967db 201003_02
hgs
parents:
diff changeset
   746
        TPtrC typeName;
7feec50967db 201003_02
hgs
parents:
diff changeset
   747
        User::LeaveIfError( iStatement.ColumnText( 
7feec50967db 201003_02
hgs
parents:
diff changeset
   748
                ColumnIndexL(iStatement, KColumnEnTypeName ), typeName) );
88
hgs
parents: 85
diff changeset
   749
                
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   750
        TPtrC iconFilename;
7feec50967db 201003_02
hgs
parents:
diff changeset
   751
        User::LeaveIfError( iStatement.ColumnText( ColumnIndexL(
7feec50967db 201003_02
hgs
parents:
diff changeset
   752
                iStatement, KColumnIcFileName ), iconFilename ) );
7feec50967db 201003_02
hgs
parents:
diff changeset
   753
88
hgs
parents: 85
diff changeset
   754
        TPtrC iconSkinId;
hgs
parents: 85
diff changeset
   755
        User::LeaveIfError( iStatement.ColumnText( ColumnIndexL(
hgs
parents: 85
diff changeset
   756
                iStatement, KColumnIcSkinId ), iconSkinId ) );
hgs
parents: 85
diff changeset
   757
hgs
parents: 85
diff changeset
   758
        TPtrC iconApplicationId;
hgs
parents: 85
diff changeset
   759
        User::LeaveIfError( iStatement.ColumnText( ColumnIndexL(
hgs
parents: 85
diff changeset
   760
                iStatement, KColumnIcAppId ), iconApplicationId ) );
hgs
parents: 85
diff changeset
   761
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   762
        CCaInnerEntry* result = CCaInnerEntry::NewLC();
7feec50967db 201003_02
hgs
parents:
diff changeset
   763
        result->SetId( entryId );
7feec50967db 201003_02
hgs
parents:
diff changeset
   764
        result->SetRole( role );
88
hgs
parents: 85
diff changeset
   765
        result->SetIconDataL(
hgs
parents: 85
diff changeset
   766
                iconFilename, iconSkinId, iconApplicationId );
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   767
        result->SetIconId( idIcon );
7feec50967db 201003_02
hgs
parents:
diff changeset
   768
        result->SetFlags( flags );
7feec50967db 201003_02
hgs
parents:
diff changeset
   769
        result->SetUid( uid );
7feec50967db 201003_02
hgs
parents:
diff changeset
   770
        result->SetTextL( text );
7feec50967db 201003_02
hgs
parents:
diff changeset
   771
        result->SetDescriptionL( description );
7feec50967db 201003_02
hgs
parents:
diff changeset
   772
        result->SetEntryTypeNameL( typeName );
7feec50967db 201003_02
hgs
parents:
diff changeset
   773
7feec50967db 201003_02
hgs
parents:
diff changeset
   774
        aResultInput.AppendL( result );
7feec50967db 201003_02
hgs
parents:
diff changeset
   775
        CleanupStack::Pop( result );
7feec50967db 201003_02
hgs
parents:
diff changeset
   776
        rowCount++;
7feec50967db 201003_02
hgs
parents:
diff changeset
   777
        }//while
7feec50967db 201003_02
hgs
parents:
diff changeset
   778
7feec50967db 201003_02
hgs
parents:
diff changeset
   779
    return rowCount;
7feec50967db 201003_02
hgs
parents:
diff changeset
   780
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   781
7feec50967db 201003_02
hgs
parents:
diff changeset
   782
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   783
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   784
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   785
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   786
TInt CCaSqlQuery::ExecuteLocalizationsL(
7feec50967db 201003_02
hgs
parents:
diff changeset
   787
        RPointerArray<CCaLocalizationEntry>& aResultInput )
7feec50967db 201003_02
hgs
parents:
diff changeset
   788
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   789
    TInt rowCount(0);
7feec50967db 201003_02
hgs
parents:
diff changeset
   790
    while( iStatement.Next() == KSqlAtRow )
7feec50967db 201003_02
hgs
parents:
diff changeset
   791
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   792
        TInt locTextId = iStatement.ColumnInt(
7feec50967db 201003_02
hgs
parents:
diff changeset
   793
                ColumnIndexL( iStatement, KColumnLocTextId )
7feec50967db 201003_02
hgs
parents:
diff changeset
   794
                );
7feec50967db 201003_02
hgs
parents:
diff changeset
   795
        
7feec50967db 201003_02
hgs
parents:
diff changeset
   796
        TInt rowId = iStatement.ColumnInt(
7feec50967db 201003_02
hgs
parents:
diff changeset
   797
                ColumnIndexL( iStatement, KColumnLocRowId ) 
7feec50967db 201003_02
hgs
parents:
diff changeset
   798
                );
7feec50967db 201003_02
hgs
parents:
diff changeset
   799
         
7feec50967db 201003_02
hgs
parents:
diff changeset
   800
        TPtrC tableName;
7feec50967db 201003_02
hgs
parents:
diff changeset
   801
        User::LeaveIfError(
7feec50967db 201003_02
hgs
parents:
diff changeset
   802
                iStatement.ColumnText(
7feec50967db 201003_02
hgs
parents:
diff changeset
   803
                        ColumnIndexL( iStatement, KColumnLocTableName ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   804
                        tableName )
7feec50967db 201003_02
hgs
parents:
diff changeset
   805
                        );
7feec50967db 201003_02
hgs
parents:
diff changeset
   806
        
94
hgs
parents: 92
diff changeset
   807
        TPtrC qmFilename;
hgs
parents: 92
diff changeset
   808
        User::LeaveIfError(
hgs
parents: 92
diff changeset
   809
                iStatement.ColumnText(
hgs
parents: 92
diff changeset
   810
                        ColumnIndexL( iStatement, KColumnQmFile ),
hgs
parents: 92
diff changeset
   811
                        qmFilename )
hgs
parents: 92
diff changeset
   812
                        );
hgs
parents: 92
diff changeset
   813
        
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   814
        TPtrC attribute;
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, KColumnLocAttrName ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   818
                        attribute )
7feec50967db 201003_02
hgs
parents:
diff changeset
   819
                        );  
7feec50967db 201003_02
hgs
parents:
diff changeset
   820
        
7feec50967db 201003_02
hgs
parents:
diff changeset
   821
        TPtrC stringId;
7feec50967db 201003_02
hgs
parents:
diff changeset
   822
        User::LeaveIfError(
7feec50967db 201003_02
hgs
parents:
diff changeset
   823
                iStatement.ColumnText(
7feec50967db 201003_02
hgs
parents:
diff changeset
   824
                        ColumnIndexL( iStatement, KColumnLocStringId ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   825
                        stringId )
7feec50967db 201003_02
hgs
parents:
diff changeset
   826
                        );
7feec50967db 201003_02
hgs
parents:
diff changeset
   827
        
7feec50967db 201003_02
hgs
parents:
diff changeset
   828
        CCaLocalizationEntry* result = CCaLocalizationEntry::NewLC( );
7feec50967db 201003_02
hgs
parents:
diff changeset
   829
        result->SetTextId( locTextId );
7feec50967db 201003_02
hgs
parents:
diff changeset
   830
        result->SetAttributeNameL( attribute );
7feec50967db 201003_02
hgs
parents:
diff changeset
   831
        result->SetStringIdL( stringId );
7feec50967db 201003_02
hgs
parents:
diff changeset
   832
        result->SetRowId( rowId );
7feec50967db 201003_02
hgs
parents:
diff changeset
   833
        result->SetTableNameL( tableName );
94
hgs
parents: 92
diff changeset
   834
        result->SetQmFilenameL( qmFilename );
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   835
        
7feec50967db 201003_02
hgs
parents:
diff changeset
   836
        aResultInput.AppendL( result );
7feec50967db 201003_02
hgs
parents:
diff changeset
   837
        CleanupStack::Pop( result );
7feec50967db 201003_02
hgs
parents:
diff changeset
   838
        rowCount++;
7feec50967db 201003_02
hgs
parents:
diff changeset
   839
        }//while
7feec50967db 201003_02
hgs
parents:
diff changeset
   840
7feec50967db 201003_02
hgs
parents:
diff changeset
   841
    return rowCount;
7feec50967db 201003_02
hgs
parents:
diff changeset
   842
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   843
7feec50967db 201003_02
hgs
parents:
diff changeset
   844
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   845
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   846
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   847
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   848
TInt CCaSqlQuery::ExecutePropertyL( TDes& aPropertyValue )
7feec50967db 201003_02
hgs
parents:
diff changeset
   849
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   850
    TInt rowCount(0);
7feec50967db 201003_02
hgs
parents:
diff changeset
   851
    while( iStatement.Next() == KSqlAtRow )
7feec50967db 201003_02
hgs
parents:
diff changeset
   852
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   853
        TPtrC propertyValue;
7feec50967db 201003_02
hgs
parents:
diff changeset
   854
        User::LeaveIfError( iStatement. ColumnText(
7feec50967db 201003_02
hgs
parents:
diff changeset
   855
                ColumnIndexL( iStatement, KColumnDbValue ), propertyValue ) );
7feec50967db 201003_02
hgs
parents:
diff changeset
   856
        
7feec50967db 201003_02
hgs
parents:
diff changeset
   857
        aPropertyValue.Copy( propertyValue );
7feec50967db 201003_02
hgs
parents:
diff changeset
   858
        
7feec50967db 201003_02
hgs
parents:
diff changeset
   859
        rowCount++;
7feec50967db 201003_02
hgs
parents:
diff changeset
   860
        }//while
7feec50967db 201003_02
hgs
parents:
diff changeset
   861
7feec50967db 201003_02
hgs
parents:
diff changeset
   862
    return rowCount;
7feec50967db 201003_02
hgs
parents:
diff changeset
   863
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   864
7feec50967db 201003_02
hgs
parents:
diff changeset
   865
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   866
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   867
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   868
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   869
TInt CCaSqlQuery::ExecuteAttributeL(
7feec50967db 201003_02
hgs
parents:
diff changeset
   870
        RPointerArray<CCaInnerEntry>& aEntryArray )
7feec50967db 201003_02
hgs
parents:
diff changeset
   871
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   872
    TInt rowCount( 0 );
7feec50967db 201003_02
hgs
parents:
diff changeset
   873
    while( iStatement.Next() == KSqlAtRow )
7feec50967db 201003_02
hgs
parents:
diff changeset
   874
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   875
        TInt idEntry = iStatement.ColumnInt(
7feec50967db 201003_02
hgs
parents:
diff changeset
   876
                ColumnIndexL( iStatement, KColumnAttrEntryID ) );
7feec50967db 201003_02
hgs
parents:
diff changeset
   877
        TPtrC name;
7feec50967db 201003_02
hgs
parents:
diff changeset
   878
        User::LeaveIfError(iStatement.ColumnText(
7feec50967db 201003_02
hgs
parents:
diff changeset
   879
                ColumnIndexL( iStatement, KColumnAttrName), name ) );
7feec50967db 201003_02
hgs
parents:
diff changeset
   880
        TPtrC value;
7feec50967db 201003_02
hgs
parents:
diff changeset
   881
        User::LeaveIfError(iStatement.ColumnText(
7feec50967db 201003_02
hgs
parents:
diff changeset
   882
                ColumnIndexL( iStatement, KColumnAttrValue), value ) );
7feec50967db 201003_02
hgs
parents:
diff changeset
   883
        for( TInt i = 0; i < aEntryArray.Count(); i++ )
7feec50967db 201003_02
hgs
parents:
diff changeset
   884
            {
7feec50967db 201003_02
hgs
parents:
diff changeset
   885
            if( idEntry == aEntryArray[i]->GetId() )
7feec50967db 201003_02
hgs
parents:
diff changeset
   886
                {
7feec50967db 201003_02
hgs
parents:
diff changeset
   887
                aEntryArray[i]->AddAttributeL( name, value );
7feec50967db 201003_02
hgs
parents:
diff changeset
   888
                }
7feec50967db 201003_02
hgs
parents:
diff changeset
   889
            }
7feec50967db 201003_02
hgs
parents:
diff changeset
   890
        rowCount++;
7feec50967db 201003_02
hgs
parents:
diff changeset
   891
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   892
    return rowCount;
7feec50967db 201003_02
hgs
parents:
diff changeset
   893
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   894
7feec50967db 201003_02
hgs
parents:
diff changeset
   895
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   896
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   897
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   898
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   899
TInt CCaSqlQuery::ExecuteL( RArray<TInt>& aResultIdArray,
7feec50967db 201003_02
hgs
parents:
diff changeset
   900
        TTableType aType )
7feec50967db 201003_02
hgs
parents:
diff changeset
   901
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   902
    TInt rowCount( 0 );
7feec50967db 201003_02
hgs
parents:
diff changeset
   903
    TPtrC columnId;
7feec50967db 201003_02
hgs
parents:
diff changeset
   904
    if( aType == CCaSqlQuery::EEntryTable )
7feec50967db 201003_02
hgs
parents:
diff changeset
   905
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   906
        columnId.Set( KColumnEntryId );
7feec50967db 201003_02
hgs
parents:
diff changeset
   907
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   908
    else // aType==CCaSqlQuery::EGroupTable
7feec50967db 201003_02
hgs
parents:
diff changeset
   909
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   910
        columnId.Set( KColumnGEIdGroup );
7feec50967db 201003_02
hgs
parents:
diff changeset
   911
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   912
    while( iStatement.Next() == KSqlAtRow )
7feec50967db 201003_02
hgs
parents:
diff changeset
   913
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   914
        aResultIdArray.AppendL( iStatement.ColumnInt( ColumnIndexL(
7feec50967db 201003_02
hgs
parents:
diff changeset
   915
                iStatement, columnId ) ) );
7feec50967db 201003_02
hgs
parents:
diff changeset
   916
        rowCount++;
7feec50967db 201003_02
hgs
parents:
diff changeset
   917
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   918
    return rowCount;
7feec50967db 201003_02
hgs
parents:
diff changeset
   919
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   920
7feec50967db 201003_02
hgs
parents:
diff changeset
   921
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   922
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   923
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   924
//
92
hgs
parents: 89
diff changeset
   925
TInt CCaSqlQuery::ExecuteL( CCaInnerIconDescription* aInnerIconDescription )
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   926
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   927
    TInt columnCount( 0 );
92
hgs
parents: 89
diff changeset
   928
    
hgs
parents: 89
diff changeset
   929
   RBuf description;
hgs
parents: 89
diff changeset
   930
   description.CleanupClosePushL();
hgs
parents: 89
diff changeset
   931
   description.CreateL(KMaxFileName);
hgs
parents: 89
diff changeset
   932
    
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   933
    while( iStatement.Next() == KSqlAtRow )
7feec50967db 201003_02
hgs
parents:
diff changeset
   934
        {
92
hgs
parents: 89
diff changeset
   935
        aInnerIconDescription->SetId( iStatement.ColumnInt(
hgs
parents: 89
diff changeset
   936
                ColumnIndexL( iStatement, KColumnIconId ) ) );
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   937
        User::LeaveIfError(iStatement.ColumnText(
7feec50967db 201003_02
hgs
parents:
diff changeset
   938
                ColumnIndexL( iStatement, KColumnIcFileName),
92
hgs
parents: 89
diff changeset
   939
                description));
hgs
parents: 89
diff changeset
   940
        aInnerIconDescription->SetFileNameL(description);
hgs
parents: 89
diff changeset
   941
        
88
hgs
parents: 85
diff changeset
   942
        User::LeaveIfError(iStatement.ColumnText(
hgs
parents: 85
diff changeset
   943
                ColumnIndexL( iStatement, KColumnIcSkinId),
92
hgs
parents: 89
diff changeset
   944
                description));
hgs
parents: 89
diff changeset
   945
        aInnerIconDescription->SetSkinIdL(description);
hgs
parents: 89
diff changeset
   946
        
88
hgs
parents: 85
diff changeset
   947
        User::LeaveIfError(iStatement.ColumnText(
hgs
parents: 85
diff changeset
   948
                ColumnIndexL( iStatement, KColumnIcAppId),
92
hgs
parents: 89
diff changeset
   949
                description));
hgs
parents: 89
diff changeset
   950
        aInnerIconDescription->SetApplicationIdL(description);
hgs
parents: 89
diff changeset
   951
        
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   952
        columnCount++;
7feec50967db 201003_02
hgs
parents:
diff changeset
   953
        }
92
hgs
parents: 89
diff changeset
   954
    CleanupStack::PopAndDestroy(&description);
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   955
    return columnCount;
7feec50967db 201003_02
hgs
parents:
diff changeset
   956
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   957
7feec50967db 201003_02
hgs
parents:
diff changeset
   958
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   959
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   960
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   961
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   962
TInt CCaSqlQuery::ColumnIndexL( RSqlStatement& aStmt,
7feec50967db 201003_02
hgs
parents:
diff changeset
   963
        const TDesC& aColumnName ) const
7feec50967db 201003_02
hgs
parents:
diff changeset
   964
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   965
    TInt ret( aStmt.ColumnIndex( aColumnName ) );
7feec50967db 201003_02
hgs
parents:
diff changeset
   966
    User::LeaveIfError( ret );
7feec50967db 201003_02
hgs
parents:
diff changeset
   967
    return ret;
7feec50967db 201003_02
hgs
parents:
diff changeset
   968
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   969