| Commit message (Collapse) | Author | Age | Lines |
... | |
| |
|
|
|
|
| |
This was a miss when updating to 1.4.2
|
|
|
|
|
|
|
|
|
|
|
|
| |
The static assertions are not normally evaluated in the JVM, and failed
to fail when the enums went from size 25 to size 26. This meant missing
values would not be detected at runtime and instead return null,
compounding problems later. The switches should never evaluate to null
so will instead throw runtime assertion errors.
Additional unit tests were added to detect new paintings and assure they
have proper, unique mappings. The test checks both that a mapping
exists, is not null, and does not duplicate another mapping.
|
|
|
|
|
|
|
| |
If a defensive copy is not used in the API, changes to the item are
reflected in memory, but never updated to the client. It also goes
against the general contract provided in Bukkit, where setItem should be
the only way to change the underlying item frame.
|
| |
|
| |
|
|
|
|
| |
BUKKIT-2764
|
| |
|
| |
|
|
|
|
| |
bukkit.yml. Adds BUKKIT-2765
|
|
|
|
| |
Also allow commands that don't start with a / to match vanilla behavior
|
| |
|
|
|
|
|
| |
This will need to have its own CommandSender but this makes command blocks
work for now with any command console can run.
|
| |
|
| |
|
| |
|
| |
|
|
|
|
| |
dimensions whilst doing so.
|
|
|
|
|
| |
Relates to:
BUKKIT-2695 BUKKIT-2675
|
|
|
|
| |
return. Adds BUKKIT-2745
|
| |
|
|
|
|
| |
new behaviour with Minecraft 1.4. Adds BUKKIT-2739
|
| |
|
|
|
|
|
|
|
|
|
| |
Skull blocks store their type in a tile entity and use their block data
as rotation. When breaking a block the block data is used for determining
what item to drop. Simply changing this to use the skull method for getting
their drop data is not enough because their tile entity is already gone.
Therefore we have to special case skulls to get the correct data _and_ get
that data before breaking the block.
|
|
|
|
| |
BUKKIT-2708
|
|
|
|
|
| |
Instead of having a special case for skulls just use the normal logic for
breaking a block. This avoids issues when interacting with API.
|
|
|
|
| |
BUKKIT-2707
|
| |
|
|
|
|
|
|
|
| |
On player death player PotionEffects need to be updated so that a player's
invisibility and other effects are removed, otherwise they will persist
after a respawn. This is a carry-over from our use of persistent player
entities.
|
|
|
|
|
|
|
| |
Some features added in 1.4.2 use the difficulty value as an index to an
array so while before having it set to an invalid value would do nothing
or maybe cause an odd side effect somewhere it now crashes the server. This
patch ensures difficulty values are clamped between 0 and 3, inclusive.
|
|
|
|
|
|
|
| |
Filtering item data is usually a good idea to make sure we don't have
invalid data or data on items that shouldn't have it. However, anvils
use item data in slightly different way and so running its code for
filtering here causes the data to be corrupted.
|
| |
|
| |
|
| |
|
|
|
|
|
|
| |
A couple method names were changed between 1.3.2 and 1.4.2 but were missed
in the update. One of these affects being able to enchant bows and the
other is used for updating player animations while firing.
|
| |
|
|
|
|
| |
server.properties. Fixes BUKKIT-2657
|
| |
|
|
|
|
|
|
|
|
| |
Vanilla has its own handlers for plugin channel messages for things like
texture packs, books, and anvils. When vanilla handles one of these messages
we should not also pass it to plugins because they will be duplicating work
and potentially running in to situations our plugin system isn't setup to
handle. This is how 1.3.2 worked but was lost in the 1.4.2 update.
|
| |
|
| |
|
| |
|
| |
|
| |
|
|
|
|
|
| |
The chat tab completion implementation also includes a sanity check to
assure type-safety in the list.
|
|
|
|
|
|
| |
CommandMap now contains the functionality for tab completion. This
commit replaces the vanilla implementation and simply delegates it to
the Bukkit API.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| |
This change affects the old chat compatibility layer from an
implementation only standpoint. It does not queue the 'event' to fire,
but rather queues a runnable that allows the calling thread to wait for
execution to finish.
The other effect of this change is that rcon connects now have their
commands queued to be run on next server tick using the same
implementation.
The internal implementation is in org.bukkit.craftbukkit.util.Waitable.
It is very similar to a Future<T> task, but only contains minimal
implementation with object.wait() and object.notify() calls
under the hood of waitable.get() and waitable.run().
PlayerPreLoginEvent now properly implements thread-safe event execution
by queuing the events similar to chat and rcon. This is still a poor way
albeit proper way to implement thread-safety; PlayerPreLoginEvent will
stay deprecated.
|
|
|
|
|
|
| |
The implementation for the new methods mimics the old methods. The final
call for the old methods now maps to the new methods with an additional
call to get id.
|
|
|
|
|
|
|
|
|
| |
If two players (or a player and any other entity) are teleported to the
same location in the same tick they will both get added to the other's
destroy queue then have a new entity spawn packet sent. Next tick the
destroy queue will be processed and they will then be invisible to each
other. To prevent this situation we remove the entity from the destroy
queue when sending out a spawn packet for them.
|
| |
|