mirror of
				https://github.com/OpenMW/openmw.git
				synced 2025-10-26 18:26:41 +00:00 
			
		
		
		
	Remove duplicate code for PlaceAtMe/PlaceAtPC using a template
This commit is contained in:
		
							parent
							
								
									8ff747fbef
								
							
						
					
					
						commit
						f4f2586e8c
					
				
					 1 changed files with 12 additions and 57 deletions
				
			
		|  | @ -450,62 +450,16 @@ namespace MWScript | ||||||
|                 } |                 } | ||||||
|         }; |         }; | ||||||
| 
 | 
 | ||||||
|         template<class R> |         template<class R, bool pc> | ||||||
|         class OpPlaceAtPc : public Interpreter::Opcode0 |         class OpPlaceAt : public Interpreter::Opcode0 | ||||||
|         { |         { | ||||||
|             public: |             public: | ||||||
| 
 | 
 | ||||||
|                 virtual void execute (Interpreter::Runtime& runtime) |                 virtual void execute (Interpreter::Runtime& runtime) | ||||||
|                 { |                 { | ||||||
|                     std::string itemID = runtime.getStringLiteral (runtime[0].mInteger); |                     MWWorld::Ptr actor = pc | ||||||
|                     runtime.pop(); |                         ? MWBase::Environment::get().getWorld()->getPlayer().getPlayer() | ||||||
| 
 |                         : R()(runtime); | ||||||
|                     Interpreter::Type_Integer count = runtime[0].mInteger; |  | ||||||
|                     runtime.pop(); |  | ||||||
|                     Interpreter::Type_Float distance = runtime[0].mFloat; |  | ||||||
|                     runtime.pop(); |  | ||||||
|                     Interpreter::Type_Integer direction = runtime[0].mInteger; |  | ||||||
|                     runtime.pop(); |  | ||||||
| 
 |  | ||||||
|                     if (count<0) |  | ||||||
|                         throw std::runtime_error ("count must be non-negative"); |  | ||||||
| 
 |  | ||||||
|                     // no-op
 |  | ||||||
|                     if (count == 0) |  | ||||||
|                         return; |  | ||||||
| 
 |  | ||||||
|                     ESM::Position ipos = MWBase::Environment::get().getWorld()->getPlayer().getPlayer().getRefData().getPosition(); |  | ||||||
|                     Ogre::Vector3 pos(ipos.pos[0],ipos.pos[1],ipos.pos[2]); |  | ||||||
|                     Ogre::Quaternion rot(Ogre::Radian(-ipos.rot[2]), Ogre::Vector3::UNIT_Z); |  | ||||||
|                     if(direction == 0) pos = pos + distance*rot.yAxis(); |  | ||||||
|                     else if(direction == 1) pos = pos - distance*rot.yAxis(); |  | ||||||
|                     else if(direction == 2) pos = pos - distance*rot.xAxis(); |  | ||||||
|                     else if(direction == 3) pos = pos + distance*rot.xAxis(); |  | ||||||
|                     else throw std::runtime_error ("direction must be 0,1,2 or 3"); |  | ||||||
| 
 |  | ||||||
|                     ipos.pos[0] = pos.x; |  | ||||||
|                     ipos.pos[1] = pos.y; |  | ||||||
|                     ipos.pos[2] = pos.z; |  | ||||||
|                     ipos.rot[0] = 0; |  | ||||||
|                     ipos.rot[1] = 0; |  | ||||||
|                     ipos.rot[2] = 0; |  | ||||||
| 
 |  | ||||||
|                     MWWorld::CellStore* store = MWBase::Environment::get().getWorld()->getPlayer().getPlayer().getCell();                     |  | ||||||
|                     MWWorld::ManualRef ref(MWBase::Environment::get().getWorld()->getStore(),itemID); |  | ||||||
|                     ref.getPtr().getCellRef().mPos = ipos; |  | ||||||
|                     ref.getPtr().getRefData().setCount(count); |  | ||||||
|                     MWBase::Environment::get().getWorld()->safePlaceObject(ref.getPtr(),*store,ipos); |  | ||||||
|                 } |  | ||||||
|         }; |  | ||||||
| 
 |  | ||||||
|         template<class R> |  | ||||||
|         class OpPlaceAtMe : public Interpreter::Opcode0 |  | ||||||
|         { |  | ||||||
|             public: |  | ||||||
| 
 |  | ||||||
|                 virtual void execute (Interpreter::Runtime& runtime) |  | ||||||
|                 { |  | ||||||
|                     MWWorld::Ptr me = R()(runtime); |  | ||||||
| 
 | 
 | ||||||
|                     std::string itemID = runtime.getStringLiteral (runtime[0].mInteger); |                     std::string itemID = runtime.getStringLiteral (runtime[0].mInteger); | ||||||
|                     runtime.pop(); |                     runtime.pop(); | ||||||
|  | @ -524,7 +478,7 @@ namespace MWScript | ||||||
|                     if (count == 0) |                     if (count == 0) | ||||||
|                         return; |                         return; | ||||||
| 
 | 
 | ||||||
|                     ESM::Position ipos = me.getRefData().getPosition(); |                     ESM::Position ipos = actor.getRefData().getPosition(); | ||||||
|                     Ogre::Vector3 pos(ipos.pos[0],ipos.pos[1],ipos.pos[2]); |                     Ogre::Vector3 pos(ipos.pos[0],ipos.pos[1],ipos.pos[2]); | ||||||
|                     Ogre::Quaternion rot(Ogre::Radian(-ipos.rot[2]), Ogre::Vector3::UNIT_Z); |                     Ogre::Quaternion rot(Ogre::Radian(-ipos.rot[2]), Ogre::Vector3::UNIT_Z); | ||||||
|                     if(direction == 0) pos = pos + distance*rot.yAxis(); |                     if(direction == 0) pos = pos + distance*rot.yAxis(); | ||||||
|  | @ -540,12 +494,13 @@ namespace MWScript | ||||||
|                     ipos.rot[1] = 0; |                     ipos.rot[1] = 0; | ||||||
|                     ipos.rot[2] = 0; |                     ipos.rot[2] = 0; | ||||||
| 
 | 
 | ||||||
|                     MWWorld::CellStore* store = me.getCell();                     |                     // create item
 | ||||||
|  |                     MWWorld::CellStore* store = actor.getCell(); | ||||||
|                     MWWorld::ManualRef ref(MWBase::Environment::get().getWorld()->getStore(),itemID); |                     MWWorld::ManualRef ref(MWBase::Environment::get().getWorld()->getStore(),itemID); | ||||||
|                     ref.getPtr().getCellRef().mPos = ipos; |                     ref.getPtr().getCellRef().mPos = ipos; | ||||||
|                     ref.getPtr().getRefData().setCount(count); |                     ref.getPtr().getRefData().setCount(count); | ||||||
|                     MWBase::Environment::get().getWorld()->safePlaceObject(ref.getPtr(),*store,ipos); |  | ||||||
| 
 | 
 | ||||||
|  |                     MWBase::Environment::get().getWorld()->safePlaceObject(ref.getPtr(),*store,ipos); | ||||||
|                 } |                 } | ||||||
|         }; |         }; | ||||||
| 
 | 
 | ||||||
|  | @ -730,9 +685,9 @@ namespace MWScript | ||||||
|             interpreter.installSegment5(Compiler::Transformation::opcodePositionCellExplicit,new OpPositionCell<ExplicitRef>); |             interpreter.installSegment5(Compiler::Transformation::opcodePositionCellExplicit,new OpPositionCell<ExplicitRef>); | ||||||
|             interpreter.installSegment5(Compiler::Transformation::opcodePlaceItemCell,new OpPlaceItemCell<ImplicitRef>);             |             interpreter.installSegment5(Compiler::Transformation::opcodePlaceItemCell,new OpPlaceItemCell<ImplicitRef>);             | ||||||
|             interpreter.installSegment5(Compiler::Transformation::opcodePlaceItem,new OpPlaceItem<ImplicitRef>);             |             interpreter.installSegment5(Compiler::Transformation::opcodePlaceItem,new OpPlaceItem<ImplicitRef>);             | ||||||
|             interpreter.installSegment5(Compiler::Transformation::opcodePlaceAtPc,new OpPlaceAtPc<ImplicitRef>);    |             interpreter.installSegment5(Compiler::Transformation::opcodePlaceAtPc,new OpPlaceAt<ImplicitRef, true>); | ||||||
|             interpreter.installSegment5(Compiler::Transformation::opcodePlaceAtMe,new OpPlaceAtMe<ImplicitRef>);    |             interpreter.installSegment5(Compiler::Transformation::opcodePlaceAtMe,new OpPlaceAt<ImplicitRef, false>); | ||||||
|             interpreter.installSegment5(Compiler::Transformation::opcodePlaceAtMeExplicit,new OpPlaceAtMe<ExplicitRef>); |             interpreter.installSegment5(Compiler::Transformation::opcodePlaceAtMeExplicit,new OpPlaceAt<ExplicitRef, false>); | ||||||
|             interpreter.installSegment5(Compiler::Transformation::opcodeModScale,new OpModScale<ImplicitRef>); |             interpreter.installSegment5(Compiler::Transformation::opcodeModScale,new OpModScale<ImplicitRef>); | ||||||
|             interpreter.installSegment5(Compiler::Transformation::opcodeModScaleExplicit,new OpModScale<ExplicitRef>); |             interpreter.installSegment5(Compiler::Transformation::opcodeModScaleExplicit,new OpModScale<ExplicitRef>); | ||||||
|             interpreter.installSegment5(Compiler::Transformation::opcodeRotate,new OpRotate<ImplicitRef>); |             interpreter.installSegment5(Compiler::Transformation::opcodeRotate,new OpRotate<ImplicitRef>); | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue