Jump to content

[SOLVED] [1.17.1] AttachCapabilitiesEvent firing twice.


DaqEm

Recommended Posts

Hey everyone,

I've been testing the new 1.17.1 way to create capabilities and for some reason the AttachCapabilitiesEvent is firing twice when I join a singleplayer world.

The code I used is here: GitHub - TheIllusiveC4/Curios at 726bfd9589d49174520379de8bfdb53b5208ed13 (this is not my code, I just it for testing purposes only)

@SubscribeEvent
public void onAttachEntityCaps(AttachCapabilitiesEvent<Entity> event) {
    if (event.getObject() instanceof Player) {
        event.addCapability(CuriosCapability.ID_INVENTORY,
                CurioInventoryCapability.createProvider((Player) event.getObject()));
        LOGGER.info("Attached Capability!");
    }
}

 

Also to do some more testing I've added a PlayerTickEvent (I know it's bad but its for testing xD):

@Mod.EventBusSubscriber(bus= Mod.EventBusSubscriber.Bus.MOD)
public class EventPlayerTick {

    int count = 0;

    @SubscribeEvent
    public void onPlayerTick(TickEvent.PlayerTickEvent event) {
        if (count == 100) {
            event.player.getCapability(CuriosCapability.INVENTORY).ifPresent((jobHandler) -> {
                int currentValue = jobHandler.getSlots();
                JobsPlus.LOGGER.info(currentValue + " | | | " + jobHandler + " " + event.player.getScoreboardName());
                jobHandler.setSlots(currentValue + 1);
            });
            count = 0;
        }
        count += 1;
    }
}

and that outputs this:

[20:45:13] [Server thread/INFO]: 0 | | |  me.daqem.jobsplus.testcap.CurioInventoryCapability$CurioInventoryWrapper@3524f28 Dev
[20:45:14] [Render thread/INFO]: 0 | | |  me.daqem.jobsplus.testcap.CurioInventoryCapability$CurioInventoryWrapper@1014c825 Dev
[20:45:15] [Server thread/INFO]: 1 | | |  me.daqem.jobsplus.testcap.CurioInventoryCapability$CurioInventoryWrapper@3524f28 Dev
[20:45:16] [Server thread/INFO]: 2 | | |  me.daqem.jobsplus.testcap.CurioInventoryCapability$CurioInventoryWrapper@3524f28 Dev

So this definitely are 2 capabilities attached to the Player.

 

Any help is appreciated! Thank you.

Edited by DaqEm
Topic has been solved.
Link to comment
Share on other sites

no there is only one Capability,
you don't notice that TickEvents fired twice (tick START and END),
also the TickEvents are fired on server and client

so if you don't check the phase and the side the Event is fired 4 times

  1. client START
  2. server START
  3. client END
  4. server END

also you can't use static values in Events, since they are not synced to the client and they exists for all Players (in this case)

Link to comment
Share on other sites

Okay, so completely forgot it fired client and server side. I made some adjustments to the PlayerTickEvent and found the problem.

@SubscribeEvent
    public void onPlayerTick(TickEvent.PlayerTickEvent event) {
        if (event.side == LogicalSide.SERVER && event.phase == TickEvent.Phase.START) {
            event.player.getCapability(CuriosCapability.INVENTORY).ifPresent((jobHandler) -> {
                int currentValue = jobHandler.getSlots();
                JobsPlus.LOGGER.info(currentValue + " | | | " + jobHandler + " " + event.player.getScoreboardName() + " server");
                jobHandler.setSlots(currentValue + 1);
            });
        }
        if (event.side == LogicalSide.CLIENT && event.phase == TickEvent.Phase.START) {
            event.player.getCapability(CuriosCapability.INVENTORY).ifPresent((jobHandler) -> {
                int currentValue = jobHandler.getSlots();
                JobsPlus.LOGGER.info(currentValue + " | | | " + jobHandler + " " + event.player.getScoreboardName() + " client");
                jobHandler.setSlots(currentValue + 1);
            });
        }
    }
[21:20:45] [Server thread/INFO]: 23 | | | me.daqem.jobsplus.testcap.CurioInventoryCapability$CurioInventoryWrapper@8899b18 Dev server
[21:20:45] [Render thread/INFO]: 31 | | | me.daqem.jobsplus.testcap.CurioInventoryCapability$CurioInventoryWrapper@3db84bfa Dev client
[21:20:45] [Server thread/INFO]: 24 | | | me.daqem.jobsplus.testcap.CurioInventoryCapability$CurioInventoryWrapper@8899b18 Dev server
[21:20:45] [Render thread/INFO]: 32 | | | me.daqem.jobsplus.testcap.CurioInventoryCapability$CurioInventoryWrapper@3db84bfa Dev client
[21:20:45] [Server thread/INFO]: 25 | | | me.daqem.jobsplus.testcap.CurioInventoryCapability$CurioInventoryWrapper@8899b18 Dev server
[21:20:45] [Render thread/INFO]: 33 | | | me.daqem.jobsplus.testcap.CurioInventoryCapability$CurioInventoryWrapper@3db84bfa Dev client
[21:20:45] [Server thread/INFO]: 26 | | | me.daqem.jobsplus.testcap.CurioInventoryCapability$CurioInventoryWrapper@8899b18 Dev server
[21:20:45] [Server thread/INFO]: 27 | | | me.daqem.jobsplus.testcap.CurioInventoryCapability$CurioInventoryWrapper@8899b18 Dev server

Marking this as solved.

Link to comment
Share on other sites

  • DaqEm changed the title to [SOLVED] [1.17.1] AttachCapabilitiesEvent firing twice.

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

Announcements



  • Recently Browsing

    • No registered users viewing this page.
  • Posts

    • 网络花图战略▷BCGAME55·COM⊙网络花图网站帕劳网络花图游乐场America花图方法[本社文之Tele @JBOX7]网络花图Holdom Pub Ginibiso网络花图广播匈牙利花图旅行津巴布韦花图比赛[总经销文的Kakao Talk JBOX7]网络游戏FOXWood Casino ITALPERAUTALL Telecom Pub[本社文之音] 制作社区] 网游] [澳大利亚网购] [赌场总公司] 网络花图巡回 莱索托 网络花图赌场 哈萨克斯坦花图游乐场 科特迪瓦花图企业 [体育总公司] 网络花图网站南非 网络花图 巴卡拉酒吧 加拿大花图视频 Kyrivasi 网络花图赌场酒吧 [TOTO总公司咨询] ITWO赌博场所 ESWATINI IT COUPONE厄瓜多尔卡什游戏 Aria Casino Hoto Tourtourtourtune [TOTO总购买] ITHIGOTUGO游戏场] 联盟[bacara总经销] 网络花图 bacara pub 塞内加尔网络花图视频 南美洲花图战略塞内加尔花图转播[赛马总经销] 网络花图 bacara pub 罗马尼亚网络花图游戏 日本花图 bacara pub montecaro 花图 coopoon[BCGAME bc游戏总经销咨询] 设置通知推荐 订阅 点赞
    • 東京都キスバン話†BCGAME33・COM↖東京都キスバン、ツイッターボッチャ東京都キスバンサイト槍投げキスバンサイトのオンラインゲームキスバンインスタグラム[本社の問い合わせテレ@JBOX7]東京都キスバン同好会、鉄棒、東京都キスバン、ユーチューブオンラインゲームキスバン動画の水上スポーツのキスバン推薦[の一手販売業者の問い合わせ、カカオトークやJBOX7]東京都キスバン放送、マッサージ、東京都キスバン指導スキーキスバンツアーラグビーキスバン会情報[各種オーピーコミュニティ制作】東京都キスバンリゾート水泳東京都キスバン旅行重量挙げキスバン映像シルムキスバンするところ[マーケティング問い合わせ]東京都キスバン旅行棒高跳びの東京都キスバン、ツイッタースキーキスバンの一手販売ラケットボールキスバン求人広告[カジノ本社] 東京都キスバン住所、重量挙げ、東京都キスバン旅行水泳キスバンラインハンドボールキスバンシステム[スポーツ本社】東京都キスバンラインアルペン東京都キスバンツアーハンドボールキスバン接続ワールドカップキスバン位置[トト(株)本社のお問い合わせ]東京都キスバン、ツイッター、マッサージ、東京都キスバン求人広告バドミントンキスバンリンクギョクキキスバンインスタグラム[トトの一手販売購買】東京都キスバン話、鉄棒、東京都キスバンリゾートアーチェリーキスバンリンク棒高跳びキスバン、新住所[カジノの一手販売業者】東京都キスバンの一手販売業者フェンシング東京都キスバン、新住所、ティーボールキスバン推薦誘導キスバン動画[大和の本社】東京都キスバンコミュニティ相撲東京都キスバン指導ギョクキキスバンリンクダイビングキスバン指導[バカラの一手販売]
    • 东南亚Go-Stop游戏厅♨BCGAME55·COM @ 东南亚Go-Stop网站Book Makedonia东南亚Go-Stop转播Win Casino Go-Stop网站Ryberia Go-Stop方法[本社的Tele @JBOX7] 东南亚Go-Stop Bar西亚东南亚Go-Poon 格伦纳丁GO-Stop扑克大赛刚果民主Goostop Coopon[总经销的Kakao Talk JBOX7] 东南亚 Gomino Saition网站] 制作方法[东南亚 G 赌场 [赌场总公司] 东南亚Go Stop 转播 帕劳 东南亚Go Stop总经销 苏里南Go Stop 视频 罗马尼亚Go Stop战略 尼泊尔东南亚Go Stop方法西非Go Stop赌场尼日利亚Go Stop Tour[TOTO总公司咨询]东南亚Go Stop连接冈比亚东南亚 GOSTOP SITE Estonia GOSTOP MALLET MALLATION GOSTOP招募[TOTOTOTO总经销购买]东南亚 GOSTOP比赛 NIGOSTOP TANGE GOSTOP TALLIGOTION GOSTOP总经销 Holdumba厄瓜多尔Go Stop赌场酒吧新西兰Go Stop总经销[Bakara总经销]东南亚Go Stop转播巴登巴登东南亚Go Stop游戏场台湾Go Stop社区塞内加尔Go Stop招募[赛马总经销]东南亚Go Stop视频葡萄牙东南亚Go Stop方法 Falls View赌场Kosogos游戏场Cipross Gosing地址[BCGME BC Game总经销咨询]设置通知推荐订阅点赞
    • 全球LAPT推荐™BCGAME55·COM℡ 全球LAPT YouTube 意大利全球LAPT总经销匈牙利LAPT赌场酒吧 新加坡LAPT Holdom Pub[本文的Tele @JBOX7] 全球LAPT淘汰赛塞尔维亚全球LAPT推荐赞比亚LAPT扑克大赛 西非的LAPT游戏厅[总经销的Kakao Talk JBOX7] 缅甸的环球网游 马里网游 加拿大网 制作地址:非洲网吧 制作。 LAPT战略也门LAPT Bakara Pub [赌场总公司] 全世界LAPT招募不丹LAPT Holdomba阿富汗LAPT游戏场 Tubalu LAPT战略 [体育总公司] 全世界LAPT比赛 Ibiza Gran Cagino 全世界 LAPT Bakara Pub Armenia LAFT 旅行[TOTOTO总公司咨询] 全世界 LAPT KUPONG叙利亚 LAST 连接 TUKET 土耳其 土耳其 TUKET社区旅行 [TOMET] 社区埃及LAPT地址[YAMATO总公司]全球LAPT方法利比亚全球LAPT总经销厄立特里亚LAPT连接列支敦士登LAPT战略[巴卡拉总经销]全球LAPT联赛黑塞哥维那全球LAPT赛亚特兰蒂斯卡吉诺LAPT视频刚果(刚果)(赛马总经销)]全球LAPT赌城冈比亚全球LAPT比赛尼加拉瓜LAPT战略多哥LAPCA游戏总经销点赞设定]
    • 世界杯搏击网站♥BCGAME55·COM‡世界杯搏击企业欧洲世界杯搏击YouTube度假村世界赌场搏击Holdom Pub Falls View赌场搏击地址[本社文义通 @JBOX7]世界杯搏击YouTube北非世界杯搏击总经销卢森堡搏击巴卡拉波普 刚果(Kakao Talk JBOX7] 推荐世界杯Holdom Barwago世界杯台湾格斗高尔夫球场异种格斗视频制作方法] 巴登巴登世界杯搏击赛场吉尔吉斯斯坦搏击赛场Suncity搏击赛场[赌场总部]世界杯搏击赛场梵蒂冈时局世界杯搏击赛场库彭博茨瓦纳搏击赛场黎巴嫩搏击赛场][体育总部]世界杯搏击扑克大赛圣马力诺世界杯终极格斗视频巴登巴登巴登终极格斗赛场立陶宛终极格斗联赛[兔本社咨询]世界杯终极格斗联赛 NATHUDUDUBBA世界杯UTHUDUDUTUTBBBE 购买世界杯终极格斗大赛 异种格斗赌场酒吧阿富汗世界杯异种格斗Cash游戏Suri Nam异种格斗登录白俄罗斯异种格斗总经销[Yamato总公司]世界杯异种格斗Coopoon加拿大世界杯异种格斗转播卢旺达异种格斗游戏场东南亚异种格斗Coopoon[Bakara总经销] [赛马总经销]世界杯 东南亚搏击战略游戏Coopoon[Bakara总经销]澳大利亚世界杯搏击转播 圣玛丽诺 圣卡拉波普 西非地区搏击 Bakpojokpoon]
  • Topics

×
×
  • Create New...

Important Information

By using this site, you agree to our Terms of Use.