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