Advancement 達成でスコアを付与する。

8Fields
1Constructors
6Methods
196Lines
Package
com.example.rankingplugin
Source
AdvancementListener.java
Kind
class
Roles
イベント駆動非同期 / スケジューラ初期化 / ブートストラップ
このクラスにも章立て解説を追加しています。 自動抽出の一覧だけでなく、下の『重点クラスの詳細解説』で読む順番・内部サブシステム・変更時の注意点まで追えます。 全クラス章立てガイドを見る

クラス説明

Advancement 達成でスコアを付与する。

重要:
- Bukkit API(AdvancementProgress / getBiome / getBlockAt など)はメインスレッドのみ。
- DB / ScoreService の処理は非同期に逃がす。

責務と見どころ

重点クラスの詳細解説

Advancement 達成でスコアを付与する。(root) パッケージの 小〜中規模クラスで、運用中の主ループ・スケジューラを確認する起点です。全面展開版では、他の重点クラスと同じ章立てで読めるように補強しています。

最初に追う読む順番

  1. AdvancementListener
    依存オブジェクトと初期状態を束ね、このクラスが担当するランタイムの前提を固めます。
  2. processDoneKeys
    運用中の中心ループです。イベント受理から状態更新までの主経路を追えます。
  3. onPlayerJoin
    運用中の中心ループです。イベント受理から状態更新までの主経路を追えます。
  4. onAdvancement
    運用中の中心ループです。イベント受理から状態更新までの主経路を追えます。
  5. catchUpAdvancements
    既に達成済みの進捗を「月ごとに重複しない」形でキャッチアップ付与する。
  6. calcDelta
    calcDelta の主要処理を担当します。

内部サブシステムの地図

運用中の主ループ

イベント受理、定期監視、判定、進行更新など、実際に挙動を生む中心ロジックです。

主なフィールド
なし

非同期処理と定期実行

メインスレッド境界とバックグラウンド処理が交差します。重い処理やタイミング起因の不具合を追うときの要所です。

主なメソッド
主なフィールド
なし

イベント受理と主処理

Bukkit イベントや内部イベントを受けたあと、どの状態を更新するかをまとめています。

主なフィールド
なし

代表フロー詳解

初期化と起動の流れ

  1. AdvancementListener

このクラスが前提状態を揃え、外部から利用可能な形まで立ち上がる流れです。新規依存の追加や起動失敗の調査はまずここから追います。

通常運用の中心フロー

  1. onPlayerJoin
  2. processDoneKeys
  3. onAdvancement

イベント受理、判定、状態更新、通知までの主経路です。体感不具合や想定外の分岐はこの流れのどこで止まるかを見ると切り分けやすいです。

変更時の注意点

フィールド

VisibilityTypeName役割
privateJavaPluginpluginプラグイン本体参照です。
privateScoreManagermanager関連マネージャーへの参照です。
privateScoreServiceservice関連サービスへの参照です。
privateAdvancementTrackertrackertracker の状態を保持します。
privateRewardServicerewardService関連サービスへの参照です。
privateSet<NamespacedKey>EASYEASY の状態を保持します。
privateSet<NamespacedKey>NORMALNORMAL の状態を保持します。
privateSet<NamespacedKey>HARDHARD の状態を保持します。

コンストラクタ / 初期化

Signature説明主要呼び出し
public AdvancementListener(JavaPlugin plugin, ScoreManager manager, ScoreService service, AdvancementTracker tracker, RewardService rewardService)依存オブジェクトや初期状態を受け取り、このクラスの動作を開始できる状態へ組み立てます。主要呼び出しなし

メソッド索引

NameVisibilityKind説明
AdvancementListenerpublicコンストラクタ依存オブジェクトや初期状態を受け取り、このクラスの動作を開始できる状態へ組み立てます。
onPlayerJoinpublicイベント処理イベント発生時の分岐と後続処理を担当します。
catchUpAdvancementspublicメソッド既に達成済みの進捗を「月ごとに重複しない」形でキャッチアップ付与する。
processDoneKeysprivateメソッドprocessDoneKeys の主要処理を担当します。
onAdvancementpublicイベント処理イベント発生時の分岐と後続処理を担当します。
calcDeltaprivateメソッドcalcDelta の主要処理を担当します。

メソッド詳細

AdvancementListener

コンストラクタpublic
public AdvancementListener(JavaPlugin plugin, ScoreManager manager, ScoreService service, AdvancementTracker tracker, RewardService rewardService)

依存オブジェクトや初期状態を受け取り、このクラスの動作を開始できる状態へ組み立てます。

引数

throws

なし

主要な呼び出し順

目立つ内部呼び出しは抽出されませんでした。

onPlayerJoin

イベント処理public
public void onPlayerJoin(PlayerJoinEvent e)

イベント発生時の分岐と後続処理を担当します。

引数

throws

なし

主要な呼び出し順

getPlayerblockedgetSchedulerrunTaskLaterisOnlinecatchUpAdvancementsgetLoggerwarning

catchUpAdvancements

メソッドpublic
public void catchUpAdvancements(Player p)

既に達成済みの進捗を「月ごとに重複しない」形でキャッチアップ付与する。

引数

throws

なし

主要な呼び出し順

isOnlineisPrimaryThreadgetSchedulerrunTaskblockedisLikelyMcidgetName

processDoneKeys

メソッドprivate
private void processDoneKeys(UUID uuid, String name, YearMonth month, Set<NamespacedKey> doneKeys)

processDoneKeys の主要処理を担当します。

引数

throws

なし

主要な呼び出し順

getScoretoStringhasrecordcalcDeltaaddScorecheckAndGrantgetLogger

onAdvancement

イベント処理public
public void onAdvancement(PlayerAdvancementDoneEvent e)

イベント発生時の分岐と後続処理を担当します。

引数

throws

なし

主要な呼び出し順

getPlayerblockedisLikelyMcidgetNamegetUniqueIdgetAdvancementgetKeytoString

calcDelta

メソッドprivatestatic
private static long calcDelta(NamespacedKey key)

calcDelta の主要処理を担当します。

引数

throws

なし

主要な呼び出し順

contains

代表的な処理フロー

  1. onAdvancement フロー
    onAdvancement → getPlayer → blocked → isLikelyMcid → getName → getUniqueId
    イベント発生時の分岐と後続処理を担当します。
  2. onPlayerJoin フロー
    onPlayerJoin → getPlayer → blocked → getScheduler → runTaskLater → isOnline
    イベント発生時の分岐と後続処理を担当します。
  3. processDoneKeys フロー
    processDoneKeys → getScore → toString → has → record → calcDelta
    processDoneKeys の主要処理を担当します。
  4. catchUpAdvancements フロー
    catchUpAdvancements → isOnline → isPrimaryThread → getScheduler → runTask → blocked
    既に達成済みの進捗を「月ごとに重複しない」形でキャッチアップ付与する。
  5. calcDelta フロー
    calcDelta → contains
    calcDelta の主要処理を担当します。

外部との接点

Web ルート

このクラス内に目立つ Web ルート定義は見つかりませんでした。

SQL / テーブル

テーブル名の抽出はありませんでした。

関連クラス

補足