Add a consumer parameter to ProjectileSource#launchProjectile (#8374)
Co-authored-by: MelnCat <melncatuwu@gmail.com>
This commit is contained in:
		
					parent
					
						
							
								d843d7659e
							
						
					
				
			
			
				commit
				
					
						d2239c40a5
					
				
			
		
					 2 changed files with 104 additions and 0 deletions
				
			
		|  | @ -0,0 +1,35 @@ | |||
| From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 | ||||
| From: MelnCat <melncatuwu@gmail.com> | ||||
| Date: Mon, 19 Sep 2022 14:04:13 -0700 | ||||
| Subject: [PATCH] Add a consumer parameter to ProjectileSource#launchProjectile | ||||
| 
 | ||||
| 
 | ||||
| diff --git a/src/main/java/org/bukkit/projectiles/ProjectileSource.java b/src/main/java/org/bukkit/projectiles/ProjectileSource.java
 | ||||
| index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
 | ||||
| --- a/src/main/java/org/bukkit/projectiles/ProjectileSource.java
 | ||||
| +++ b/src/main/java/org/bukkit/projectiles/ProjectileSource.java
 | ||||
| @@ -0,0 +0,0 @@ public interface ProjectileSource {
 | ||||
|       */ | ||||
|      @NotNull | ||||
|      public <T extends Projectile> T launchProjectile(@NotNull Class<? extends T> projectile, @Nullable Vector velocity); | ||||
| +    
 | ||||
| +    // Paper start
 | ||||
| +    /**
 | ||||
| +     * Launches a {@link Projectile} from the ProjectileSource with an
 | ||||
| +     * initial velocity, with the supplied function run before the
 | ||||
| +     * entity is added to the world.
 | ||||
| +     * <br>
 | ||||
| +     * Note that when the function is run, the entity will not be actually in
 | ||||
| +     * the world. Any operation involving such as teleporting the entity is undefined
 | ||||
| +     * until after this function returns.
 | ||||
| +     *
 | ||||
| +     * @param <T> a projectile subclass
 | ||||
| +     * @param projectile class of the projectile to launch
 | ||||
| +     * @param velocity the velocity with which to launch
 | ||||
| +     * @param function the function to be run before the entity is spawned
 | ||||
| +     * @return the launched projectile
 | ||||
| +     */
 | ||||
| +    @NotNull
 | ||||
| +    public <T extends Projectile> T launchProjectile(@NotNull Class<? extends T> projectile, @Nullable Vector velocity, @Nullable org.bukkit.util.Consumer<T> function);
 | ||||
| +    // Paper end
 | ||||
|  } | ||||
|  | @ -0,0 +1,69 @@ | |||
| From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 | ||||
| From: MelnCat <melncatuwu@gmail.com> | ||||
| Date: Mon, 19 Sep 2022 14:16:10 -0700 | ||||
| Subject: [PATCH] Add a consumer parameter to ProjectileSource#launchProjectile | ||||
| 
 | ||||
| 
 | ||||
| diff --git a/src/main/java/org/bukkit/craftbukkit/entity/CraftLivingEntity.java b/src/main/java/org/bukkit/craftbukkit/entity/CraftLivingEntity.java
 | ||||
| index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
 | ||||
| --- a/src/main/java/org/bukkit/craftbukkit/entity/CraftLivingEntity.java
 | ||||
| +++ b/src/main/java/org/bukkit/craftbukkit/entity/CraftLivingEntity.java
 | ||||
| @@ -0,0 +0,0 @@ public class CraftLivingEntity extends CraftEntity implements LivingEntity {
 | ||||
|      } | ||||
|   | ||||
|      @Override | ||||
| -    @SuppressWarnings("unchecked")
 | ||||
|      public <T extends Projectile> T launchProjectile(Class<? extends T> projectile, Vector velocity) { | ||||
| +        // Paper start - launchProjectile consumer
 | ||||
| +        return this.launchProjectile(projectile, velocity, null);
 | ||||
| +    }
 | ||||
| +
 | ||||
| +    @Override
 | ||||
| +    @SuppressWarnings("unchecked")
 | ||||
| +    public <T extends Projectile> T launchProjectile(Class<? extends T> projectile, Vector velocity, org.bukkit.util.Consumer<T> function) {
 | ||||
| +        // Paper end - launchProjectile consumer
 | ||||
|          Preconditions.checkState(!this.getHandle().generation, "Cannot launch projectile during world generation"); | ||||
|   | ||||
|          net.minecraft.world.level.Level world = ((CraftWorld) getWorld()).getHandle(); | ||||
| @@ -0,0 +0,0 @@ public class CraftLivingEntity extends CraftEntity implements LivingEntity {
 | ||||
|          if (velocity != null) { | ||||
|              ((T) launch.getBukkitEntity()).setVelocity(velocity); | ||||
|          } | ||||
| +        // Paper start - launchProjectile consumer
 | ||||
| +        if (function != null) {
 | ||||
| +            function.accept((T) launch.getBukkitEntity());
 | ||||
| +        }
 | ||||
| +        // Paper end - launchProjectile consumer
 | ||||
|   | ||||
|          world.addFreshEntity(launch); | ||||
|          return (T) launch.getBukkitEntity(); | ||||
| diff --git a/src/main/java/org/bukkit/craftbukkit/projectiles/CraftBlockProjectileSource.java b/src/main/java/org/bukkit/craftbukkit/projectiles/CraftBlockProjectileSource.java
 | ||||
| index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
 | ||||
| --- a/src/main/java/org/bukkit/craftbukkit/projectiles/CraftBlockProjectileSource.java
 | ||||
| +++ b/src/main/java/org/bukkit/craftbukkit/projectiles/CraftBlockProjectileSource.java
 | ||||
| @@ -0,0 +0,0 @@ public class CraftBlockProjectileSource implements BlockProjectileSource {
 | ||||
|   | ||||
|      @Override | ||||
|      public <T extends Projectile> T launchProjectile(Class<? extends T> projectile, Vector velocity) { | ||||
| +        // Paper start - launchProjectile consumer
 | ||||
| +        return this.launchProjectile(projectile, velocity, null);
 | ||||
| +    }
 | ||||
| +
 | ||||
| +    @Override
 | ||||
| +    public <T extends Projectile> T launchProjectile(Class<? extends T> projectile, Vector velocity, org.bukkit.util.Consumer<T> function) {
 | ||||
| +        // Paper end - launchProjectile consumer
 | ||||
|          Validate.isTrue(this.getBlock().getType() == Material.DISPENSER, "Block is no longer dispenser"); | ||||
|          // Copied from BlockDispenser.dispense() | ||||
|          BlockSourceImpl isourceblock = new BlockSourceImpl((ServerLevel) this.dispenserBlock.getLevel(), this.dispenserBlock.getBlockPos()); | ||||
| @@ -0,0 +0,0 @@ public class CraftBlockProjectileSource implements BlockProjectileSource {
 | ||||
|          if (velocity != null) { | ||||
|              ((T) launch.getBukkitEntity()).setVelocity(velocity); | ||||
|          } | ||||
| +        // Paper start
 | ||||
| +        if (function != null) {
 | ||||
| +            function.accept((T) launch.getBukkitEntity());
 | ||||
| +        }
 | ||||
| +        // Paper end
 | ||||
|   | ||||
|          world.addFreshEntity(launch); | ||||
|          return (T) launch.getBukkitEntity(); | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Melncat
				Melncat