2013-10-11 23:07:35 +00:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2012 - Juan Ferrer Toribio
|
|
|
|
*
|
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "db-iter.h"
|
|
|
|
|
|
|
|
/**
|
|
|
|
* SECTION: db-iter
|
|
|
|
* @Short_description: an iterator for the #DbModel
|
|
|
|
* @Title: DbIter
|
|
|
|
* @See_also: #DbModel
|
|
|
|
*
|
|
|
|
* The #DbIter is the structure used to navigate through a #DbModel. See #DbModel
|
|
|
|
* for the methods required to do it.
|
|
|
|
**/
|
|
|
|
G_DEFINE_BOXED_TYPE (DbIter, db_iter, db_iter_copy, db_iter_free);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* db_model_iter_compare:
|
|
|
|
* @a: a #DbIter
|
|
|
|
* @b: a #DbIter
|
|
|
|
*
|
|
|
|
* Compares the two given iters for equality. The equality between two
|
|
|
|
* #DbIter is determined by its stamp and the row of a #DbModel they are
|
|
|
|
* pointing to.
|
|
|
|
*
|
|
|
|
* Return value: #TRUE if the two iters are the same
|
|
|
|
**/
|
|
|
|
gboolean db_iter_compare (DbIter * a, DbIter * b)
|
|
|
|
{
|
2014-02-21 10:20:28 +00:00
|
|
|
if (a && b)
|
|
|
|
return (a->stamp == b->stamp && a->data == b->data);
|
|
|
|
else if (!a && !b)
|
|
|
|
return TRUE;
|
|
|
|
else
|
|
|
|
return FALSE;
|
2013-10-11 23:07:35 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* db_iter_copy:
|
|
|
|
* @obj: the #DbIter to copy
|
|
|
|
*
|
|
|
|
* Copies a #DbIter. Note that this function copies only the reference to the
|
|
|
|
* data in @obj. This is so due to the nature of #DbIter and it's use.
|
|
|
|
*
|
|
|
|
* Return value: a new #DbIter
|
|
|
|
**/
|
|
|
|
DbIter * db_iter_copy (DbIter * obj)
|
|
|
|
{
|
|
|
|
g_return_val_if_fail (obj, NULL);
|
|
|
|
|
|
|
|
DbIter * dst = g_new (DbIter, 1);
|
|
|
|
dst->stamp = obj->stamp;
|
|
|
|
dst->data = obj->data;
|
|
|
|
dst->data2 = obj->data2;
|
|
|
|
dst->data3 = obj->data3;
|
|
|
|
return dst;
|
|
|
|
}
|
|
|
|
|
2014-02-21 10:20:28 +00:00
|
|
|
/**
|
|
|
|
* db_iter_free:
|
|
|
|
* @obj: (allow-none): a #DbIter
|
|
|
|
*
|
|
|
|
* Frees a #DbIter.
|
|
|
|
**/
|
2013-10-11 23:07:35 +00:00
|
|
|
void db_iter_free (DbIter * obj)
|
|
|
|
{
|
|
|
|
g_free (obj);
|
|
|
|
}
|