|
Принятые патчи Иногда выкладывают патчи, которые потом в итоге все-таки принимают в ядро.
Повод для гордости. |
|
Опции темы | Поиск в этой теме | Опции просмотра |
21.10.2010, 21:39 | #1 |
Пользователь
Регистрация: 09.03.2010
Сообщений: 37
Сказал(а) спасибо: 4
Поблагодарили 63 раз(а) в 21 сообщениях
|
[10641][hack fix] Отображение характеристик heroic предметов.
Суть проблемы: Вещи с меткой "Heroic" не показывают вставленные камни, бонусы от камней, наложенные энчанты,
прочность. Идея: Оригинальный патч от Shauren. Суть в том , что в данный момент флаги от шаблона предмета копируются каждому экземпляру предмета. В итоге в экземпляре храниться сумма флагов предмета и шаблона. До появления ITEM_FLAGS_HEROIC = 0x00000008 проблема себя не проявляла. Предлагаемый патч требует дополнительной проверки, пока проблемы не выявлены. Код:
diff --git a/src/game/Bag.cpp b/src/game/Bag.cpp index c2d3b74..e929796 100644 --- a/src/game/Bag.cpp +++ b/src/game/Bag.cpp @@ -74,7 +74,7 @@ bool Bag::Create(uint32 guidlow, uint32 itemid, Player const* owner) SetUInt32Value(ITEM_FIELD_MAXDURABILITY, itemProto->MaxDurability); SetUInt32Value(ITEM_FIELD_DURABILITY, itemProto->MaxDurability); - SetUInt32Value(ITEM_FIELD_FLAGS, itemProto->Flags); + //SetUInt32Value(ITEM_FIELD_FLAGS, itemProto->Flags); SetUInt32Value(ITEM_FIELD_STACK_COUNT, 1); // Setting the number of Slots the Container has diff --git a/src/game/Item.cpp b/src/game/Item.cpp index 52e58a9..68049ce 100644 --- a/src/game/Item.cpp +++ b/src/game/Item.cpp @@ -266,7 +266,7 @@ bool Item::Create( uint32 guidlow, uint32 itemid, Player const* owner) for(int i = 0; i < MAX_ITEM_PROTO_SPELLS; ++i) SetSpellCharges(i,itemProto->Spells[i].SpellCharges); - SetUInt32Value(ITEM_FIELD_FLAGS, itemProto->Flags); + //SetUInt32Value(ITEM_FIELD_FLAGS, itemProto->Flags); SetUInt32Value(ITEM_FIELD_DURATION, itemProto->Duration); return true; diff --git a/src/game/Item.h b/src/game/Item.h index 33ac541..a64dbbd 100644 --- a/src/game/Item.h +++ b/src/game/Item.h @@ -240,7 +240,7 @@ class MANGOS_DLL_SPEC Item : public Object void SetBinding(bool val) { ApplyModFlag(ITEM_FIELD_FLAGS,ITEM_FLAGS_BINDED,val); } bool IsSoulBound() const { return HasFlag(ITEM_FIELD_FLAGS, ITEM_FLAGS_BINDED); } - bool IsBoundAccountWide() const { return HasFlag(ITEM_FIELD_FLAGS, ITEM_FLAGS_BOA); } + bool IsBoundAccountWide() const { return (GetProto()->Flags & ITEM_FLAGS_BOA); } bool IsBindedNotWith(Player const* player) const; bool IsBoundByEnchant() const; virtual void SaveToDB(); diff --git a/src/game/ItemHandler.cpp b/src/game/ItemHandler.cpp index 08b3386..bdb08ae 100644 --- a/src/game/ItemHandler.cpp +++ b/src/game/ItemHandler.cpp @@ -1111,7 +1111,7 @@ void WorldSession::HandleWrapItemOpcode(WorldPacket& recv_data) return; } - if (!gift->HasFlag(ITEM_FIELD_FLAGS, ITEM_FLAGS_WRAPPER))// cheating: non-wrapper wrapper + if (!(gift->GetProto()->Flags & ITEM_FLAGS_WRAPPER))// cheating: non-wrapper wrapper { _player->SendEquipError( EQUIP_ERR_ITEM_NOT_FOUND, gift, NULL ); return; резервную копию базы characters. PHP код:
Последний раз редактировалось Warlord123; 22.10.2010 в 08:58. |
|
|
Похожие темы | ||||
Тема | Автор | Раздел | Ответов | Последнее сообщение |
[10641] Fixed use item dynamic/item proto flags. | newsbot | CMaNGOS Commits | 0 | 25.10.2010 15:30 |
Фильтр отображения предметов у торговца. | alien | Баг-репорты | 12 | 08.06.2010 20:57 |
[10046][patch] Хранение GUIDов передаваемых предметов при обмене | zergtmn | Принятые патчи | 4 | 08.06.2010 19:50 |
Отображение сгруппированных квестов | timmit | Баг-репорты | 7 | 30.05.2010 12:59 |
[fixed][bug] Дублирование предметов. | Maximus | Баг-репорты | 12 | 23.04.2010 21:52 |