Aleksander Machniak
2013-01-07 3e3767138e2ea62aea549917c13040849036fbf3
program/lib/Roundcube/rcube_addressbook.php
@@ -2,8 +2,6 @@
/*
 +-----------------------------------------------------------------------+
 | program/include/rcube_addressbook.php                                 |
 |                                                                       |
 | This file is part of the Roundcube Webmail client                     |
 | Copyright (C) 2006-2012, The Roundcube Dev Team                       |
 |                                                                       |
@@ -13,7 +11,6 @@
 |                                                                       |
 | PURPOSE:                                                              |
 |   Interface to the local address book database                        |
 |                                                                       |
 +-----------------------------------------------------------------------+
 | Author: Thomas Bruederli <roundcube@gmail.com>                        |
 +-----------------------------------------------------------------------+
@@ -48,6 +45,7 @@
    public $sort_col = 'name';
    public $sort_order = 'ASC';
    public $coltypes = array('name' => array('limit'=>1), 'firstname' => array('limit'=>1), 'surname' => array('limit'=>1), 'email' => array('limit'=>1));
    public $date_cols = array();
    protected $error;
@@ -141,7 +139,7 @@
     */
    function get_error()
    {
      return $this->error;
        return $this->error;
    }
    /**
@@ -152,7 +150,7 @@
     */
    protected function set_error($type, $message)
    {
      $this->error = array('type' => $type, 'message' => $message);
        $this->error = array('type' => $type, 'message' => $message);
    }
    /**
@@ -224,7 +222,6 @@
        return true;
    }
    /**
     * Create a new contact record
@@ -410,7 +407,6 @@
        return array();
    }
    /**
     * Utility function to return all values of a certain data column
     * either as flat list or grouped by subtype
@@ -442,7 +438,6 @@
        return $out;
    }
    /**
     * Normalize the given string for fulltext search.
@@ -491,7 +486,6 @@
        return $fn;
    }
    /**
     * Compose the name to display in the contacts list for the given contact record.
     * This respects the settings parameter how to list conacts.
@@ -529,5 +523,50 @@
        return $fn;
    }
    /**
     * Compare search value with contact data
     *
     * @param string       $colname Data name
     * @param string|array $value   Data value
     * @param string       $search  Search value
     * @param int          $mode    Search mode
     *
     * @return bool Comparision result
     */
    protected function compare_search_value($colname, $value, $search, $mode)
    {
        // The value is a date string, for date we'll
        // use only strict comparison (mode = 1)
        // @TODO: partial search, e.g. match only day and month
        if (in_array($colname, $this->date_fields)) {
            return (($value = rcube_utils::strtotime($value))
                && ($search = rcube_utils::strtotime($search))
                && date('Ymd', $value) == date('Ymd', $search));
        }
        // composite field, e.g. address
        foreach ((array)$value as $val) {
            $val = mb_strtolower($val);
            switch ($mode) {
            case 1:
                $got = ($val == $search);
                break;
            case 2:
                $got = ($search == substr($val, 0, strlen($search)));
                break;
            default:
                $got = (strpos($val, $search) !== false);
            }
            if ($got) {
                return true;
            }
        }
        return false;
    }
}