From 575fda29ea55fd6c2b5d9921a44f3e74c57dd1af Mon Sep 17 00:00:00 2001 From: isxander Date: Wed, 22 Nov 2023 17:14:40 +0000 Subject: Forget the pending value of options when they become unavailable. --- common/src/main/java/dev/isxander/yacl3/impl/OptionImpl.java | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) (limited to 'common/src/main/java/dev/isxander/yacl3/impl') diff --git a/common/src/main/java/dev/isxander/yacl3/impl/OptionImpl.java b/common/src/main/java/dev/isxander/yacl3/impl/OptionImpl.java index e539f73..afe9517 100644 --- a/common/src/main/java/dev/isxander/yacl3/impl/OptionImpl.java +++ b/common/src/main/java/dev/isxander/yacl3/impl/OptionImpl.java @@ -89,8 +89,12 @@ public final class OptionImpl implements Option { this.available = available; - if (changed) - this.triggerListeners(false); + if (changed) { + if (!available) { + this.pendingValue = binding().getValue(); + } + this.triggerListeners(!available); + } } @Override -- cgit