mirror of
				https://github.com/OpenMW/openmw.git
				synced 2025-10-25 14:26:36 +00:00 
			
		
		
		
	Merchant items should be restocked instantly
This commit is contained in:
		
							parent
							
								
									1bcc4430e0
								
							
						
					
					
						commit
						fb542a64ec
					
				
					 3 changed files with 19 additions and 10 deletions
				
			
		|  | @ -415,20 +415,11 @@ namespace MWGui | |||
|         MWMechanics::CreatureStats &sellerStats = mPtr.getClass().getCreatureStats(mPtr); | ||||
|         float delay = MWBase::Environment::get().getWorld()->getStore().get<ESM::GameSetting>().find("fBarterGoldResetDelay")->getFloat(); | ||||
| 
 | ||||
|         // Gold is restocked every 24h
 | ||||
|         if (MWBase::Environment::get().getWorld()->getTimeStamp() >= sellerStats.getLastRestockTime() + delay) | ||||
|         { | ||||
|             sellerStats.setGoldPool(mPtr.getClass().getBaseGold(mPtr)); | ||||
| 
 | ||||
|             mPtr.getClass().restock(mPtr); | ||||
| 
 | ||||
|             // Also restock any containers owned by this merchant, which are also available to buy in the trade window
 | ||||
|             std::vector<MWWorld::Ptr> itemSources; | ||||
|             MWBase::Environment::get().getWorld()->getContainersOwnedBy(mPtr, itemSources); | ||||
|             for (std::vector<MWWorld::Ptr>::iterator it = itemSources.begin(); it != itemSources.end(); ++it) | ||||
|             { | ||||
|                 it->getClass().restock(*it); | ||||
|             } | ||||
| 
 | ||||
|             sellerStats.setLastRestockTime(MWBase::Environment::get().getWorld()->getTimeStamp()); | ||||
|         } | ||||
|     } | ||||
|  |  | |||
|  | @ -94,6 +94,20 @@ namespace MWGui | |||
|         setCoord(400, 0, 400, 300); | ||||
|     } | ||||
| 
 | ||||
|     void TradeWindow::restock() | ||||
|     { | ||||
|         // Restock items on the actor inventory
 | ||||
|         mPtr.getClass().restock(mPtr); | ||||
| 
 | ||||
|         // Also restock any containers owned by this merchant, which are also available to buy in the trade window
 | ||||
|         std::vector<MWWorld::Ptr> itemSources; | ||||
|         MWBase::Environment::get().getWorld()->getContainersOwnedBy(mPtr, itemSources); | ||||
|         for (std::vector<MWWorld::Ptr>::iterator it = itemSources.begin(); it != itemSources.end(); ++it) | ||||
|         { | ||||
|             it->getClass().restock(*it); | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     void TradeWindow::startTrade(const MWWorld::Ptr& actor) | ||||
|     { | ||||
|         mPtr = actor; | ||||
|  | @ -101,6 +115,8 @@ namespace MWGui | |||
|         mCurrentBalance = 0; | ||||
|         mCurrentMerchantOffer = 0; | ||||
| 
 | ||||
|         restock(); | ||||
| 
 | ||||
|         std::vector<MWWorld::Ptr> itemSources; | ||||
|         MWBase::Environment::get().getWorld()->getContainersOwnedBy(actor, itemSources); | ||||
| 
 | ||||
|  |  | |||
|  | @ -98,6 +98,8 @@ namespace MWGui | |||
|             virtual void onReferenceUnavailable(); | ||||
| 
 | ||||
|             int getMerchantGold(); | ||||
| 
 | ||||
|             void restock(); | ||||
|     }; | ||||
| } | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
		Reference in a new issue