contentstorage/castorage/src/casqlquery.cpp
author hgs
Fri, 16 Apr 2010 14:45:49 +0300
changeset 92 782e3408c2ab
parent 89 1e87eb3b400f
child 94 dbb8300717f7
permissions -rw-r--r--
201015
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
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   416
void CCaSqlQuery::BindValuesForGetEntriesL( const CCaInnerQuery* aQuery )
7feec50967db 201003_02
hgs
parents:
diff changeset
   417
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   418
    if( aQuery->GetIds().Count() > 0 )
7feec50967db 201003_02
hgs
parents:
diff changeset
   419
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   420
        BindIdsL( aQuery->GetIds(), KSQLEntryId );
7feec50967db 201003_02
hgs
parents:
diff changeset
   421
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   422
    else
7feec50967db 201003_02
hgs
parents:
diff changeset
   423
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   424
        if( aQuery->GetFlagsOn() != 0 && iQuery.Find( KSQLFlagsOn )
7feec50967db 201003_02
hgs
parents:
diff changeset
   425
                != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   426
            {
7feec50967db 201003_02
hgs
parents:
diff changeset
   427
            BindIntL( iStatement.ParameterIndex( KSQLFlagsOn ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   428
                    aQuery->GetFlagsOn() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   429
            }
7feec50967db 201003_02
hgs
parents:
diff changeset
   430
        if( aQuery->GetFlagsOff() != 0 && iQuery.Find( KSQLFlagsOff )
7feec50967db 201003_02
hgs
parents:
diff changeset
   431
                != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   432
            {
7feec50967db 201003_02
hgs
parents:
diff changeset
   433
            BindIntL( iStatement.ParameterIndex( KSQLFlagsOff ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   434
                    aQuery->GetFlagsOff() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   435
            }
7feec50967db 201003_02
hgs
parents:
diff changeset
   436
        if( aQuery->GetRole() != -1 && iQuery.Find( KSQLEnRole )
7feec50967db 201003_02
hgs
parents:
diff changeset
   437
                != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   438
            {
7feec50967db 201003_02
hgs
parents:
diff changeset
   439
            BindIntL( iStatement.ParameterIndex( KSQLEnRole ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   440
                    aQuery->GetRole() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   441
            }
7feec50967db 201003_02
hgs
parents:
diff changeset
   442
        if( aQuery->GetParentId() != -1 && iQuery.Find( KSQLGEIdGroup )
7feec50967db 201003_02
hgs
parents:
diff changeset
   443
                != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   444
            {
7feec50967db 201003_02
hgs
parents:
diff changeset
   445
            BindIntL( iStatement.ParameterIndex( KSQLGEIdGroup ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   446
                    aQuery->GetParentId() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   447
            }
7feec50967db 201003_02
hgs
parents:
diff changeset
   448
        if( aQuery->GetUid() != 0 && iQuery.Find( KSQLEnUid )
7feec50967db 201003_02
hgs
parents:
diff changeset
   449
                != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   450
            {
7feec50967db 201003_02
hgs
parents:
diff changeset
   451
            BindIntL( iStatement.ParameterIndex( KSQLEnUid ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   452
                    aQuery->GetUid() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   453
            }
7feec50967db 201003_02
hgs
parents:
diff changeset
   454
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   455
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   456
7feec50967db 201003_02
hgs
parents:
diff changeset
   457
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   458
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   459
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   460
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   461
void CCaSqlQuery::BindValuesForGetEntriesL( const CCaInnerEntry* aEntry )
7feec50967db 201003_02
hgs
parents:
diff changeset
   462
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   463
    if( iQuery.Find( KSQLEntryId ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   464
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   465
        BindIntL(iStatement.ParameterIndex( KSQLEntryId ), 
7feec50967db 201003_02
hgs
parents:
diff changeset
   466
                aEntry->GetId() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   467
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   468
    if( iQuery.Find( KSQLEnText) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   469
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   470
        BindTextL(iStatement.ParameterIndex( KSQLEnText ), 
7feec50967db 201003_02
hgs
parents:
diff changeset
   471
                aEntry->GetText() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   472
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   473
    if( iQuery.Find( KSQLEnDescription ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   474
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   475
        BindTextL(iStatement.ParameterIndex( KSQLEnDescription ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   476
                aEntry->GetDescription() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   477
        }    
7feec50967db 201003_02
hgs
parents:
diff changeset
   478
    if( iQuery.Find( KSQLEnRole ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   479
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   480
        BindIntL( iStatement.ParameterIndex( KSQLEnRole ), 
7feec50967db 201003_02
hgs
parents:
diff changeset
   481
                aEntry->GetRole() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   482
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   483
    if( iQuery.Find( KSQLEnTypeName ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   484
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   485
        BindTextL( iStatement.ParameterIndex( KSQLEnTypeName ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   486
                aEntry->GetEntryTypeName() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   487
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   488
    if( iQuery.Find( KSQLEnIdIcon ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   489
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   490
        BindIntL( iStatement.ParameterIndex( KSQLEnIdIcon ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   491
                aEntry->GetIconId() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   492
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   493
    if( iQuery.Find( KSQLEnUid ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   494
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   495
        BindIntL( iStatement.ParameterIndex(KSQLEnUid), aEntry->GetUid() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   496
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   497
    if( iQuery.Find( KSQLEnFlags ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   498
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   499
        BindIntL( iStatement.ParameterIndex( KSQLEnFlags ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   500
                aEntry->GetFlags() );
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
void CCaSqlQuery::BindValuesForGetIconL( const CCaInnerEntry* aEntry )
7feec50967db 201003_02
hgs
parents:
diff changeset
   508
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   509
    if( iQuery.Find( KSQLIconId ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   510
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   511
        BindIntL(iStatement.ParameterIndex( KSQLIconId ),
92
hgs
parents: 89
diff changeset
   512
                aEntry->Icon()->Id() );
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   513
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   514
    if( iQuery.Find( KSQLIcFileName ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   515
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   516
        BindTextL( iStatement.ParameterIndex( KSQLIcFileName ),
92
hgs
parents: 89
diff changeset
   517
                aEntry->Icon()->FileName() );
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   518
        }
88
hgs
parents: 85
diff changeset
   519
    if( iQuery.Find( KSQLIcSkinId ) != KErrNotFound )
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   520
        {
88
hgs
parents: 85
diff changeset
   521
        BindTextL( iStatement.ParameterIndex( KSQLIcSkinId ),
92
hgs
parents: 89
diff changeset
   522
                aEntry->Icon()->SkinId() );
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   523
        }
88
hgs
parents: 85
diff changeset
   524
    if( iQuery.Find( KSQLIcAppId ) != KErrNotFound )
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   525
        {
88
hgs
parents: 85
diff changeset
   526
        BindTextL( iStatement.ParameterIndex( KSQLIcAppId ),
92
hgs
parents: 89
diff changeset
   527
                aEntry->Icon()->ApplicationId() );
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   528
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   529
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   530
7feec50967db 201003_02
hgs
parents:
diff changeset
   531
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   532
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   533
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   534
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   535
void CCaSqlQuery::BindEntryIdsL(
7feec50967db 201003_02
hgs
parents:
diff changeset
   536
        const RPointerArray<CCaInnerEntry>& aEntryArray )
7feec50967db 201003_02
hgs
parents:
diff changeset
   537
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   538
    RArray<TInt> entryIdArray;
7feec50967db 201003_02
hgs
parents:
diff changeset
   539
    CleanupClosePushL( entryIdArray );
7feec50967db 201003_02
hgs
parents:
diff changeset
   540
7feec50967db 201003_02
hgs
parents:
diff changeset
   541
    for( TInt i = 0; i < aEntryArray.Count(); i++ )
7feec50967db 201003_02
hgs
parents:
diff changeset
   542
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   543
        entryIdArray.AppendL( aEntryArray[i]->GetId() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   544
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   545
    BindIdsL( entryIdArray, KSQLEntryId );
7feec50967db 201003_02
hgs
parents:
diff changeset
   546
    CleanupStack::PopAndDestroy( &entryIdArray );
7feec50967db 201003_02
hgs
parents:
diff changeset
   547
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   548
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
void CCaSqlQuery::BindIdsL( const RArray<TInt>& aEntryIdArray,
7feec50967db 201003_02
hgs
parents:
diff changeset
   554
        const TDesC& aColName )
7feec50967db 201003_02
hgs
parents:
diff changeset
   555
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   556
    RBuf bindKey;
7feec50967db 201003_02
hgs
parents:
diff changeset
   557
    bindKey.CleanupClosePushL();
7feec50967db 201003_02
hgs
parents:
diff changeset
   558
    bindKey.CreateL( aColName.Length() + KMaxIntNumLength );
7feec50967db 201003_02
hgs
parents:
diff changeset
   559
    for( TInt i = 0; i < aEntryIdArray.Count() ; i++ )
7feec50967db 201003_02
hgs
parents:
diff changeset
   560
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   561
        bindKey.Copy( KNullDesC );
7feec50967db 201003_02
hgs
parents:
diff changeset
   562
        bindKey.Append( aColName );
7feec50967db 201003_02
hgs
parents:
diff changeset
   563
        bindKey.AppendNum( i );
7feec50967db 201003_02
hgs
parents:
diff changeset
   564
        if( iQuery.Find( bindKey ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   565
            {
7feec50967db 201003_02
hgs
parents:
diff changeset
   566
            BindIntL( iStatement.ParameterIndex( bindKey ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   567
                    aEntryIdArray[i] );
7feec50967db 201003_02
hgs
parents:
diff changeset
   568
            }
7feec50967db 201003_02
hgs
parents:
diff changeset
   569
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   570
    CleanupStack::PopAndDestroy( &bindKey );
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
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   577
void CCaSqlQuery::BindEntryIdL( const TInt& aEntryId )
7feec50967db 201003_02
hgs
parents:
diff changeset
   578
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   579
    if( iQuery.Find( KSQLEntryId ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   580
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   581
        BindIntL( iStatement.ParameterIndex( KSQLEntryId ), aEntryId );
7feec50967db 201003_02
hgs
parents:
diff changeset
   582
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   583
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   584
7feec50967db 201003_02
hgs
parents:
diff changeset
   585
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   586
// CCaSqlQuery::BindValuesForRemoveFromLocalizationL(  const TInt aEntryId )
7feec50967db 201003_02
hgs
parents:
diff changeset
   587
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   588
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   589
void CCaSqlQuery::BindValuesForRemoveFromLocalizationL(  const TInt aEntryId )
7feec50967db 201003_02
hgs
parents:
diff changeset
   590
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   591
    if( iQuery.Find( KSQLLocRowId ) != KErrNotFound )
7feec50967db 201003_02
hgs
parents:
diff changeset
   592
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   593
        BindIntL( iStatement.ParameterIndex( KSQLLocRowId ), aEntryId );
7feec50967db 201003_02
hgs
parents:
diff changeset
   594
        }
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
TInt CCaSqlQuery::ExecuteL()
7feec50967db 201003_02
hgs
parents:
diff changeset
   602
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   603
    User::LeaveIfError( iStatement.Exec() );
7feec50967db 201003_02
hgs
parents:
diff changeset
   604
    TSqlScalarFullSelectQuery id_query( iSqlDb );
7feec50967db 201003_02
hgs
parents:
diff changeset
   605
    return id_query.SelectIntL( KSQLGetLastInsertId );
7feec50967db 201003_02
hgs
parents:
diff changeset
   606
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   607
7feec50967db 201003_02
hgs
parents:
diff changeset
   608
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   609
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   610
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   611
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   612
TInt CCaSqlQuery::ExecuteL( TInt& aId )
7feec50967db 201003_02
hgs
parents:
diff changeset
   613
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   614
    if( iStatement.Next() == KSqlAtRow )
7feec50967db 201003_02
hgs
parents:
diff changeset
   615
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   616
        aId = iStatement.ColumnInt( ColumnIndexL( iStatement,
7feec50967db 201003_02
hgs
parents:
diff changeset
   617
                KColumnSingleData ) );
7feec50967db 201003_02
hgs
parents:
diff changeset
   618
        return 1;
7feec50967db 201003_02
hgs
parents:
diff changeset
   619
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   620
    return 0;
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
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   626
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   627
TInt CCaSqlQuery::ExecuteL( TInt64& aId )
7feec50967db 201003_02
hgs
parents:
diff changeset
   628
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   629
    if( iStatement.Next() == KSqlAtRow )
7feec50967db 201003_02
hgs
parents:
diff changeset
   630
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   631
        aId = iStatement.ColumnInt64(ColumnIndexL( iStatement,
7feec50967db 201003_02
hgs
parents:
diff changeset
   632
                KColumnSingleData ) );
7feec50967db 201003_02
hgs
parents:
diff changeset
   633
        return 1;
7feec50967db 201003_02
hgs
parents:
diff changeset
   634
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   635
    return 0;
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( RPointerArray<CCaInnerEntry>& result,
7feec50967db 201003_02
hgs
parents:
diff changeset
   643
        TQueryResultType aResultType )
7feec50967db 201003_02
hgs
parents:
diff changeset
   644
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   645
    TInt rowCount( 0 );
7feec50967db 201003_02
hgs
parents:
diff changeset
   646
    if( aResultType==CCaSqlQuery::EEntry )
7feec50967db 201003_02
hgs
parents:
diff changeset
   647
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   648
        rowCount = ExecuteEntryL( result );
7feec50967db 201003_02
hgs
parents:
diff changeset
   649
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   650
    else // aResultType==CCaSqlQuery::EAttribute
7feec50967db 201003_02
hgs
parents:
diff changeset
   651
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   652
        rowCount = ExecuteAttributeL( result );
7feec50967db 201003_02
hgs
parents:
diff changeset
   653
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   654
    return rowCount;
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
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   660
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   661
TInt CCaSqlQuery::ExecuteEntryL(
7feec50967db 201003_02
hgs
parents:
diff changeset
   662
        RPointerArray<CCaInnerEntry>& aResultInput )
7feec50967db 201003_02
hgs
parents:
diff changeset
   663
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   664
    TInt rowCount(0);
7feec50967db 201003_02
hgs
parents:
diff changeset
   665
    while( iStatement.Next() == KSqlAtRow )
7feec50967db 201003_02
hgs
parents:
diff changeset
   666
        {
89
hgs
parents: 88
diff changeset
   667
        TInt entryId = iStatement.ColumnInt( 
hgs
parents: 88
diff changeset
   668
        		ColumnIndexL( iStatement, KColumnEntryId ) );
hgs
parents: 88
diff changeset
   669
        TInt role = iStatement.ColumnInt( 
hgs
parents: 88
diff changeset
   670
        		ColumnIndexL( iStatement, KColumnEnRole ) );
hgs
parents: 88
diff changeset
   671
        TInt32 uid = iStatement.ColumnInt( 
hgs
parents: 88
diff changeset
   672
        		ColumnIndexL( iStatement, KColumnEnUid ) );
hgs
parents: 88
diff changeset
   673
        TUint flags = iStatement.ColumnInt( 
hgs
parents: 88
diff changeset
   674
        		ColumnIndexL( iStatement, KColumnEnFlags ) );
hgs
parents: 88
diff changeset
   675
        TInt idIcon = iStatement.ColumnInt( 
hgs
parents: 88
diff changeset
   676
        		ColumnIndexL( iStatement, KColumnEnIdIcon ) );
88
hgs
parents: 85
diff changeset
   677
        
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   678
        TPtrC text;
7feec50967db 201003_02
hgs
parents:
diff changeset
   679
        User::LeaveIfError( iStatement. ColumnText( ColumnIndexL(
7feec50967db 201003_02
hgs
parents:
diff changeset
   680
                iStatement, KColumnEnText ), text ) );
7feec50967db 201003_02
hgs
parents:
diff changeset
   681
        TPtrC description;
7feec50967db 201003_02
hgs
parents:
diff changeset
   682
        User::LeaveIfError( iStatement.
7feec50967db 201003_02
hgs
parents:
diff changeset
   683
                ColumnText( ColumnIndexL( iStatement, KColumnEnDescription ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   684
                description) );      
7feec50967db 201003_02
hgs
parents:
diff changeset
   685
        TPtrC typeName;
7feec50967db 201003_02
hgs
parents:
diff changeset
   686
        User::LeaveIfError( iStatement.ColumnText( 
7feec50967db 201003_02
hgs
parents:
diff changeset
   687
                ColumnIndexL(iStatement, KColumnEnTypeName ), typeName) );
88
hgs
parents: 85
diff changeset
   688
                
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   689
        TPtrC iconFilename;
7feec50967db 201003_02
hgs
parents:
diff changeset
   690
        User::LeaveIfError( iStatement.ColumnText( ColumnIndexL(
7feec50967db 201003_02
hgs
parents:
diff changeset
   691
                iStatement, KColumnIcFileName ), iconFilename ) );
7feec50967db 201003_02
hgs
parents:
diff changeset
   692
88
hgs
parents: 85
diff changeset
   693
        TPtrC iconSkinId;
hgs
parents: 85
diff changeset
   694
        User::LeaveIfError( iStatement.ColumnText( ColumnIndexL(
hgs
parents: 85
diff changeset
   695
                iStatement, KColumnIcSkinId ), iconSkinId ) );
hgs
parents: 85
diff changeset
   696
hgs
parents: 85
diff changeset
   697
        TPtrC iconApplicationId;
hgs
parents: 85
diff changeset
   698
        User::LeaveIfError( iStatement.ColumnText( ColumnIndexL(
hgs
parents: 85
diff changeset
   699
                iStatement, KColumnIcAppId ), iconApplicationId ) );
hgs
parents: 85
diff changeset
   700
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   701
        CCaInnerEntry* result = CCaInnerEntry::NewLC();
7feec50967db 201003_02
hgs
parents:
diff changeset
   702
        result->SetId( entryId );
7feec50967db 201003_02
hgs
parents:
diff changeset
   703
        result->SetRole( role );
88
hgs
parents: 85
diff changeset
   704
        result->SetIconDataL(
hgs
parents: 85
diff changeset
   705
                iconFilename, iconSkinId, iconApplicationId );
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   706
        result->SetIconId( idIcon );
7feec50967db 201003_02
hgs
parents:
diff changeset
   707
        result->SetFlags( flags );
7feec50967db 201003_02
hgs
parents:
diff changeset
   708
        result->SetUid( uid );
7feec50967db 201003_02
hgs
parents:
diff changeset
   709
        result->SetTextL( text );
7feec50967db 201003_02
hgs
parents:
diff changeset
   710
        result->SetDescriptionL( description );
7feec50967db 201003_02
hgs
parents:
diff changeset
   711
        result->SetEntryTypeNameL( typeName );
7feec50967db 201003_02
hgs
parents:
diff changeset
   712
7feec50967db 201003_02
hgs
parents:
diff changeset
   713
        aResultInput.AppendL( result );
7feec50967db 201003_02
hgs
parents:
diff changeset
   714
        CleanupStack::Pop( result );
7feec50967db 201003_02
hgs
parents:
diff changeset
   715
        rowCount++;
7feec50967db 201003_02
hgs
parents:
diff changeset
   716
        }//while
7feec50967db 201003_02
hgs
parents:
diff changeset
   717
7feec50967db 201003_02
hgs
parents:
diff changeset
   718
    return rowCount;
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
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   723
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   724
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   725
TInt CCaSqlQuery::ExecuteLocalizationsL(
7feec50967db 201003_02
hgs
parents:
diff changeset
   726
        RPointerArray<CCaLocalizationEntry>& aResultInput )
7feec50967db 201003_02
hgs
parents:
diff changeset
   727
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   728
    TInt rowCount(0);
7feec50967db 201003_02
hgs
parents:
diff changeset
   729
    while( iStatement.Next() == KSqlAtRow )
7feec50967db 201003_02
hgs
parents:
diff changeset
   730
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   731
        TInt locTextId = iStatement.ColumnInt(
7feec50967db 201003_02
hgs
parents:
diff changeset
   732
                ColumnIndexL( iStatement, KColumnLocTextId )
7feec50967db 201003_02
hgs
parents:
diff changeset
   733
                );
7feec50967db 201003_02
hgs
parents:
diff changeset
   734
        
7feec50967db 201003_02
hgs
parents:
diff changeset
   735
        TInt rowId = iStatement.ColumnInt(
7feec50967db 201003_02
hgs
parents:
diff changeset
   736
                ColumnIndexL( iStatement, KColumnLocRowId ) 
7feec50967db 201003_02
hgs
parents:
diff changeset
   737
                );
7feec50967db 201003_02
hgs
parents:
diff changeset
   738
         
7feec50967db 201003_02
hgs
parents:
diff changeset
   739
        TPtrC tableName;
7feec50967db 201003_02
hgs
parents:
diff changeset
   740
        User::LeaveIfError(
7feec50967db 201003_02
hgs
parents:
diff changeset
   741
                iStatement.ColumnText(
7feec50967db 201003_02
hgs
parents:
diff changeset
   742
                        ColumnIndexL( iStatement, KColumnLocTableName ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   743
                        tableName )
7feec50967db 201003_02
hgs
parents:
diff changeset
   744
                        );
7feec50967db 201003_02
hgs
parents:
diff changeset
   745
        
7feec50967db 201003_02
hgs
parents:
diff changeset
   746
        TPtrC attribute;
7feec50967db 201003_02
hgs
parents:
diff changeset
   747
        User::LeaveIfError(
7feec50967db 201003_02
hgs
parents:
diff changeset
   748
                iStatement.ColumnText(
7feec50967db 201003_02
hgs
parents:
diff changeset
   749
                        ColumnIndexL( iStatement, KColumnLocAttrName ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   750
                        attribute )
7feec50967db 201003_02
hgs
parents:
diff changeset
   751
                        );  
7feec50967db 201003_02
hgs
parents:
diff changeset
   752
        
7feec50967db 201003_02
hgs
parents:
diff changeset
   753
        TPtrC stringId;
7feec50967db 201003_02
hgs
parents:
diff changeset
   754
        User::LeaveIfError(
7feec50967db 201003_02
hgs
parents:
diff changeset
   755
                iStatement.ColumnText(
7feec50967db 201003_02
hgs
parents:
diff changeset
   756
                        ColumnIndexL( iStatement, KColumnLocStringId ),
7feec50967db 201003_02
hgs
parents:
diff changeset
   757
                        stringId )
7feec50967db 201003_02
hgs
parents:
diff changeset
   758
                        );
7feec50967db 201003_02
hgs
parents:
diff changeset
   759
        
7feec50967db 201003_02
hgs
parents:
diff changeset
   760
        CCaLocalizationEntry* result = CCaLocalizationEntry::NewLC( );
7feec50967db 201003_02
hgs
parents:
diff changeset
   761
        result->SetTextId( locTextId );
7feec50967db 201003_02
hgs
parents:
diff changeset
   762
        result->SetAttributeNameL( attribute );
7feec50967db 201003_02
hgs
parents:
diff changeset
   763
        result->SetStringIdL( stringId );
7feec50967db 201003_02
hgs
parents:
diff changeset
   764
        result->SetRowId( rowId );
7feec50967db 201003_02
hgs
parents:
diff changeset
   765
        result->SetTableNameL( tableName );
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::ExecutePropertyL( TDes& aPropertyValue )
7feec50967db 201003_02
hgs
parents:
diff changeset
   780
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   781
    TInt rowCount(0);
7feec50967db 201003_02
hgs
parents:
diff changeset
   782
    while( iStatement.Next() == KSqlAtRow )
7feec50967db 201003_02
hgs
parents:
diff changeset
   783
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   784
        TPtrC propertyValue;
7feec50967db 201003_02
hgs
parents:
diff changeset
   785
        User::LeaveIfError( iStatement. ColumnText(
7feec50967db 201003_02
hgs
parents:
diff changeset
   786
                ColumnIndexL( iStatement, KColumnDbValue ), propertyValue ) );
7feec50967db 201003_02
hgs
parents:
diff changeset
   787
        
7feec50967db 201003_02
hgs
parents:
diff changeset
   788
        aPropertyValue.Copy( propertyValue );
7feec50967db 201003_02
hgs
parents:
diff changeset
   789
        
7feec50967db 201003_02
hgs
parents:
diff changeset
   790
        rowCount++;
7feec50967db 201003_02
hgs
parents:
diff changeset
   791
        }//while
7feec50967db 201003_02
hgs
parents:
diff changeset
   792
7feec50967db 201003_02
hgs
parents:
diff changeset
   793
    return rowCount;
7feec50967db 201003_02
hgs
parents:
diff changeset
   794
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   795
7feec50967db 201003_02
hgs
parents:
diff changeset
   796
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   797
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   798
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   799
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   800
TInt CCaSqlQuery::ExecuteAttributeL(
7feec50967db 201003_02
hgs
parents:
diff changeset
   801
        RPointerArray<CCaInnerEntry>& aEntryArray )
7feec50967db 201003_02
hgs
parents:
diff changeset
   802
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   803
    TInt rowCount( 0 );
7feec50967db 201003_02
hgs
parents:
diff changeset
   804
    while( iStatement.Next() == KSqlAtRow )
7feec50967db 201003_02
hgs
parents:
diff changeset
   805
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   806
        TInt idEntry = iStatement.ColumnInt(
7feec50967db 201003_02
hgs
parents:
diff changeset
   807
                ColumnIndexL( iStatement, KColumnAttrEntryID ) );
7feec50967db 201003_02
hgs
parents:
diff changeset
   808
        TPtrC name;
7feec50967db 201003_02
hgs
parents:
diff changeset
   809
        User::LeaveIfError(iStatement.ColumnText(
7feec50967db 201003_02
hgs
parents:
diff changeset
   810
                ColumnIndexL( iStatement, KColumnAttrName), name ) );
7feec50967db 201003_02
hgs
parents:
diff changeset
   811
        TPtrC value;
7feec50967db 201003_02
hgs
parents:
diff changeset
   812
        User::LeaveIfError(iStatement.ColumnText(
7feec50967db 201003_02
hgs
parents:
diff changeset
   813
                ColumnIndexL( iStatement, KColumnAttrValue), value ) );
7feec50967db 201003_02
hgs
parents:
diff changeset
   814
        for( TInt i = 0; i < aEntryArray.Count(); i++ )
7feec50967db 201003_02
hgs
parents:
diff changeset
   815
            {
7feec50967db 201003_02
hgs
parents:
diff changeset
   816
            if( idEntry == aEntryArray[i]->GetId() )
7feec50967db 201003_02
hgs
parents:
diff changeset
   817
                {
7feec50967db 201003_02
hgs
parents:
diff changeset
   818
                aEntryArray[i]->AddAttributeL( name, value );
7feec50967db 201003_02
hgs
parents:
diff changeset
   819
                }
7feec50967db 201003_02
hgs
parents:
diff changeset
   820
            }
7feec50967db 201003_02
hgs
parents:
diff changeset
   821
        rowCount++;
7feec50967db 201003_02
hgs
parents:
diff changeset
   822
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   823
    return rowCount;
7feec50967db 201003_02
hgs
parents:
diff changeset
   824
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   825
7feec50967db 201003_02
hgs
parents:
diff changeset
   826
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   827
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   828
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   829
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   830
TInt CCaSqlQuery::ExecuteL( RArray<TInt>& aResultIdArray,
7feec50967db 201003_02
hgs
parents:
diff changeset
   831
        TTableType aType )
7feec50967db 201003_02
hgs
parents:
diff changeset
   832
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   833
    TInt rowCount( 0 );
7feec50967db 201003_02
hgs
parents:
diff changeset
   834
    TPtrC columnId;
7feec50967db 201003_02
hgs
parents:
diff changeset
   835
    if( aType == CCaSqlQuery::EEntryTable )
7feec50967db 201003_02
hgs
parents:
diff changeset
   836
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   837
        columnId.Set( KColumnEntryId );
7feec50967db 201003_02
hgs
parents:
diff changeset
   838
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   839
    else // aType==CCaSqlQuery::EGroupTable
7feec50967db 201003_02
hgs
parents:
diff changeset
   840
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   841
        columnId.Set( KColumnGEIdGroup );
7feec50967db 201003_02
hgs
parents:
diff changeset
   842
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   843
    while( iStatement.Next() == KSqlAtRow )
7feec50967db 201003_02
hgs
parents:
diff changeset
   844
        {
7feec50967db 201003_02
hgs
parents:
diff changeset
   845
        aResultIdArray.AppendL( iStatement.ColumnInt( ColumnIndexL(
7feec50967db 201003_02
hgs
parents:
diff changeset
   846
                iStatement, columnId ) ) );
7feec50967db 201003_02
hgs
parents:
diff changeset
   847
        rowCount++;
7feec50967db 201003_02
hgs
parents:
diff changeset
   848
        }
7feec50967db 201003_02
hgs
parents:
diff changeset
   849
    return rowCount;
7feec50967db 201003_02
hgs
parents:
diff changeset
   850
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   851
7feec50967db 201003_02
hgs
parents:
diff changeset
   852
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   853
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   854
// ---------------------------------------------------------------------------
7feec50967db 201003_02
hgs
parents:
diff changeset
   855
//
92
hgs
parents: 89
diff changeset
   856
TInt CCaSqlQuery::ExecuteL( CCaInnerIconDescription* aInnerIconDescription )
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   857
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   858
    TInt columnCount( 0 );
92
hgs
parents: 89
diff changeset
   859
    
hgs
parents: 89
diff changeset
   860
   RBuf description;
hgs
parents: 89
diff changeset
   861
   description.CleanupClosePushL();
hgs
parents: 89
diff changeset
   862
   description.CreateL(KMaxFileName);
hgs
parents: 89
diff changeset
   863
    
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   864
    while( iStatement.Next() == KSqlAtRow )
7feec50967db 201003_02
hgs
parents:
diff changeset
   865
        {
92
hgs
parents: 89
diff changeset
   866
        aInnerIconDescription->SetId( iStatement.ColumnInt(
hgs
parents: 89
diff changeset
   867
                ColumnIndexL( iStatement, KColumnIconId ) ) );
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   868
        User::LeaveIfError(iStatement.ColumnText(
7feec50967db 201003_02
hgs
parents:
diff changeset
   869
                ColumnIndexL( iStatement, KColumnIcFileName),
92
hgs
parents: 89
diff changeset
   870
                description));
hgs
parents: 89
diff changeset
   871
        aInnerIconDescription->SetFileNameL(description);
hgs
parents: 89
diff changeset
   872
        
88
hgs
parents: 85
diff changeset
   873
        User::LeaveIfError(iStatement.ColumnText(
hgs
parents: 85
diff changeset
   874
                ColumnIndexL( iStatement, KColumnIcSkinId),
92
hgs
parents: 89
diff changeset
   875
                description));
hgs
parents: 89
diff changeset
   876
        aInnerIconDescription->SetSkinIdL(description);
hgs
parents: 89
diff changeset
   877
        
88
hgs
parents: 85
diff changeset
   878
        User::LeaveIfError(iStatement.ColumnText(
hgs
parents: 85
diff changeset
   879
                ColumnIndexL( iStatement, KColumnIcAppId),
92
hgs
parents: 89
diff changeset
   880
                description));
hgs
parents: 89
diff changeset
   881
        aInnerIconDescription->SetApplicationIdL(description);
hgs
parents: 89
diff changeset
   882
        
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   883
        columnCount++;
7feec50967db 201003_02
hgs
parents:
diff changeset
   884
        }
92
hgs
parents: 89
diff changeset
   885
    CleanupStack::PopAndDestroy(&description);
85
7feec50967db 201003_02
hgs
parents:
diff changeset
   886
    return columnCount;
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
//
7feec50967db 201003_02
hgs
parents:
diff changeset
   893
TInt CCaSqlQuery::ColumnIndexL( RSqlStatement& aStmt,
7feec50967db 201003_02
hgs
parents:
diff changeset
   894
        const TDesC& aColumnName ) const
7feec50967db 201003_02
hgs
parents:
diff changeset
   895
    {
7feec50967db 201003_02
hgs
parents:
diff changeset
   896
    TInt ret( aStmt.ColumnIndex( aColumnName ) );
7feec50967db 201003_02
hgs
parents:
diff changeset
   897
    User::LeaveIfError( ret );
7feec50967db 201003_02
hgs
parents:
diff changeset
   898
    return ret;
7feec50967db 201003_02
hgs
parents:
diff changeset
   899
    }
7feec50967db 201003_02
hgs
parents:
diff changeset
   900