亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? dbase.c

?? linux下的dvb收看解析軟件代碼; 帶參考程序
?? C
字號:
/*
Copyright (C) 2006  Adam Charrett
 
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 2
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, write to the Free Software
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA
 
dbase.c
 
Opens/Closes and setups the sqlite database for use by the rest of the application.
 
*/

#include <stdlib.h>
#include <stdio.h>
#include <limits.h>
#include <sys/stat.h>
#include <sys/types.h>

#include "dbase.h"
#include "main.h"
#include "logging.h"

#define STRINGIFY(x) #x
#define TOSTRING(x) STRINGIFY(x)

/* This is the version of the database not the application!*/
#define DBASE_VERSION 0.2

sqlite3 *DBaseInstance;

int DBaseCreateTables(double version);
int DBaseCheckVersion();

int DBaseInit(int adapter)
{
    char dir[PATH_MAX];
    char file[PATH_MAX];
    int rc;

    sprintf(dir, "%s/.dvbstreamer", getenv("HOME"));
    mkdir(dir, S_IRWXU);

    sprintf(file, "%s/adapter%d.db", dir, adapter);
    rc = sqlite3_open(file, &DBaseInstance);
    if( rc )
    {
        printlog(LOG_ERROR, "Can't open database: %s\n", sqlite3_errmsg(DBaseInstance));
        sqlite3_close(DBaseInstance);
    }
    else
    {
        rc = DBaseCheckVersion();
    }
    return rc;
}


void DBaseDeInit()
{
    sqlite3_close(DBaseInstance);
}

int DBaseCheckVersion()
{
    STATEMENT_INIT;
	double version;
	STATEMENT_PREPARE("select " VERSION_VERSION " from " VERSION_TABLE ";");
    STATEMENT_STEP();
    if ((rc != SQLITE_OK) && (rc != SQLITE_ROW) && (rc != SQLITE_DONE))
    {
		printlog(LOG_DEBUG, "Failed to get contents of version table (%d)\n", rc);
		version = 0.0f;
    }
	else
	{
		version = STATEMENT_COLUMN_DOUBLE(0);
	}
	STATEMENT_FINALIZE();
	printlog(LOG_DEBUG, "Current version of database is %f\n", version);
    /* Check version number and upgrade tables for future releases ? */
	rc = DBaseCreateTables(version);
    return rc;
}

int DBaseCreateTables(double version)
{
    int rc;

    printlog(LOG_DEBUG, "Creating tables\n");
	/* Version 0.1 - 0.2 tables */
	if (version < 0.1)
	{
	    rc = sqlite3_exec(DBaseInstance, "CREATE TABLE " SERVICES_TABLE " ( "
	                      SERVICE_MPLEXFREQ ","
	                      SERVICE_ID ","
	                      SERVICE_NAME ","
	                      SERVICE_PMTPID ","
	                      SERVICE_PMTVERSION ","
	                      "PRIMARY KEY ( "SERVICE_MPLEXFREQ "," SERVICE_ID ")"
	                      ");", NULL, NULL, NULL);
	    if (rc)
	    {
	        printlog(LOG_ERROR, "Failed to create Services table: %s\n", sqlite3_errmsg(DBaseInstance));
	        return rc;
	    }

	    rc = sqlite3_exec(DBaseInstance, "CREATE TABLE " MULTIPLEXES_TABLE " ( "
	                      MULTIPLEX_FREQ " PRIMARY KEY,"
	                      MULTIPLEX_ID ","
	                      MULTIPLEX_TYPE ","
	                      MULTIPLEX_PATVERSION
	                      ");", NULL, NULL, NULL);
	    if (rc)
	    {
	        printlog(LOG_ERROR, "Failed to create Multiplexes table: %s\n", sqlite3_errmsg(DBaseInstance));
	        return rc;
	    }
	    /*
	    (DVBT) OFDM: <frequency>:<inversion>:<bw>:<fec_hp>:<fec_lp>:<qam>:<transmissionm>:<guardlist>:<hierarchinfo>
	    */
	    rc = sqlite3_exec(DBaseInstance, "CREATE TABLE " OFDMPARAMS_TABLE " ( "
	                      OFDMPARAM_FREQ " PRIMARY KEY,"
	                      OFDMPARAM_INVERSION ","
	                      OFDMPARAM_BW ","
	                      OFDMPARAM_FEC_HP ","
	                      OFDMPARAM_FEC_LP ","
	                      OFDMPARAM_QAM ","
	                      OFDMPARAM_TRANSMISSIONM ","
	                      OFDMPARAM_GUARDLIST ","
	                      OFDMPARAM_HIERARCHINFO
	                      ");", NULL, NULL, NULL);
	    if (rc)
	    {
	        printlog(LOG_ERROR, "Failed to create OFDMParameters table: %s\n", sqlite3_errmsg(DBaseInstance));
	        return rc;
	    }
		
	    rc = sqlite3_exec(DBaseInstance, "CREATE TABLE " PIDS_TABLE " ( "
	                      PID_MPLEXFREQ ","
	                      PID_SERVICEID ","
	                      PID_PID ","
	                      PID_TYPE ","
	                      PID_SUBTYPE ","
	                      PID_PMTVERSION ","
	                      "PRIMARY KEY(" PID_MPLEXFREQ "," PID_SERVICEID "," PID_PID ")"
	                      ");", NULL, NULL, NULL);
	    if (rc)
	    {
	        printlog(LOG_ERROR, "Failed to create OFDMParameters table: %s\n", sqlite3_errmsg(DBaseInstance));
	        return rc;
	    }

	    rc = sqlite3_exec(DBaseInstance, "CREATE TABLE " VERSION_TABLE " ( "
	                      VERSION_VERSION
	                      ");", NULL, NULL, NULL);
	    if (rc)
	    {
	        printlog(LOG_ERROR, "Failed to create Version table: %s\n", sqlite3_errmsg(DBaseInstance));
	        return rc;
	    }
	}
	/* Version 0.2 tables */
	if (version < 0.2)
	{
		/*
		(DVBS) QPSK: <channel name>:<frequency>:<polarisation>:<sat_no>:<sym_rate>
		(DVBC) QAM: <channel name>:<frequency>:<inversion>:<sym_rate>:<fec>:<qam>
		*/
		rc = sqlite3_exec(DBaseInstance, "CREATE TABLE " QPSKPARAMS_TABLE " ( "
	                      QPSKPARAM_FREQ " PRIMARY KEY,"
	                      QPSKPARAM_INVERSION ","
	                      QPSKPARAM_SYMBOL_RATE ","
	                      QPSKPARAM_FEC_INNER
	                      ");", NULL, NULL, NULL);
	    if (rc)
	    {
	        printlog(LOG_ERROR, "Failed to create OFDMParameters table: %s\n", sqlite3_errmsg(DBaseInstance));
	        return rc;
	    }
		rc = sqlite3_exec(DBaseInstance, "CREATE TABLE " QAMPARAMS_TABLE " ( "
	                      QAMPARAM_FREQ " PRIMARY KEY,"
	                      QAMPARAM_INVERSION ","
	                      QAMPARAM_SYMBOL_RATE ","
	                      QAMPARAM_FEC_INNER ","
	                      QAMPARAM_MODULATION
	                      ");", NULL, NULL, NULL);
	    if (rc)
	    {
	        printlog(LOG_ERROR, "Failed to create OFDMParameters table: %s\n", sqlite3_errmsg(DBaseInstance));
	        return rc;
	    }
	}
	
    rc = sqlite3_exec(DBaseInstance, "DELETE FROM " VERSION_TABLE ";", NULL, NULL, NULL);
	rc = sqlite3_exec(DBaseInstance, "INSERT INTO " VERSION_TABLE " VALUES ( " TOSTRING(DBASE_VERSION) " );", NULL, NULL, NULL);
    return rc;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲在线观看免费视频| 亚洲精品国产品国语在线app| 色综合色综合色综合| 国产成人av电影在线观看| 日本大胆欧美人术艺术动态| 午夜精品一区二区三区免费视频| 一区二区欧美精品| 日韩黄色免费网站| 久久成人免费网站| 国产一区二区在线免费观看| 国产成人综合在线| 成人av影院在线| 色欧美88888久久久久久影院| 色欧美88888久久久久久影院| 欧美天堂亚洲电影院在线播放| 欧美日韩亚洲高清一区二区| 欧美另类一区二区三区| 日韩欧美国产综合一区| 久久久久97国产精华液好用吗| 久久久一区二区三区| 中文字幕一区二区日韩精品绯色| 亚洲视频电影在线| 日韩高清一级片| 国产成人精品免费网站| 欧美性受极品xxxx喷水| 日韩亚洲欧美一区| 国产精品私房写真福利视频| 亚洲观看高清完整版在线观看| 麻豆成人久久精品二区三区小说| 国产激情一区二区三区四区| 成人a级免费电影| 56国语精品自产拍在线观看| 国产精品天天看| 日本一区中文字幕| www.av精品| 日韩一区二区三区三四区视频在线观看 | 激情五月播播久久久精品| 成人毛片在线观看| 欧美精选一区二区| 日韩理论片中文av| 美女网站色91| 91麻豆精品在线观看| 精品91自产拍在线观看一区| 亚洲激情中文1区| 粉嫩在线一区二区三区视频| 在线播放视频一区| 亚洲欧美成人一区二区三区| 精品一区二区三区香蕉蜜桃| 色8久久精品久久久久久蜜| 久久综合九色综合欧美亚洲| 亚洲成人av电影| 99r国产精品| 欧美国产精品中文字幕| 九九九精品视频| 欧美人妇做爰xxxⅹ性高电影 | 亚洲日韩欧美一区二区在线| 久久99国产精品麻豆| 欧美日韩不卡视频| 一区二区三区视频在线看| www.一区二区| 国产精品网曝门| 国产精品亚洲专一区二区三区| 在线观看91av| 香蕉成人啪国产精品视频综合网| 91尤物视频在线观看| 国产精品少妇自拍| 国产福利一区二区| 国产欧美日韩视频在线观看| 精品一区二区成人精品| 欧美一区二区免费| 奇米影视在线99精品| 91精品国产91久久久久久一区二区| 亚洲精品美腿丝袜| 色婷婷国产精品| 一级特黄大欧美久久久| 欧洲精品在线观看| 亚洲成年人影院| 欧美高清视频不卡网| 五月婷婷色综合| 日韩一级精品视频在线观看| 免费观看在线综合| 久久尤物电影视频在线观看| 国产精品自拍三区| 国产精品福利一区| 色狠狠av一区二区三区| 日韩中文字幕一区二区三区| 在线成人av影院| 精品一区二区在线免费观看| 久久久99久久精品欧美| av在线播放一区二区三区| 亚洲日本成人在线观看| 欧美日韩精品一区二区天天拍小说 | 免费成人小视频| 久久久国产精品午夜一区ai换脸| 国产69精品久久久久777| 中文字幕在线视频一区| 一本色道久久综合亚洲精品按摩| 午夜精品久久久久久久99水蜜桃| 欧美电影精品一区二区| 成人在线视频首页| 亚洲第一福利视频在线| 91精品欧美久久久久久动漫| 国产毛片一区二区| 一区二区三区小说| 日韩精品一区二区三区在线观看| 国产精品小仙女| 亚洲成人精品在线观看| 久久综合色婷婷| 欧美手机在线视频| 国产剧情一区二区| 亚洲国产一区二区三区青草影视| 日韩美女视频一区二区在线观看| 国产91精品一区二区| 亚洲亚洲人成综合网络| 久久这里只有精品6| 欧美日韩你懂得| 成人国产亚洲欧美成人综合网| 日韩国产精品久久久久久亚洲| 欧美国产亚洲另类动漫| 欧美一级一区二区| 色综合亚洲欧洲| 懂色av一区二区三区蜜臀| 日韩黄色小视频| 亚洲综合久久久| 国产视频一区在线播放| 88在线观看91蜜桃国自产| 国产成人aaa| 国内精品写真在线观看| 五月天婷婷综合| 一区二区三区日韩精品视频| 国产精品色在线观看| 日韩视频一区二区三区在线播放 | 日韩精品1区2区3区| 亚洲毛片av在线| 亚洲欧美自拍偷拍| 中文字幕国产一区| 国产区在线观看成人精品| 精品国产乱码久久久久久久久 | 欧美日韩国产美| 91精彩视频在线观看| 99精品热视频| 成人免费高清在线| 国产精品一区二区不卡| 国产毛片精品一区| 国产一区二区三区不卡在线观看| 另类调教123区| 老司机午夜精品| 久久97超碰色| 精品影视av免费| 国内成人自拍视频| 精品亚洲porn| 国内精品视频666| 国产美女精品在线| 国产91精品入口| 99久久精品国产网站| 91在线porny国产在线看| 一本高清dvd不卡在线观看| 97se亚洲国产综合在线| 91精品1区2区| 欧美精品在欧美一区二区少妇| 欧美精品欧美精品系列| 91精品婷婷国产综合久久| 日韩欧美成人激情| 久久久精品日韩欧美| 中文字幕av一区二区三区| 国产精品久久久爽爽爽麻豆色哟哟| 国产拍揄自揄精品视频麻豆| 国产精品视频线看| 亚洲午夜在线视频| 久久国产麻豆精品| 高清av一区二区| 91精彩视频在线| 日韩视频免费观看高清完整版 | 国产mv日韩mv欧美| 色播五月激情综合网| 欧美精品久久99| 国产日韩精品久久久| 亚洲视频在线一区| 日韩成人午夜电影| proumb性欧美在线观看| 欧美日韩精品电影| 久久久久久99精品| 亚洲一区精品在线| 国产麻豆日韩欧美久久| 色屁屁一区二区| 久久久亚洲国产美女国产盗摄| 亚洲欧美激情小说另类| 免费人成在线不卡| 一本久久精品一区二区| 日韩欧美色电影| 一级中文字幕一区二区| 国产乱码精品一区二区三区忘忧草 | fc2成人免费人成在线观看播放| 欧美系列在线观看| 国产精品高潮呻吟| 国产伦精一区二区三区| 欧美丰满高潮xxxx喷水动漫| 1000部国产精品成人观看| 另类小说视频一区二区| 欧美午夜在线观看|