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

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

?? cross.cpp

?? 天之煉獄1服務(wù)器端源文件游戲服務(wù)端不完整
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
	Statement* pStmt;	BEGIN_DB 	{		pStmt = g_pDatabaseManager->getConnection("DARKEDEN")->createStatement();        Result* pResult = pStmt->executeQuery("SELECT MAX(ItemType) FROM CrossInfo");        pResult->next();        m_InfoCount = pResult->getInt(1);        m_pItemInfos = new ItemInfo*[m_InfoCount+1];        for (uint i = 0 ; i <= m_InfoCount ; i ++)            m_pItemInfos[i] = NULL;        pResult = pStmt->executeQuery(			"SELECT ItemType, Name, EName, Price, Volume, Weight, Ratio, Durability, minDamage, maxDamage, MPBonus, MaxSilver, Speed, ReqAbility, ItemLevel, CriticalBonus, DefaultOption, UpgradeRatio, UpgradeCrashPercent, NextOptionRatio, NextItemType, DowngradeRatio FROM CrossInfo"		);		while (pResult->next()) 		{			uint i = 0;			CrossInfo* pCrossInfo = new CrossInfo();			pCrossInfo->setItemType(pResult->getInt(++i));			pCrossInfo->setName(pResult->getString(++i));			pCrossInfo->setEName(pResult->getString(++i));			pCrossInfo->setPrice(pResult->getInt(++i));			pCrossInfo->setVolumeType(pResult->getInt(++i));			pCrossInfo->setWeight(pResult->getInt(++i));			pCrossInfo->setRatio(pResult->getInt(++i));			pCrossInfo->setDurability(pResult->getInt(++i));			pCrossInfo->setMinDamage(pResult->getInt(++i));			pCrossInfo->setMaxDamage(pResult->getInt(++i));			pCrossInfo->setMPBonus(pResult->getInt(++i));			pCrossInfo->setMaxSilver(pResult->getInt(++i));			pCrossInfo->setSpeed(pResult->getInt(++i));			pCrossInfo->setReqAbility(pResult->getString(++i));			pCrossInfo->setItemLevel(pResult->getInt(++i));			pCrossInfo->setCriticalBonus(pResult->getInt(++i));			pCrossInfo->setDefaultOptions(pResult->getString(++i));			pCrossInfo->setUpgradeRatio(pResult->getInt(++i));			pCrossInfo->setUpgradeCrashPercent(pResult->getInt(++i));			pCrossInfo->setNextOptionRatio(pResult->getInt(++i));			pCrossInfo->setNextItemType(pResult->getInt(++i));			pCrossInfo->setDowngradeRatio(pResult->getInt(++i));			addItemInfo(pCrossInfo);		}				SAFE_DELETE(pStmt);	}	END_DB(pStmt)		__END_CATCH}//--------------------------------------------------------------------------------// load to creature//--------------------------------------------------------------------------------void CrossLoader::load(Creature* pCreature) 	throw(Error){	__BEGIN_TRY	Assert(pCreature != NULL);	Statement* pStmt;	BEGIN_DB 	{		pStmt = g_pDatabaseManager->getConnection("DARKEDEN")->createStatement();		/*		StringStream sql;		sql << "SELECT ItemID, ObjectID, ItemType, Storage, StorageID, X, Y,"			<< " OptionType, Durability, EnchantLevel, Silver FROM CrossObject"			<< " WHERE OwnerID = '" << pCreature->getName() << "' AND Storage IN("			<<(int)STORAGE_INVENTORY << ", " <<(int)STORAGE_GEAR << ", " <<(int)STORAGE_BELT << ", " 			<<(int)STORAGE_EXTRASLOT << ", " <<(int)STORAGE_MOTORCYCLE << ", " <<(int)STORAGE_STASH << ", " 			<<(int)STORAGE_GARBAGE << ")";		Result* pResult = pStmt->executeQuery(sql.toString());		*/		Result* pResult = pStmt->executeQuery( "SELECT ItemID, ObjectID, ItemType, Storage, StorageID, X, Y, OptionType, Durability, EnchantLevel, Silver, Grade, ItemFlag FROM CrossObject WHERE OwnerID = '%s' AND Storage IN(0, 1, 2, 3, 4, 9)",									pCreature->getName().c_str() );		while (pResult->next())		{			try {				uint i = 0;				Cross* pCross = new Cross();				pCross->setItemID(pResult->getDWORD(++i));				pCross->setObjectID(pResult->getDWORD(++i));				pCross->setItemType(pResult->getDWORD(++i));					if (g_pCrossInfoManager->getItemInfo(pCross->getItemType())->isUnique())					pCross->setUnique();				Storage storage =(Storage)pResult->getInt(++i);				StorageID_t storageID = pResult->getDWORD(++i);				BYTE x = pResult->getBYTE(++i);				BYTE y = pResult->getBYTE(++i);				string optionField = pResult->getString(++i);				list<OptionType_t> optionTypes;				setOptionTypeFromField(optionTypes, optionField);				pCross->setOptionType(optionTypes);				pCross->setDurability(pResult->getInt(++i));				pCross->setEnchantLevel(pResult->getInt(++i));				pCross->setSilver(pResult->getInt(++i));				pCross->setGrade(pResult->getInt(++i));				pCross->setCreateType((Item::CreateType)pResult->getInt(++i));				Inventory*  pInventory      = NULL;				Slayer*     pSlayer         = NULL;				Vampire*    pVampire        = NULL;				Motorcycle* pMotorcycle     = NULL;				Inventory*  pMotorInventory = NULL;				//Item*       pItem           = NULL;				Stash*      pStash          = NULL;				//Belt*       pBelt           = NULL;				//Inventory*  pBeltInventory  = NULL;				if (pCreature->isSlayer())				{					pSlayer     = dynamic_cast<Slayer*>(pCreature);					pInventory  = pSlayer->getInventory();					pStash      = pSlayer->getStash();					pMotorcycle = pSlayer->getMotorcycle();					if (pMotorcycle) pMotorInventory = pMotorcycle->getInventory();				}				else if (pCreature->isVampire()) 				{					pVampire   = dynamic_cast<Vampire*>(pCreature);					pInventory = pVampire->getInventory();					pStash     = pVampire->getStash();				}				else throw UnsupportedError("Monster,NPC 牢亥配府狼 歷厘籃 酒流 瘤盔登瘤 臼嚼聰促.");				switch(storage)				{					case STORAGE_INVENTORY:						if (pInventory->canAddingEx(x, y, pCross))						{							pInventory->addItemEx(x, y, pCross);						}						else						{							processItemBugEx(pCreature, pCross);						}						break;					case STORAGE_GEAR:						if (pCreature->isSlayer())						{							if (!pSlayer->isWear((Slayer::WearPart)x))							{								pSlayer->wearItem((Slayer::WearPart)x, pCross);							}							else							{								processItemBugEx(pCreature, pCross);							}						}						else if (pCreature->isVampire())						{							processItemBugEx(pCreature, pCross);						}						break;					case STORAGE_BELT :						processItemBugEx(pCreature, pCross);						break;					case STORAGE_EXTRASLOT :						if (pCreature->isSlayer())       pSlayer->addItemToExtraInventorySlot(pCross);						else if (pCreature->isVampire()) pVampire->addItemToExtraInventorySlot(pCross);						break;					case STORAGE_MOTORCYCLE:						processItemBugEx(pCreature, pCross);						break;					case STORAGE_STASH:						if (pStash->isExist(x, y))						{							processItemBugEx(pCreature, pCross);						}						else pStash->insert(x, y, pCross);						break;					case STORAGE_GARBAGE:						processItemBug(pCreature, pCross);						break;					default :						SAFE_DELETE(pStmt);	// by sigi						throw Error("invalid storage or OwnerID must be NULL");				}			} catch (Error& error) {				filelog("itemLoadError.txt", "[%s] %s", getItemClassName().c_str(), error.toString().c_str());				throw;			} catch (Throwable& t) {				filelog("itemLoadError.txt", "[%s] %s", getItemClassName().c_str(), t.toString().c_str());			}		}		SAFE_DELETE(pStmt);	}	END_DB(pStmt)		__END_CATCH}//--------------------------------------------------------------------------------// load to zone//--------------------------------------------------------------------------------void CrossLoader::load(Zone* pZone) 	throw(Error){	__BEGIN_TRY	Assert(pZone != NULL);	Statement* pStmt;	BEGIN_DB 	{		pStmt = g_pDatabaseManager->getConnection("DARKEDEN")->createStatement();		StringStream sql;		sql << "SELECT ItemID, ObjectID, ItemType, Storage, StorageID, X, Y,"			<< " OptionType, Durability, EnchantLevel, Silver, ItemFlag FROM CrossObject"			<< " WHERE Storage = " <<(int)STORAGE_ZONE << " AND StorageID = " << pZone->getZoneID();		Result* pResult = pStmt->executeQuery(sql.toString());		while (pResult->next())		{			uint i = 0;			Cross* pCross = new Cross();			pCross->setItemID(pResult->getInt(++i));			pCross->setObjectID(pResult->getInt(++i));			pCross->setItemType(pResult->getInt(++i));			Storage storage =(Storage)pResult->getInt(++i);			StorageID_t storageID = pResult->getInt(++i);			BYTE x = pResult->getInt(++i);			BYTE y = pResult->getInt(++i);			string optionField = pResult->getString(++i);			list<OptionType_t> optionTypes;			setOptionTypeFromField(optionTypes, optionField);			pCross->setOptionType(optionTypes);			pCross->setDurability(pResult->getInt(++i));			pCross->setEnchantLevel(pResult->getInt(++i));			pCross->setSilver(pResult->getInt(++i));			pCross->setCreateType((Item::CreateType)pResult->getInt(++i));			switch(storage)			{				case STORAGE_ZONE :						{						Tile & pTile = pZone->getTile(x,y);						Assert(!pTile.hasItem());						pTile.addItem(pCross);					}					break;				case STORAGE_STASH :				case STORAGE_CORPSE :					throw UnsupportedError("惑磊 棺 矯眉救狼 酒撈袍狼 歷厘籃 酒流 瘤盔登瘤 臼嚼聰促.");				default :					throw Error("Storage must be STORAGE_ZONE");			}		}		SAFE_DELETE(pStmt);	}	END_DB(pStmt)	__END_CATCH}//--------------------------------------------------------------------------------// load to inventory//--------------------------------------------------------------------------------void CrossLoader::load(StorageID_t storageID, Inventory* pInventory) 	throw(Error){	__BEGIN_TRY	Statement* pStmt;	BEGIN_DB 	{	}	END_DB(pStmt)		__END_CATCH}CrossLoader* g_pCrossLoader = NULL;

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91精彩视频在线| 国产精品视频在线看| 日韩欧美成人午夜| 国产清纯白嫩初高生在线观看91| 中文字幕亚洲一区二区av在线| 日韩制服丝袜av| 99vv1com这只有精品| 精品国产一区二区亚洲人成毛片| 一区二区在线观看免费| 福利一区在线观看| 日韩精品专区在线影院重磅| 亚洲一区二区三区在线| 成人app网站| 国产亚洲欧美一区在线观看| 日日骚欧美日韩| 欧美日韩久久一区二区| 国产精品福利一区二区三区| 国内久久精品视频| 欧美一区午夜视频在线观看| 亚洲午夜激情网页| 日本精品视频一区二区三区| 中文字幕中文字幕在线一区| 国产呦萝稀缺另类资源| 91麻豆精品91久久久久久清纯| 一区二区三区毛片| 色综合久久综合网| 亚洲黄色av一区| 国产成人av电影| 欧美激情在线一区二区| 国产一区日韩二区欧美三区| 精品国产一区二区三区不卡 | 亚洲欧洲www| 成人深夜在线观看| 国产精品网站一区| 国产成人免费在线| 国产欧美精品国产国产专区| 国产成人久久精品77777最新版本 国产成人鲁色资源国产91色综 | 亚洲欧洲韩国日本视频| www.av亚洲| 艳妇臀荡乳欲伦亚洲一区| 欧洲中文字幕精品| 午夜视频在线观看一区| 91精品国产综合久久福利软件 | 午夜精品一区二区三区三上悠亚 | 97se亚洲国产综合在线| 亚洲男女一区二区三区| 在线国产亚洲欧美| 日本不卡中文字幕| 久久综合九色综合欧美98| 国产精品18久久久| 一区二区三区免费在线观看| 555www色欧美视频| 国产在线国偷精品免费看| 国产精品欧美精品| 欧美影院一区二区三区| 精品在线观看视频| 中文字幕的久久| 在线亚洲+欧美+日本专区| 日本美女一区二区三区视频| 中文字幕不卡在线播放| 欧美美女bb生活片| 国产一区二区三区四区五区入口| 国产欧美一区二区精品忘忧草| 欧日韩精品视频| 激情欧美一区二区| 亚洲青青青在线视频| 日韩欧美成人午夜| 日本久久一区二区| 国产精品一区二区在线看| 亚洲精品高清在线| 久久人人97超碰com| 在线一区二区观看| 国产精品羞羞答答xxdd| 偷拍日韩校园综合在线| 国产精品家庭影院| 精品1区2区在线观看| 在线观看网站黄不卡| 激情综合色综合久久综合| 樱桃视频在线观看一区| 久久先锋资源网| 欧美美女喷水视频| 色综合久久中文字幕综合网| 裸体在线国模精品偷拍| 亚洲影视在线观看| 国产精品久久久久一区二区三区 | 精品国产免费人成在线观看| 一本色道久久综合亚洲精品按摩 | 亚洲欧美综合另类在线卡通| 欧美一级国产精品| 欧美性色aⅴ视频一区日韩精品| 国产精品系列在线观看| 九九**精品视频免费播放| 亚洲成人免费看| 国产精品久久久久精k8| 久久精品无码一区二区三区| 日韩一级片在线观看| 欧美日韩午夜在线视频| 在线视频国产一区| 91在线观看视频| 成人app软件下载大全免费| 国产成人免费av在线| 狠狠色丁香久久婷婷综合丁香| 日日嗨av一区二区三区四区| 亚洲国产成人porn| 亚洲h精品动漫在线观看| 夜夜精品视频一区二区| 一区二区三区在线高清| 一区二区在线免费观看| 亚洲品质自拍视频| 亚洲综合色区另类av| 一区二区在线免费观看| 亚洲成人免费在线| 日本强好片久久久久久aaa| 日韩精品视频网站| 免费黄网站欧美| 蜜桃精品视频在线| 久久国产乱子精品免费女| 久久国产婷婷国产香蕉| 国产麻豆午夜三级精品| 成人一区二区三区| 成人黄色a**站在线观看| 97久久精品人人做人人爽 | 高清av一区二区| 99综合影院在线| 91浏览器打开| 欧美精品日韩一本| 欧美电影免费提供在线观看| 久久久午夜精品| 国产精品久久久久婷婷| 亚洲精品亚洲人成人网| 亚洲成va人在线观看| 久久99久久99小草精品免视看| 韩国av一区二区| av一区二区三区在线| 欧美熟乱第一页| 日韩三级视频在线看| 欧美激情一区二区三区| 亚洲精品免费在线播放| 日韩—二三区免费观看av| 国产在线精品免费| 91国产视频在线观看| 欧美一级xxx| 亚洲欧洲精品一区二区三区 | 日日骚欧美日韩| 国产精品一区二区视频| 91色综合久久久久婷婷| 91精品国产色综合久久| 久久精品视频免费观看| 亚洲综合色在线| 国产福利91精品| 欧美日韩一级大片网址| 国产亚洲污的网站| 午夜精品久久久久久久久| 国产精品一二三| 欧美日韩你懂的| 国产精品视频在线看| 美美哒免费高清在线观看视频一区二区 | 欧美成人一区二区| 亚洲天堂2014| 韩国欧美一区二区| 欧美日韩在线播放三区| 国产视频亚洲色图| 日精品一区二区三区| 色老头久久综合| 亚洲国产精品黑人久久久| 婷婷激情综合网| 91啦中文在线观看| 久久美女艺术照精彩视频福利播放| 亚洲一区在线观看网站| 国v精品久久久网| 日韩视频免费直播| 亚洲影视资源网| 99久久精品国产一区| 26uuu精品一区二区在线观看| 午夜精品久久久久久久| 色婷婷av一区二区三区gif | a级精品国产片在线观看| 欧美电影免费观看高清完整版在线观看| 综合在线观看色| 成人午夜视频在线观看| 精品国产乱码久久久久久牛牛| 偷拍自拍另类欧美| 欧美三级电影在线看| 一区二区在线观看av| 99精品在线观看视频| 国产欧美日韩在线观看| 国产精选一区二区三区| 欧美岛国在线观看| 热久久国产精品| 91精品国产免费| 日本不卡视频在线观看| 欧美二区三区的天堂| 亚洲一区二区综合| 日本电影亚洲天堂一区| 亚洲欧美偷拍三级| 日本丶国产丶欧美色综合| 一区二区三区国产精华| 91电影在线观看| 亚州成人在线电影| 日韩一区二区免费高清|