X-Git-Url: https://de.git.xonotic.org/?a=blobdiff_plain;f=qcsrc%2Fserver%2Fitems.qc;h=b21df78e3f247cb53b809446f95a555c25c86bcb;hb=9215008d87f1170da32befded6baeb55f3a2cf13;hp=0bbf499b5883b7798ddf1bac303caae7cc2a4d64;hpb=7aaff08fbaad9424651ec31c82f8a5d78e5ec1e1;p=xonotic%2Fxonotic-data.pk3dir.git diff --git a/qcsrc/server/items.qc b/qcsrc/server/items.qc index 0bbf499b5..b21df78e3 100644 --- a/qcsrc/server/items.qc +++ b/qcsrc/server/items.qc @@ -5,20 +5,50 @@ /// game items. /// \copyright GNU GPLv2 or any later version. -#include "g_subs.qh" +#include #include +#include .bool m_isloot; ///< Holds whether item is loot. /// \brief Holds whether strength, shield or superweapon timers expire while /// this item is on the ground. .bool m_isexpiring; -entity Item_Create(string class_name, vector position) +entity Item_FindDefinition(string class_name) +{ + FOREACH(Items, it.m_canonical_spawnfunc == class_name, + { + return it; + }); + FOREACH(Weapons, it.m_canonical_spawnfunc == class_name, + { + return it.m_pickup; + }); + return NULL; +} + +bool Item_IsAllowed(string class_name) +{ + entity definition = Item_FindDefinition(class_name); + if (definition == NULL) + { + return false; + } + return Item_IsDefinitionAllowed(definition); +} + +bool Item_IsDefinitionAllowed(entity definition) +{ + return !MUTATOR_CALLHOOK(FilterItemDefinition, definition); +} + +entity Item_Create(string class_name, vector position, bool no_align) { entity item = spawn(); item.classname = class_name; item.spawnfunc_checked = true; setorigin(item, position); + item.noalign = no_align; Item_Initialize(item, class_name); if (wasfreed(item)) { @@ -83,6 +113,11 @@ void Item_SetLoot(entity item, bool loot) item.m_isloot = loot; } +bool Item_ShouldKeepPosition(entity item) +{ + return item.noalign || (item.spawnflags & 1); +} + bool Item_IsExpiring(entity item) { return item.m_isexpiring;