起動・前提準備
初期テーブル、依存状態、定期処理の点灯など、このクラスが動き始める前提をまとめています。
Ore Dimension Manager に関する管理・集約処理を担当します。
com.example.rankingplugin.dimensiondimension/OreDimensionManager.javaclassクラス直前の Javadoc は見つかりませんでした。ソースとメソッド構成から責務を補完しています。
Ore Dimension Manager に関する管理・集約処理を担当します。dimension パッケージの中でも 429 行規模の中核クラスで、運用中の主ループ・スケジューラが一か所に集まっています。中規模クラス群の中では変更影響が広く、章立てで読む価値が高いため重点解説へ追加しています。
OreDimensionManagerstartMerchantWatchdogstartSessioncreateOreWorldonMerchantClickonInventoryClickonWorldChangeonQuitonEntityDeath初期テーブル、依存状態、定期処理の点灯など、このクラスが動き始める前提をまとめています。
外部から呼ばれる公開メソッドや、対象プレイヤー・対象データ・対象ワールドを引き当てる経路です。
イベント受理、定期監視、判定、進行更新など、実際に挙動を生む中心ロジックです。
メモリ状態と保存状態を揃え、結果を次の呼び出しや画面表示へ繋ぐ部分です。
メインスレッド境界とバックグラウンド処理が交差します。重い処理やタイミング起因の不具合を追うときの要所です。
このクラスが前提状態を揃え、外部から利用可能な形まで立ち上がる流れです。新規依存の追加や起動失敗の調査はまずここから追います。
イベント受理、判定、状態更新、通知までの主経路です。体感不具合や想定外の分岐はこの流れのどこで止まるかを見ると切り分けやすいです。
結果を保持し、必要なら永続化し、最後に掃除まで行う出口です。画面更新だけ合って保存が壊れるケースや残骸が残るケースの確認に向きます。
SQL 文字列から抽出できた主要テーブルです。スキーマ変更時の確認用です。
| Signature | 説明 | 主要呼び出し |
|---|---|---|
public OreDimensionManager(JavaPlugin plugin, CurrencyService currencyService, Location merchantLocation) | 依存オブジェクトや初期状態を受け取り、このクラスの動作を開始できる状態へ組み立てます。 | getPluginManager → registerEvents → getServer → getScheduler → runTaskTimer → cleanupOrphanMerchantsOnceOnEnable |
| Name | Visibility | Kind | 説明 |
|---|---|---|---|
| formatTime | private | メソッド | formatTime の主要処理を担当します。 |
| OreDimensionManager | public | コンストラクタ | 依存オブジェクトや初期状態を受け取り、このクラスの動作を開始できる状態へ組み立てます。 |
| trySpawnMerchant | private | メソッド | trySpawnMerchant の主要処理を担当します。 |
| startMerchantWatchdog | private | メソッド | 初期化と各種登録を行い、機能を有効化します。 |
| cleanupOrphanMerchantsOnceOnEnable | private | メソッド | cleanupOrphanMerchantsOnceOnEnable の主要処理を担当します。 |
| onMerchantClick | public | イベント処理 | イベント発生時の分岐と後続処理を担当します。 |
| startSession | private | メソッド | 初期化と各種登録を行い、機能を有効化します。 |
| endSession | private | メソッド | endSession の主要処理を担当します。 |
| onInventoryClick | public | イベント処理 | イベント発生時の分岐と後続処理を担当します。 |
| onWorldChange | public | イベント処理 | イベント発生時の分岐と後続処理を担当します。 |
| onQuit | public | イベント処理 | イベント発生時の分岐と後続処理を担当します。 |
| onEntityDeath | public | イベント処理 | イベント発生時の分岐と後続処理を担当します。 |
| onChunkLoad | public | イベント処理 | チャンク読み込み時に期限切れの行商人がいたら即除去(再起動・未参照でもOK) |
| cleanupAfterGone | private | メソッド | 行商人がいなくなった際の共通クリーンアップ |
| releaseForcedChunk | private | メソッド | releaseForcedChunk の主要処理を担当します。 |
| createOreWorld | private | メソッド | createOreWorld の主要処理を担当します。 |
| cleanupOreWorld | private | メソッド | cleanupOreWorld の主要処理を担当します。 |
| deleteFolder | private | メソッド | 対象データや登録状態を削除・解除します。 |
| shutdown | public | メソッド | call from your onDisable() |
private String formatTime(long millis)formatTime の主要処理を担当します。
long millisなし
public OreDimensionManager(JavaPlugin plugin, CurrencyService currencyService, Location merchantLocation)依存オブジェクトや初期状態を受け取り、このクラスの動作を開始できる状態へ組み立てます。
JavaPlugin pluginCurrencyService currencyServiceLocation merchantLocationなし
private void trySpawnMerchant()trySpawnMerchant の主要処理を担当します。
なし
private void startMerchantWatchdog()初期化と各種登録を行い、機能を有効化します。
なし
private void cleanupOrphanMerchantsOnceOnEnable()cleanupOrphanMerchantsOnceOnEnable の主要処理を担当します。
なし
public void onMerchantClick(PlayerInteractEntityEvent e)イベント発生時の分岐と後続処理を担当します。
PlayerInteractEntityEvent eなし
private void startSession(Player p)初期化と各種登録を行い、機能を有効化します。
Player pなし
private void endSession(UUID uuid, boolean teleportBack)endSession の主要処理を担当します。
UUID uuidboolean teleportBackなし
public void onInventoryClick(InventoryClickEvent e)イベント発生時の分岐と後続処理を担当します。
InventoryClickEvent eなし
public void onWorldChange(PlayerChangedWorldEvent e)イベント発生時の分岐と後続処理を担当します。
PlayerChangedWorldEvent eなし
public void onQuit(PlayerQuitEvent e)イベント発生時の分岐と後続処理を担当します。
PlayerQuitEvent eなし
public void onEntityDeath(EntityDeathEvent e)イベント発生時の分岐と後続処理を担当します。
EntityDeathEvent eなし
public void onChunkLoad(ChunkLoadEvent e)チャンク読み込み時に期限切れの行商人がいたら即除去(再起動・未参照でもOK)
ChunkLoadEvent eなし
private void cleanupAfterGone()行商人がいなくなった際の共通クリーンアップ
なし
private void releaseForcedChunk()releaseForcedChunk の主要処理を担当します。
なし
private void createOreWorld()createOreWorld の主要処理を担当します。
なし
private void cleanupOreWorld()cleanupOreWorld の主要処理を担当します。
なし
private void deleteFolder(File f)対象データや登録状態を削除・解除します。
File fなし
public void shutdown()call from your onDisable()
なし
OreDimensionManager → getPluginManager → registerEvents → getServer → getScheduler → runTaskTimeronChunkLoad → getChunk → getEntities → getScoreboardTags → contains → getPersistentDataContaineronInventoryClick → getView → getTitle → equals → setCancelled → getWhoClickedonMerchantClick → getRightClicked → getScoreboardTags → contains → setCancelled → createInventoryonWorldChange → getFrom → equals → endSession → getPlayer → getUniqueIdonEntityDeath → getEntity → getUniqueId → equals → cleanupAfterGone