aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/server/game/Conditions/ConditionMgr.cpp16
-rw-r--r--src/server/game/Conditions/ConditionMgr.h3
2 files changed, 15 insertions, 4 deletions
diff --git a/src/server/game/Conditions/ConditionMgr.cpp b/src/server/game/Conditions/ConditionMgr.cpp
index 6317fae2767..9f69e2b0acb 100644
--- a/src/server/game/Conditions/ConditionMgr.cpp
+++ b/src/server/game/Conditions/ConditionMgr.cpp
@@ -104,7 +104,8 @@ ConditionMgr::ConditionTypeInfo const ConditionMgr::StaticConditionTypeData[COND
{ "In Water", false, false, false },
{ "Terrain Swap", false, false, false },
{ "Sit/stand state", true, true, false },
- { "Daily Quest Completed",true, false, false }
+ { "Daily Quest Completed",true, false, false },
+ { "Charmed", false, false, false }
};
// Checks if object meets the condition
@@ -455,6 +456,12 @@ bool Condition::Meets(ConditionSourceInfo& sourceInfo) const
condMeets = player->IsDailyQuestDone(ConditionValue1);
break;
}
+ case CONDITION_CHARMED:
+ {
+ if (Unit* unit = object->ToUnit())
+ condMeets = unit->IsCharmed();
+ break;
+ }
default:
condMeets = false;
break;
@@ -631,6 +638,9 @@ uint32 Condition::GetSearcherTypeMaskForCondition() const
case CONDITION_DAILY_QUEST_DONE:
mask |= GRID_MAP_TYPE_MASK_PLAYER;
break;
+ case CONDITION_CHARMED:
+ mask |= GRID_MAP_TYPE_MASK_CREATURE | GRID_MAP_TYPE_MASK_PLAYER;
+ break;
default:
ASSERT(false && "Condition::GetSearcherTypeMaskForCondition - missing condition handling!");
break;
@@ -2129,8 +2139,6 @@ bool ConditionMgr::isConditionTypeValid(Condition* cond) const
}
break;
}
- case CONDITION_IN_WATER:
- break;
case CONDITION_TERRAIN_SWAP:
TC_LOG_ERROR("sql.sql", "%s is not valid for this branch, skipped.", cond->ToString(true).c_str());
return false;
@@ -2156,6 +2164,8 @@ bool ConditionMgr::isConditionTypeValid(Condition* cond) const
}
break;
}
+ case CONDITION_IN_WATER:
+ case CONDITION_CHARMED:
default:
break;
}
diff --git a/src/server/game/Conditions/ConditionMgr.h b/src/server/game/Conditions/ConditionMgr.h
index 4ec2be0753a..fc37946603b 100644
--- a/src/server/game/Conditions/ConditionMgr.h
+++ b/src/server/game/Conditions/ConditionMgr.h
@@ -74,7 +74,8 @@ enum ConditionTypes
CONDITION_TERRAIN_SWAP = 41, // only for 6.x
CONDITION_STAND_STATE = 42, // stateType state 0 true if unit matches specified sitstate (0,x: has exactly state x; 1,0: any standing state; 1,1: any sitting state;)
CONDITION_DAILY_QUEST_DONE = 43, // quest id 0 0 true if daily quest has been completed for the day
- CONDITION_MAX = 44 // MAX
+ CONDITION_CHARMED = 44, // 0 0 0 true if unit is currently charmed
+ CONDITION_MAX = 45 // MAX
};
/*! Documentation on implementing a new ConditionSourceType: