diff --git a/common/src/main/java/kr/tkrmagid/chatanswer/core/ChatAnswerCore.java b/common/src/main/java/kr/tkrmagid/chatanswer/core/ChatAnswerCore.java index 611be67..c314c37 100644 --- a/common/src/main/java/kr/tkrmagid/chatanswer/core/ChatAnswerCore.java +++ b/common/src/main/java/kr/tkrmagid/chatanswer/core/ChatAnswerCore.java @@ -32,28 +32,33 @@ public final class ChatAnswerCore { private ChatAnswerCore() {} /** - * 플레이어 로그인 직후 호출. 데이터팩이 "모드 살아있음" 신호로 쓸 수 있게 - * storage chat_answer:status 에 active=1b 를 세팅한다. 데이터팩의 mq:load 가 - * 매 /reload 와 서버 시작 시 이 값을 0b 로 clear 하므로, 모드가 없으면 이 - * 호출이 일어나지 않아 0b 로 유지되고, 모드가 있으면 첫 로그인 직후 1b 로 갱신. + * 플레이어 로그인 직후 호출. 음악퀴즈 데이터팩의 + * mq:players/mod_active_notice + * 함수를 해당 플레이어 컨텍스트로 직접 호출한다. 데이터팩이 메세지를 정의하고, + * 모드는 "지금 막 들어온 이 플레이어에게 보여라" 만 트리거한다. + * + * 이전엔 storage chat_answer:status active=1b 플래그를 썼는데, 통합 서버에서 + * mq:load 의 0b 초기화가 player join 이후에 도는 케이스 때문에 race 가 발생했다. + * 함수를 모드가 직접 호출하면 race 가 사라지고, 데이터팩이 없을 땐 함수가 + * 존재하지 않아 커맨드가 (suppressed source 라 채팅엔 안 뜨고 log warn 으로) + * 무시된다. */ public static void onPlayerJoin(ServerPlayer player) { String name = player.getName().getString(); LOG.info("[{}] onPlayerJoin fired for {}", MOD_ID, name); MinecraftServer server = player.level().getServer(); if (server == null) { - LOG.warn("[{}] onPlayerJoin: server is null, skipping active-flag set for {}", MOD_ID, name); + LOG.warn("[{}] onPlayerJoin: server is null, skipping notice for {}", MOD_ID, name); return; } CommandSourceStack source = server.createCommandSourceStack().withSuppressedOutput(); + String command = "execute as " + player.getStringUUID() + + " at @s run function mq:players/mod_active_notice"; try { - server.getCommands().performPrefixedCommand( - source, - "data modify storage chat_answer:status active set value 1b" - ); - LOG.info("[{}] active=1b set after {} joined", MOD_ID, name); + server.getCommands().performPrefixedCommand(source, command); + LOG.info("[{}] mod_active_notice invoked for {}", MOD_ID, name); } catch (Exception e) { - LOG.warn("[{}] failed to set active flag for {}: {}", MOD_ID, name, e.toString(), e); + LOG.warn("[{}] failed to invoke mod_active_notice for {}: {}", MOD_ID, name, e.toString(), e); } } diff --git a/gradle.properties b/gradle.properties index e92d083..985d773 100644 --- a/gradle.properties +++ b/gradle.properties @@ -3,7 +3,7 @@ org.gradle.parallel=true # ───── mod metadata ───────────────────────────────────────────────────────── mod_id=chat_answer -mod_version=1.3.2 +mod_version=1.3.3 mod_group=kr.tkrmagid.chatanswer mod_name=채팅정답