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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? database.cpp

?? 一個symbian操作系統(tǒng)的
?? CPP
字號:
#include "database.h"
#include <utf.h>
#include <aknnotewrappers.h>
#include "HeatMeter2Container.h"

CDataBase* CDataBase::NewL(MContainerObserver *aCallBack)
{
    CDataBase* self = NewLC(aCallBack);
    CleanupStack::Pop(); // self
    return self;
}

CDataBase* CDataBase::NewLC(MContainerObserver *aCallBack)
{
    CDataBase* self = new (ELeave) CDataBase();
    CleanupStack::PushL(self);
    self->ConstructL(aCallBack);
    return self;
}


void CDataBase::ConstructL(MContainerObserver *aCallBack)
{
	//initialize with default values
	iVersion=0;
	iClientID=1125;

	//set database and ini file location
	iCallBack=aCallBack;
	fileName=(_L("\\System\\Apps\\HeatMeter2\\HeatMeter.db"));
	iniFileName=(_L("\\System\\Apps\\HeatMeter2\\HeatMeter.ini"));
	iGprsClient=CGprsClient::NewL(this);
	if (OpenDb()!=KErrNone) 
	{
		//create a DB first if does not exist
		User::LeaveIfError(CreateDb());
		User::LeaveIfError(OpenDb());
	}
}

//creates the database
TInt CDataBase::CreateDb()
{
	//Create Database
	SaveIniFile();
	iFs.Connect();
	iHeatMeterDb.Replace(iFs, fileName);

	//Create Tables
	TDbCol subs_id(_L("subs_id"), EDbColUint32);
	TDbCol addr(_L("addr"), EDbColText);
	TDbCol name(_L("name"), EDbColText);
	TDbCol state(_L("state"), EDbColUint32);
	CDbColSet *heatMeterColSet=CDbColSet::NewLC();
	heatMeterColSet->AddL(subs_id);
	heatMeterColSet->AddL(addr);
	heatMeterColSet->AddL(name);
	heatMeterColSet->AddL(state);
	iHeatMeterDb.CreateTable(_L("heatmeter"), *heatMeterColSet);
	CleanupStack::PopAndDestroy(heatMeterColSet);

	CDbKey *heatMeterIndex=CDbKey::NewLC();
	TDbKeyCol addrKeyCol(_L("addr"));
	heatMeterIndex->AddL(addrKeyCol);
	iHeatMeterDb.CreateIndex(_L("TheIndex"), _L("heatmeter"), *heatMeterIndex);
	CleanupStack::PopAndDestroy(heatMeterIndex);
	iHeatMeterDb.Close();
	iFs.Close();
	return 1;

}

//opens the database
TInt CDataBase::OpenDb()
{
	iDbSession.Connect();	
	TInt ret=iHeatMeterDb.Open(iDbSession, fileName);
	if (ret!=KErrNone) iDbSession.Close();
	else
	{
		//read ini file
		iFs.Connect();
		RFile iniFile;
		iniFile.Open(iFs, iniFileName, EFileRead);
		TFileText tFileText;
		tFileText.Set(iniFile);
		TBuf<100> nowLine;
		tFileText.Read(nowLine);
		TLex lex(nowLine);
		lex.SkipCharacters();
		lex.SkipSpace();
		lex.Val(iVersion);
		tFileText.Read(nowLine);
		TLex lex2(nowLine);
		lex2.SkipCharacters();
		lex2.SkipSpace();
		lex2.Val(iClientID);
		tFileText.Read(nowLine);
		TInt index=nowLine.Locate(' ');
		((CHeatMeter2Container*)iCallBack)->iServerAddr.Input(nowLine.Mid(index+1));		//"ServerAddress 192.168.0.1"
		iniFile.Close();
		iFs.Close();
	}
	return ret;
}

CDataBase::~CDataBase()
{
	iHeatMeterDb.Close();
	iDbSession.Close();
	SaveIniFile();
	delete iGprsClient;
}


//fills listbox array with values read from database
void CDataBase::FillArrays(CDesCArray *aListBoxArray, CArrayFixFlat<TInt> *aValues, CArrayFixFlat<TInt> *aIDs)
{
	RDbView view;
	aListBoxArray->Reset();
	aValues->Reset();
	aIDs->Reset();
	view.Prepare(iHeatMeterDb, TDbQuery(_L("SELECT * FROM HEATMETER")), view.EReadOnly);
	CleanupClosePushL(view);
	view.EvaluateAll();
	for (view.FirstL(); view.AtRow(); view.NextL())
	{
		view.GetL();
		TBuf<200> text;
		TBuf<100> addr=view.ColDes16(3);
		TBuf<100> name=view.ColDes16(2);
		TInt value=view.ColUint32(4);
		if (value==0) text.Format(_L("\t%S\t%S\t0"), &addr, &name);
		else text.Format(_L("\t%S\t%S [%d]\t1"), &addr, &name, value);
		aListBoxArray->AppendL(text);
		aValues->AppendL(value);
		aIDs->AppendL(view.ColUint32(1));
	}
	CleanupStack::PopAndDestroy();
}

//called by GPRS receiver class when a response is received from the server
void CDataBase::ResponseReceived(TDesC8 &aResponse)
{
	//return if error
	if (aResponse.Length()<10)	//probably empty response
	{
		iCallBack->SynchFailed(0);
		return;
	}
	TInt pos0=aResponse.Find(_L8("\r\n\r\nError"));
	if (pos0>=0)  //error occured, but HTTP packet is ok
	{
		iCallBack->SynchFailed(1);
		return;
	}
	TInt pos=aResponse.Find(_L8("\r\n\r\n"))+4; //start position of actual data (body)

	TBuf8<10000> *response8=new (ELeave) TBuf8<10000>;
	TBuf16<5000> *response16=new (ELeave) TBuf16<5000>;
	response8->Copy(aResponse.Ptr()+pos);

	CnvUtfConverter::ConvertToUnicodeFromUtf8(*response16, *response8);
	delete response8;
	
	//start a transaction
	iHeatMeterDb.Begin();

	//read new database version
	TLex16 lex(*response16);
	lex.Val(iVersion);
	lex.SkipSpace();
	while (lex.Eos()==false)
	{
		TBuf<6> action;
		TInt ID;
		lex.Mark();
		lex.SkipCharacters();
		action=lex.MarkedToken();
		lex.SkipSpace();

		//update database
		if (action==_L("DELETE"))
		{
			lex.Val(ID);
			lex.SkipSpace();
			TBuf<200> command;

			command.Format(_L("DELETE FROM heatmeter WHERE subs_id=%d"), ID);
			iHeatMeterDb.Execute(command);
		}
		else if (action==_L("RENAME"))
		{
			TInt nextLength;
			TBuf<100> newName;
			lex.Val(ID);
			lex.SkipSpace();

			lex.Val(nextLength);
			lex.SkipSpace();
			lex.Mark();
			lex.Inc(nextLength);
			newName=lex.MarkedToken();
			lex.SkipSpace();

			TBuf<200> command;
			command.Format(_L("UPDATE heatmeter SET name='%S' WHERE subs_id=%d"), &newName, ID);
			iHeatMeterDb.Execute(command);
		}
		else if (action==_L("ADDNEW"))
		{
			TInt nextLength;
			TBuf<100> newName;
			TBuf<100> newAddr;
			lex.Val(ID);
			lex.SkipSpace();

			lex.Val(nextLength);
			lex.SkipSpace();
			lex.Mark();
			lex.Inc(nextLength);
			newAddr=lex.MarkedToken();
			lex.SkipSpace();

			lex.Val(nextLength);
			lex.SkipSpace();
			lex.Mark();
			lex.Inc(nextLength);
			newName=lex.MarkedToken();
			lex.SkipSpace();

			TBuf<200> command;
			command.Format(_L("INSERT INTO heatmeter (subs_id, addr, name, state) VALUES (%d, '%S\', '%S', 0)"), ID, &newAddr, &newName);
			iHeatMeterDb.Execute(command);
		}
	}

	delete response16;
	//commit database changes
	iHeatMeterDb.Commit();
	//save new database version
	SaveIniFile();
	//reset all state entries
	iHeatMeterDb.Execute(_L("UPDATE heatmeter SET state=0"));
	//tell the view that synch is complete
	iCallBack->SynchReady();
}


//called by the view to start synchronisation
void CDataBase::Synch(TInetAddr &aIpAddress, TDesC&/* aPath*/)
{

	//create the http body for synch
	TBuf16<1000> *content16=new (ELeave) TBuf16<1000>;
	TBuf8<2000> *content8=new (ELeave) TBuf8<2000>;
	content16->Num(iVersion);
	content16->Append(_L("\n"));
	content16->AppendNum(iClientID);
	content16->Append(_L("\n"));

	RDbView view;
	view.Prepare(iHeatMeterDb, TDbQuery(_L("SELECT * FROM HEATMETER WHERE state>0")), view.EReadOnly);
	CleanupClosePushL(view);
	view.EvaluateAll();
	for (view.FirstL(); view.AtRow(); view.NextL())
	{
		view.GetL();
		content16->AppendNum(view.ColUint32(1), EDecimal); //id
		content16->Append(_L("\n"));
		content16->AppendNum(view.ColUint32(4), EDecimal); //state
		content16->Append(_L("\n"));
		
	}
	CleanupStack::PopAndDestroy();

	//convert it to UTF8 to be smaller
	CnvUtfConverter::ConvertFromUnicodeToUtf8(*content8, *content16);
	
	//create HTTP header
	TBuf8<3000> *httpBuffer8=new (ELeave) TBuf8<3000>;
	*httpBuffer8=_L8("POST /gaz/gaz HTTP/1.0\r\nContent-Type: text/plain; charset=UTF-8\r\nContent-Length: ");
	httpBuffer8->AppendNum(content8->Length());
	httpBuffer8->Append(_L("\r\n\r\n"));
	httpBuffer8->Append(*content8);

	//send the packet and wait for response
	iGprsClient->SendL(aIpAddress, *httpBuffer8);
	delete httpBuffer8;
	delete content8;
	delete content16;
	
}

//update a heatmeter state in the database
void CDataBase::UpdateItemValue(TInt aID, TInt aState)
{
	TBuf<200> command;
	command.Format(_L("UPDATE heatmeter SET state=%d WHERE subs_id=%d"), aState, aID);
	iHeatMeterDb.Execute(command);

}

//saves ini file
void CDataBase::SaveIniFile()
{
	RFs iFs;
	iFs.Connect();
	RFile iniFile;
	iniFile.Replace(iFs, iniFileName, EFileWrite);
	TFileText tFileText;
	tFileText.Set(iniFile);
	TBuf<100> nowLine;
	nowLine.Format(_L("DatabaseVersion %d"), iVersion);
	tFileText.Write(nowLine);
	nowLine.Format(_L("ClientID %d"), iClientID);
	tFileText.Write(nowLine);
	TBuf<20> addrStr;
	((CHeatMeter2Container*)iCallBack)->iServerAddr.Output(addrStr);
	nowLine.Format(_L("ServerAddress %S"), &addrStr);
	tFileText.Write(nowLine);
	
	iniFile.Close();
	iFs.Close();

}

void CDataBase::ResetDataBase()
{
	iHeatMeterDb.Execute(_L("DELETE FROM heatmeter"));
	iVersion=0;
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一区二区三区不卡在线观看 | 日韩午夜在线观看视频| 欧美性受xxxx黑人xyx性爽| 国产女人水真多18毛片18精品视频| 99re视频这里只有精品| 精品视频色一区| 日韩欧美精品在线视频| 国产精品久久久久久久久晋中| 一个色综合网站| 久久精品理论片| 97久久超碰国产精品电影| 欧美精品乱人伦久久久久久| 精品国产成人系列| 亚洲日本成人在线观看| 蜜臀久久99精品久久久久宅男| 成人一区二区视频| 欧美久久久影院| 中文字幕不卡一区| 日韩电影免费在线看| av一区二区不卡| 日韩三级伦理片妻子的秘密按摩| 国产精品久久久久久久裸模| 日韩高清在线一区| 波多野结衣中文字幕一区二区三区| 欧美精品在线一区二区三区| 国产精品美女久久久久久| 日韩va亚洲va欧美va久久| 波波电影院一区二区三区| 欧美一卡二卡在线观看| 一色桃子久久精品亚洲| 精彩视频一区二区| 欧美日韩亚洲国产综合| 中文字幕久久午夜不卡| 久久99久久99精品免视看婷婷 | 亚洲色图欧美在线| 国产精品乡下勾搭老头1| 在线观看91精品国产麻豆| 亚洲视频免费观看| 国产精品一区二区91| 91精品国产美女浴室洗澡无遮挡| 国产精品国产三级国产| 国产精品资源在线看| 制服.丝袜.亚洲.中文.综合 | 欧美一区二区三区爱爱| 亚洲一级不卡视频| 成人免费电影视频| 久久九九全国免费| 日本va欧美va精品| 欧美手机在线视频| 亚洲精品一二三| 99久久99久久精品国产片果冻| 26uuuu精品一区二区| 免费观看久久久4p| 91精品国模一区二区三区| 亚洲mv大片欧洲mv大片精品| 91蜜桃在线观看| 中文字幕中文字幕中文字幕亚洲无线 | 成人av在线资源网站| 国产午夜精品一区二区三区视频 | 久久香蕉国产线看观看99| 日本大胆欧美人术艺术动态| 欧美另类久久久品| 亚洲成人福利片| 欧美日本一区二区| 亚洲二区视频在线| 欧美日韩在线观看一区二区 | 欧美精品亚洲一区二区在线播放| 一区二区三区**美女毛片| 91在线观看地址| 专区另类欧美日韩| 91免费视频网| 亚洲精品亚洲人成人网在线播放| 一本一道久久a久久精品| **性色生活片久久毛片| av男人天堂一区| 日韩伦理av电影| 色婷婷av一区二区三区gif| 亚洲欧美日韩国产另类专区| 色偷偷88欧美精品久久久| 亚洲狠狠丁香婷婷综合久久久| 色综合天天综合给合国产| 伊人色综合久久天天| 欧美日精品一区视频| 五月婷婷欧美视频| 欧美电视剧免费全集观看| 九九在线精品视频| 国产日本欧美一区二区| jlzzjlzz国产精品久久| 一区二区三区高清在线| 欧美日韩免费电影| 久久99精品国产麻豆婷婷| 久久久不卡影院| 99久久精品国产观看| 亚洲妇女屁股眼交7| 日韩精品在线一区二区| 国产成人日日夜夜| 国产精品久久久久久久久搜平片 | 亚洲电影一级黄| 日韩一区二区三区三四区视频在线观看| 美女在线视频一区| 国产三区在线成人av| 色呦呦日韩精品| 美女精品自拍一二三四| 国产日产欧产精品推荐色| 色天使色偷偷av一区二区| 免费高清在线视频一区·| 中文在线一区二区| 日本精品一区二区三区高清 | 国产精品第13页| 欧美三级韩国三级日本一级| 久久99国产精品久久99果冻传媒| 欧美国产视频在线| 欧美综合一区二区| 国产美女一区二区三区| 亚洲综合视频网| 久久久一区二区三区| 91老师国产黑色丝袜在线| 久久精品99久久久| 亚洲女与黑人做爰| 精品国内片67194| 色狠狠av一区二区三区| 激情国产一区二区 | 7777精品久久久大香线蕉| 国产成人自拍高清视频在线免费播放| 一区二区视频在线看| 日韩精品一区二区三区四区| 一本色道亚洲精品aⅴ| 国产真实乱对白精彩久久| 一区二区三区欧美视频| 国产日韩欧美综合在线| 欧美日韩在线一区二区| 丁香一区二区三区| 奇米影视7777精品一区二区| 国产精品美女久久久久久久久 | 国产一区二区美女诱惑| 亚洲午夜久久久久久久久久久 | av亚洲产国偷v产偷v自拍| 蜜臀久久久99精品久久久久久| 亚洲美女视频在线观看| 精品嫩草影院久久| 欧洲av一区二区嗯嗯嗯啊| 粉嫩高潮美女一区二区三区| 日本怡春院一区二区| 亚洲免费观看高清完整版在线观看 | 韩国v欧美v亚洲v日本v| 亚洲免费看黄网站| 亚洲国产成人一区二区三区| 日韩欧美美女一区二区三区| 色8久久精品久久久久久蜜| 国产精品小仙女| 久久精品国产秦先生| 天天综合天天做天天综合| 亚洲色图第一区| 国产精品美女视频| 欧美一级艳片视频免费观看| 色一区在线观看| 99精品欧美一区二区三区综合在线| 国产一区二区三区电影在线观看 | 久久这里只有精品6| 欧美一区二区三区系列电影| 在线免费观看日本欧美| 99国产精品国产精品久久| 成人亚洲一区二区一| 国产精品一级片在线观看| 国产v日产∨综合v精品视频| 国产真实乱偷精品视频免| 亚洲成人av电影在线| 一区二区三区四区亚洲| 国产精品久久久久永久免费观看| 久久亚洲私人国产精品va媚药| 日韩欧美一级二级| 日韩一区二区三区视频在线观看| 欧美乱妇20p| 99久久精品一区二区| 另类小说图片综合网| 日韩精品专区在线影院重磅| 东方欧美亚洲色图在线| 国产一区二区三区四区五区美女| 麻豆精品国产91久久久久久| 免费人成黄页网站在线一区二区 | 欧美日韩视频专区在线播放| 色婷婷综合激情| 在线观看av一区二区| 在线免费观看一区| 欧美三级乱人伦电影| 欧美日本不卡视频| 欧美色综合网站| 欧美日韩黄视频| 日韩视频中午一区| 精品国产伦一区二区三区观看体验 | 亚洲精品免费看| 亚洲综合丁香婷婷六月香| 午夜精品123| 日本欧美久久久久免费播放网| 日韩电影在线观看电影| 韩日精品视频一区| 高清日韩电视剧大全免费| 91美女片黄在线观看91美女| 在线看一区二区| 日韩天堂在线观看|