logsui/logsengine/src/logsduplicatelookup.cpp
author hgs
Mon, 23 Aug 2010 18:14:51 +0300
changeset 15 76d2cf7a585e
permissions -rw-r--r--
201033
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
15
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
hgs
parents:
diff changeset
     3
* All rights reserved.
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
hgs
parents:
diff changeset
     8
*
hgs
parents:
diff changeset
     9
* Initial Contributors:
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
hgs
parents:
diff changeset
    11
*
hgs
parents:
diff changeset
    12
* Contributors:
hgs
parents:
diff changeset
    13
*
hgs
parents:
diff changeset
    14
* Description:
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
// INCLUDE FILES
hgs
parents:
diff changeset
    19
#include "logsduplicatelookup.h"
hgs
parents:
diff changeset
    20
#include "logsevent.h"
hgs
parents:
diff changeset
    21
#include "logscommondata.h"
hgs
parents:
diff changeset
    22
hgs
parents:
diff changeset
    23
// ----------------------------------------------------------------------------
hgs
parents:
diff changeset
    24
//
hgs
parents:
diff changeset
    25
// ----------------------------------------------------------------------------
hgs
parents:
diff changeset
    26
//
hgs
parents:
diff changeset
    27
LogsDuplicateLookup::LogsDuplicateLookup()
hgs
parents:
diff changeset
    28
{
hgs
parents:
diff changeset
    29
    for ( int i = 0; i <= LogsEvent::DirMissed; i++ ){
hgs
parents:
diff changeset
    30
        LogsLookupHash* directionLookup = new LogsLookupHash;
hgs
parents:
diff changeset
    31
        mDirectionLookupTables.append( directionLookup );
hgs
parents:
diff changeset
    32
    }
hgs
parents:
diff changeset
    33
}
hgs
parents:
diff changeset
    34
hgs
parents:
diff changeset
    35
// ----------------------------------------------------------------------------
hgs
parents:
diff changeset
    36
//
hgs
parents:
diff changeset
    37
// ----------------------------------------------------------------------------
hgs
parents:
diff changeset
    38
//
hgs
parents:
diff changeset
    39
LogsDuplicateLookup::~LogsDuplicateLookup()
hgs
parents:
diff changeset
    40
{
hgs
parents:
diff changeset
    41
    qDeleteAll(mDirectionLookupTables);
hgs
parents:
diff changeset
    42
}
hgs
parents:
diff changeset
    43
hgs
parents:
diff changeset
    44
// ----------------------------------------------------------------------------
hgs
parents:
diff changeset
    45
//
hgs
parents:
diff changeset
    46
// ----------------------------------------------------------------------------
hgs
parents:
diff changeset
    47
//
hgs
parents:
diff changeset
    48
void LogsDuplicateLookup::invalidate()
hgs
parents:
diff changeset
    49
{
hgs
parents:
diff changeset
    50
    for( int k = 0; k < mDirectionLookupTables.count(); k++ ){
hgs
parents:
diff changeset
    51
        LogsLookupHash& table = *mDirectionLookupTables.at(k);
hgs
parents:
diff changeset
    52
        LogsLookupHash::iterator it;
hgs
parents:
diff changeset
    53
        for (it = table.begin(); it != table.end(); ++it){
hgs
parents:
diff changeset
    54
            it.value() = 0;
hgs
parents:
diff changeset
    55
        }
hgs
parents:
diff changeset
    56
    }
hgs
parents:
diff changeset
    57
}
hgs
parents:
diff changeset
    58
hgs
parents:
diff changeset
    59
// ----------------------------------------------------------------------------
hgs
parents:
diff changeset
    60
//
hgs
parents:
diff changeset
    61
// ----------------------------------------------------------------------------
hgs
parents:
diff changeset
    62
//
hgs
parents:
diff changeset
    63
void LogsDuplicateLookup::cleanup()
hgs
parents:
diff changeset
    64
{
hgs
parents:
diff changeset
    65
    for( int k = 0; k < mDirectionLookupTables.count(); k++ ){
hgs
parents:
diff changeset
    66
        LogsLookupHash& table = *mDirectionLookupTables.at(k);
hgs
parents:
diff changeset
    67
        LogsLookupHash::iterator it = table.begin();
hgs
parents:
diff changeset
    68
        while ( it != table.end() ){
hgs
parents:
diff changeset
    69
            if ( it.value() == 0 ){
hgs
parents:
diff changeset
    70
                it = table.erase(it);
hgs
parents:
diff changeset
    71
            } else {
hgs
parents:
diff changeset
    72
                ++it;
hgs
parents:
diff changeset
    73
            }
hgs
parents:
diff changeset
    74
        }
hgs
parents:
diff changeset
    75
    }
hgs
parents:
diff changeset
    76
}
hgs
parents:
diff changeset
    77
hgs
parents:
diff changeset
    78
// ----------------------------------------------------------------------------
hgs
parents:
diff changeset
    79
//
hgs
parents:
diff changeset
    80
// ----------------------------------------------------------------------------
hgs
parents:
diff changeset
    81
//
hgs
parents:
diff changeset
    82
int LogsDuplicateLookup::addLookupEntry( LogsEvent& event )
hgs
parents:
diff changeset
    83
{
hgs
parents:
diff changeset
    84
    if ( !validLookupEvent(event) ){
hgs
parents:
diff changeset
    85
        return -1;
hgs
parents:
diff changeset
    86
    }
hgs
parents:
diff changeset
    87
    int dir = event.direction();
hgs
parents:
diff changeset
    88
    QString key = constructLookupKey(event);
hgs
parents:
diff changeset
    89
    LogsLookupHash::iterator it = mDirectionLookupTables.at(dir)->find(key);
hgs
parents:
diff changeset
    90
    if ( it != mDirectionLookupTables.at(dir)->end() ){
hgs
parents:
diff changeset
    91
        if ( it.value() == 0 ){
hgs
parents:
diff changeset
    92
            it.value() = &event;
hgs
parents:
diff changeset
    93
        }
hgs
parents:
diff changeset
    94
    } else {
hgs
parents:
diff changeset
    95
        mDirectionLookupTables.at(dir)->insert(key, &event);    
hgs
parents:
diff changeset
    96
    }
hgs
parents:
diff changeset
    97
    return 0;
hgs
parents:
diff changeset
    98
}
hgs
parents:
diff changeset
    99
hgs
parents:
diff changeset
   100
// ----------------------------------------------------------------------------
hgs
parents:
diff changeset
   101
//
hgs
parents:
diff changeset
   102
// ----------------------------------------------------------------------------
hgs
parents:
diff changeset
   103
//
hgs
parents:
diff changeset
   104
LogsEvent* LogsDuplicateLookup::findDuplicate( const LogsEvent& event ) const
hgs
parents:
diff changeset
   105
{
hgs
parents:
diff changeset
   106
    if ( !validLookupEvent(event) ){
hgs
parents:
diff changeset
   107
        return 0;
hgs
parents:
diff changeset
   108
    }
hgs
parents:
diff changeset
   109
    int dir = event.direction();
hgs
parents:
diff changeset
   110
    QString key = constructLookupKey(event);
hgs
parents:
diff changeset
   111
    LogsLookupHash::const_iterator it = 
hgs
parents:
diff changeset
   112
        mDirectionLookupTables.at(dir)->find(key);
hgs
parents:
diff changeset
   113
    if ( it != mDirectionLookupTables.at(dir)->constEnd() ){
hgs
parents:
diff changeset
   114
        return it.value();
hgs
parents:
diff changeset
   115
    }
hgs
parents:
diff changeset
   116
    return 0;
hgs
parents:
diff changeset
   117
}
hgs
parents:
diff changeset
   118
    
hgs
parents:
diff changeset
   119
// ----------------------------------------------------------------------------
hgs
parents:
diff changeset
   120
//
hgs
parents:
diff changeset
   121
// ----------------------------------------------------------------------------
hgs
parents:
diff changeset
   122
//
hgs
parents:
diff changeset
   123
QString LogsDuplicateLookup::constructLookupKey( const LogsEvent& event ) const
hgs
parents:
diff changeset
   124
{
hgs
parents:
diff changeset
   125
    return ( event.remoteParty() + "/t" + 
hgs
parents:
diff changeset
   126
        event.number().right(LogsCommonData::getInstance().telNumMatchLen() ) );
hgs
parents:
diff changeset
   127
}
hgs
parents:
diff changeset
   128
hgs
parents:
diff changeset
   129
// ----------------------------------------------------------------------------
hgs
parents:
diff changeset
   130
//
hgs
parents:
diff changeset
   131
// ----------------------------------------------------------------------------
hgs
parents:
diff changeset
   132
//
hgs
parents:
diff changeset
   133
bool LogsDuplicateLookup::validLookupEvent( const LogsEvent& event ) const
hgs
parents:
diff changeset
   134
{
hgs
parents:
diff changeset
   135
    int dir = event.direction();
hgs
parents:
diff changeset
   136
    return ( !event.remoteParty().isEmpty() && 
hgs
parents:
diff changeset
   137
             dir >= 0 && dir < mDirectionLookupTables.count() );
hgs
parents:
diff changeset
   138
}