⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 test-database-add.c

📁 linux下的电话本的最底层
💻 C
字号:
/*	librecord2 - Record Object manipulation and storage library 2 * *	Authors: YE Nan <nan.ye@orange-ftgroup.com>  *	 *	This software and associated documentation files (the "Software")  *	are copyright (C) 2005 LiPS Linux Phone Standards Forum [FranceTelecom]  *	All Rights Reserved.  * *	A copyright license is hereby granted for redistribution and use of  *	the Software in source and binary forms, with or without modification,  *	provided that the following conditions are met:  *	- Redistributions of source code must retain the above copyright notice,  *	this copyright license and the following disclaimer.  *  - Redistributions in binary form must reproduce the above copyright  * 	notice, this copyright license and the following disclaimer in the  *	documentation and/or other materials provided with the distribution.  *	- Neither the name of LiPS  nor the names of its Members may be used  *	to endorse or promote products derived from the Software without  *	specific prior written permission.  * *	A patent license for any Necessary Claims owned by Members of LiPS Forum  *	to make, have made, use, import, offer to sell, lease and sell or otherwise  *	distribute any implementation compliant with the any specification adopted  *	by the LiPS Forumcan be obtained from the respective Members on reasonable  *	and non-discriminatory terms and conditions and under reciprocity, as  *	regulated in more detail in the Internal Policy of the LiPS Forum.  * *	THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDER, ITS MEMBERS AND CONTRIBUTORS  *	"AS IS", AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,  *	THE IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE  *	AND NON-INFRINGEMENT ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER,  *	ITS MEMBERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,  *	SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,  *	PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;  *	OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,  *	WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)  *	ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE  *	POSSIBILITY OF SUCH DAMAGE.  */#include <stdio.h>#include <stdlib.h>#include <time.h>#include <glib.h>#include <database.h>#define TEMPL_FNAME			"./sample.templ"#define	DB_FNAME				"./sample.db"#define	DB_ELEMENT_NAME	"sample"typedef enum {	REC_FIELD_UID						= 1,	REC_FIELD_NAME					= 3,	REC_FIELD_MOBILE				= 6,	REC_FIELD_NUM_HOME			= 7,	REC_FIELD_NUM_OFFICE		= 8,	REC_FIELD_FAX						= 9,	REC_FIELD_COMPANY				= 10,	REC_FIELD_DEPART				= 11,	REC_FIELD_WEBSITE				= 12,	REC_FIELD_EMAIL					= 13,	REC_FIELD_PICTURE				= 14,	REC_FIELD_RINGTONE			= 15,	REC_FIELD_ADDRESS				= 16,	REC_FIELD_CUSTOM_FLOAT	= 17,	REC_FIELD_CUSTOM_BINARY	= 18,} RecordFields;FieldTemplate * templ = NULL;static Record *gen_record (RecordDB 	*db,						guint32		 index){	Record * record = NULL;	gchar * str = NULL;	gint i;		record = record_new(templ);	/*	 * set basic fields	 */	str = g_strdup_printf("Person%d.Demo", index);	record_set_field_default(record,													 REC_FIELD_NAME,													 str,													 FIELD_SIZE_AUTO);	g_free(str);		str = g_strdup_printf("%s13%d1xxxx%03d",												(g_random_boolean() ? "+86" : ""),												g_random_int_range(0, 10),												g_random_int_range(0,999));	record_set_field_default(record,													 REC_FIELD_MOBILE,													 str,													 FIELD_SIZE_AUTO);	g_free(str);		str = g_strdup_printf("%03d%dxxxx%03d",												g_random_int_range(0,999),												g_random_int_range(0, 10),												g_random_int_range(0,999));	record_set_field_default(record,													 REC_FIELD_NUM_HOME,													 str,													 FIELD_SIZE_AUTO);	g_free(str);	str = g_strdup_printf("%03d%dxxxx%03d",												g_random_int_range(0,999),												g_random_int_range(0, 10),												g_random_int_range(0,999));	record_set_field_default(record,													 REC_FIELD_NUM_OFFICE,													 str,													 FIELD_SIZE_AUTO);	record_set_field_default(record,													 REC_FIELD_FAX,													 str,													 FIELD_SIZE_AUTO);;	g_free(str);	str = g_strdup_printf("Demo%d Company",												(index) / (g_random_int_range(1, 10)));	record_set_field_default(record,													 REC_FIELD_COMPANY,													 str,													 FIELD_SIZE_AUTO);	g_free(str);		str = g_strdup_printf("Demo%d Department",												(index) % (g_random_int_range(1, 10)));	record_set_field_default(record,													 REC_FIELD_DEPART,													 str,													 FIELD_SIZE_AUTO);	g_free(str);													 	str = g_strdup_printf("http://demo%dperson.demo.org/index.php",												index);	record_set_field_default(record,													 REC_FIELD_WEBSITE,													 str,													 FIELD_SIZE_AUTO);	g_free(str);		str = g_strdup_printf("http://demo%dperson@demo.org",												index);	record_set_field_default(record,													 REC_FIELD_EMAIL,													 str,													 FIELD_SIZE_AUTO);	g_free(str);		str = g_strdup_printf("resource/pictures/head%d.png",												index);	record_set_field_default(record,													 REC_FIELD_PICTURE,													 str,													 FIELD_SIZE_AUTO);	g_free(str);		str = g_strdup_printf("resource/ringtones/ring%d.mp3",												index);	record_set_field_default(record,													 REC_FIELD_RINGTONE,													 str,													 FIELD_SIZE_AUTO);	g_free(str);		str = g_strdup_printf("No.%d Demo Road, Demo City, Demo Country",												index);	record_set_field_default(record, REC_FIELD_ADDRESS,													 str,													 FIELD_SIZE_AUTO);	g_free(str);	if (TRUE)	{		gfloat f = g_random_double();				record_set_field_default(record,														 REC_FIELD_CUSTOM_FLOAT,														 &f,														 FIELD_SIZE_AUTO);	}		if (TRUE)	{		guint8 bytes[] = {			0x01, 0x05, 0x08, 0x0A, 			0x0B, 0x02, 0x06, 0x09, 			0x0E, 0x0C, 0x03, 0x07, 			0x00, 0x0F, 0x0D, 0x04, 		};				record_set_field_default(record, 														 REC_FIELD_CUSTOM_BINARY,														 bytes,														 sizeof(bytes));	}	#if 1 		/*	 * set extend fields	 */	if (TRUE)	{		guint32 fid;		gfloat f = g_random_double();				fid = record_add_field(record, 													 REC_FIELD_CUSTOM_FLOAT);		record_set_field(record,										 fid,										 &f,										 FIELD_SIZE_AUTO);	}		if (TRUE)	{		guint32 fid;		guint8 bytes[] = {			0x01, 0x05, 0x08, 0x0A, 			0x0B, 0x02, 0x06, 0x09, 			0x0E, 0x0C, 0x03, 0x07, 		};				fid = record_add_field(record,													 REC_FIELD_CUSTOM_BINARY);		record_set_field(record,										 fid,										 bytes,										 sizeof(bytes));	}	if (TRUE)	{		gint count = g_random_int_range(0, 3);				for (i = 0; i < count; i++)		{			guint32 fid;						fid = record_add_field(record, REC_FIELD_MOBILE);						str = g_strdup_printf("Ext Mobile Number %d",														i);			record_set_label(record,											 fid,											 str);			record_set_desc(record,											fid,											str);			g_free(str);											 			str = g_strdup_printf("139%dxxxx%3d",														g_random_int_range(0, 10),														g_random_int_range(0, 999));			record_set_field(record,											 fid,											 str,											 FIELD_SIZE_AUTO);			g_free(str);						if (g_random_boolean())			{				record_set_default_fid(record,															 REC_FIELD_MOBILE,															 fid);			}		}	}#endif//	record_print(record);		return record;}int main (int argc, char *argv[]){	RecordDB * db = NULL;	RecordDBElement * element = NULL;	guint32 count = 1;	gint i;		if (argc == 2)	{		count = atoi(argv[1]);	}		templ = field_template_new_from_file(TEMPL_FNAME);		db = record_db_new(DB_FNAME);	element = record_db_element_new(db,																	DB_ELEMENT_NAME,																	templ);	record_db_open(db);		record_db_trans_begin(db);	for (i = 0; i < count; i++)	{		Record * record = NULL;				record = gen_record(db,												i);				record_db_element_add_record(element,																 record);														record_free(record);	}	record_db_trans_commit(db);		record_db_close(db);		record_db_element_free(element);	record_db_free(db);		field_template_free(templ);		return EXIT_SUCCESS;}/*vi:ts=2:nowrap:ai:expandtab */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -