Skip to content

Commit 3e5a2ce

Browse files
committed
Merge remote-tracking branch 'origin/api-12' into HEAD
2 parents 163164f + 0fcd92c commit 3e5a2ce

File tree

3 files changed

+171
-0
lines changed

3 files changed

+171
-0
lines changed
Lines changed: 88 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,88 @@
1+
/*
2+
* This file is part of SpongeAPI, licensed under the MIT License (MIT).
3+
*
4+
* Copyright (c) SpongePowered <https://www.spongepowered.org>
5+
* Copyright (c) contributors
6+
*
7+
* Permission is hereby granted, free of charge, to any person obtaining a copy
8+
* of this software and associated documentation files (the "Software"), to deal
9+
* in the Software without restriction, including without limitation the rights
10+
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
11+
* copies of the Software, and to permit persons to whom the Software is
12+
* furnished to do so, subject to the following conditions:
13+
*
14+
* The above copyright notice and this permission notice shall be included in
15+
* all copies or substantial portions of the Software.
16+
*
17+
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
18+
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
19+
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
20+
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
21+
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
22+
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
23+
* THE SOFTWARE.
24+
*/
25+
package org.spongepowered.api.block.transaction;
26+
27+
import org.spongepowered.api.scheduler.ScheduledUpdate;
28+
import org.spongepowered.api.scheduler.TaskPriority;
29+
import org.spongepowered.api.world.LocatableBlock;
30+
31+
import java.time.Duration;
32+
33+
/**
34+
* Represents a {@link ScheduledUpdate scheduled block update} that
35+
* is being proposed to the engine.
36+
*/
37+
public interface ScheduleUpdateTicket<T> {
38+
39+
/**
40+
* Gets the target block of this scheduled update.
41+
*
42+
* @return The target block
43+
*/
44+
LocatableBlock block();
45+
46+
/**
47+
* Gets the target of this scheduled update.
48+
*
49+
* @return The target
50+
*/
51+
T target();
52+
53+
/**
54+
* Gets the {@link Duration delay} until this update
55+
* should cause the block to update.
56+
*
57+
* @return The delay until this SBU should cause the block to update
58+
*/
59+
Duration delay();
60+
61+
/**
62+
* Gets the priority of this scheduled block update.
63+
*
64+
* @return The priority of this scheduled block update
65+
*/
66+
TaskPriority priority();
67+
68+
/**
69+
* Gets whether this ticket is marked as valid.
70+
*
71+
* @return The valid state of this ticket
72+
*/
73+
boolean valid();
74+
75+
/**
76+
* Sets whether this ticket is valid or not.
77+
*
78+
* @param valid The valid state of this ticket
79+
*/
80+
void setValid(boolean valid);
81+
82+
/**
83+
* Invalidates this ticket.
84+
*/
85+
default void invalidate() {
86+
this.setValid(false);
87+
}
88+
}
Lines changed: 82 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,82 @@
1+
/*
2+
* This file is part of SpongeAPI, licensed under the MIT License (MIT).
3+
*
4+
* Copyright (c) SpongePowered <https://www.spongepowered.org>
5+
* Copyright (c) contributors
6+
*
7+
* Permission is hereby granted, free of charge, to any person obtaining a copy
8+
* of this software and associated documentation files (the "Software"), to deal
9+
* in the Software without restriction, including without limitation the rights
10+
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
11+
* copies of the Software, and to permit persons to whom the Software is
12+
* furnished to do so, subject to the following conditions:
13+
*
14+
* The above copyright notice and this permission notice shall be included in
15+
* all copies or substantial portions of the Software.
16+
*
17+
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
18+
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
19+
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
20+
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
21+
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
22+
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
23+
* THE SOFTWARE.
24+
*/
25+
package org.spongepowered.api.event.block;
26+
27+
import org.spongepowered.api.block.transaction.ScheduleUpdateTicket;
28+
import org.spongepowered.api.event.Cancellable;
29+
import org.spongepowered.api.event.GenericEvent;
30+
import org.spongepowered.api.scheduler.ScheduledUpdate;
31+
import org.spongepowered.api.world.server.ServerLocation;
32+
33+
import java.util.List;
34+
import java.util.function.Predicate;
35+
36+
/**
37+
* Fired when a {@link ScheduledUpdate scheduled block update}
38+
* is being proposed to the engine.
39+
*/
40+
public interface ScheduleBlockUpdateEvent<T extends Object> extends GenericEvent<T>, Cancellable {
41+
42+
/**
43+
* Gets a list of the {@link ScheduleUpdateTicket}s for this event.
44+
* If a ticket is requested to be marked as "invalid",
45+
* {@link ScheduleUpdateTicket#setValid(boolean)} can be used.
46+
*
47+
* @return The unmodifiable list of tickets
48+
*/
49+
List<ScheduleUpdateTicket<T>> tickets();
50+
51+
/**
52+
* Applies the provided {@link Predicate} to the {@link List} of
53+
* {@link ScheduleUpdateTicket}s from {@link #tickets()} such that
54+
* any time that {@link Predicate#test(Object)} returns {@code false}
55+
* on the location of the {@link ScheduleUpdateTicket}, the
56+
* {@link ScheduleUpdateTicket} is marked as "invalid".
57+
*
58+
* <p>{@link ScheduleUpdateTicket#block()} is used to get the {@link ServerLocation}</p>
59+
*
60+
* @param predicate The predicate to use for filtering
61+
*/
62+
default void filterTargetPositions(final Predicate<ServerLocation> predicate) {
63+
this.filterTickets(t -> predicate.test(t.block().serverLocation()));
64+
}
65+
66+
/**
67+
* Applies the provided {@link Predicate} to the {@link List} of
68+
* {@link ScheduleUpdateTicket}s from {@link #tickets()} such that
69+
* any time that {@link Predicate#test(Object)} returns {@code false}
70+
* on the location of the {@link ScheduleUpdateTicket}, the
71+
* {@link ScheduleUpdateTicket} is marked as "invalid".
72+
*
73+
* @param predicate The predicate to use for filtering
74+
*/
75+
default void filterTickets(final Predicate<ScheduleUpdateTicket<T>> predicate) {
76+
this.tickets().forEach(ticket -> {
77+
if (!predicate.test(ticket)) {
78+
ticket.setValid(false);
79+
}
80+
});
81+
}
82+
}

src/main/java/org/spongepowered/api/item/recipe/smithing/ArmorTrim.java

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -37,6 +37,7 @@ static ArmorTrim of(TrimMaterial material, TrimPattern pattern) {
3737
static ArmorTrim of(Supplier<? extends TrimMaterial> material, Supplier<? extends TrimPattern> pattern) {
3838
return Sponge.game().factoryProvider().provide(Factory.class).create(material, pattern);
3939
}
40+
4041
static ArmorTrim of(TrimMaterial material, Supplier<? extends TrimPattern> pattern) {
4142
return Sponge.game().factoryProvider().provide(Factory.class).create(material, pattern);
4243
}

0 commit comments

Comments
 (0)