km_row.c

Go to the documentation of this file.
00001 /* 
00002  * $Id$ 
00003  *
00004  * MySQL module row related functions
00005  *
00006  * Copyright (C) 2001-2003 FhG Fokus
00007  * Copyright (C) 2008 1&1 Internet AG
00008  *
00009  * This file is part of Kamailio, a free SIP server.
00010  *
00011  * Kamailio is free software; you can redistribute it and/or modify
00012  * it under the terms of the GNU General Public License as published by
00013  * the Free Software Foundation; either version 2 of the License, or
00014  * (at your option) any later version
00015  *
00016  * Kamailio is distributed in the hope that it will be useful,
00017  * but WITHOUT ANY WARRANTY; without even the implied warranty of
00018  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00019  * GNU General Public License for more details.
00020  *
00021  * You should have received a copy of the GNU General Public License 
00022  * along with this program; if not, write to the Free Software 
00023  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
00024  */
00025 
00032 #include "../../dprint.h"
00033 #include "../../mem/mem.h"
00034 #include "../../lib/srdb1/db_row.h"
00035 #include "../../lib/srdb1/db_val.h"
00036 #include "km_my_con.h"
00037 #include "km_val.h"
00038 #include "km_row.h"
00039 
00047 int db_mysql_convert_row(const db1_con_t* _h, db1_res_t* _res, db_row_t* _r)
00048 {
00049         unsigned long* lengths;
00050         int i;
00051 
00052         if ((!_h) || (!_res) || (!_r)) {
00053                 LM_ERR("invalid parameter value\n");
00054                 return -1;
00055         }
00056 
00057         if (db_allocate_row(_res, _r) != 0) {
00058                 LM_ERR("could not allocate row");
00059                 return -2;
00060         }
00061         
00062         lengths = mysql_fetch_lengths(CON_RESULT(_h));
00063 
00064         for(i = 0; i < RES_COL_N(_res); i++) {
00065                 if (db_str2val(RES_TYPES(_res)[i], &(ROW_VALUES(_r)[i]),
00066                             ((MYSQL_ROW)CON_ROW(_h))[i], lengths[i], 0) < 0) {
00067                         LM_ERR("failed to convert value\n");
00068                         LM_DBG("free row at %p\n", _r);
00069                         db_free_row(_r);
00070                         return -3;
00071                 }
00072         }
00073         return 0;
00074 }