Jump to content
  • 0

Question

Posted

hi im new here and i would like some help i have puted the code to @Elfocrash on pack 272 to l2jacis 
when a player is going to send message to a bot it shows this error
and the message doesnt 
go ... can you help me to fix that 

 

code

+++ b/aCis_gameserver/java/net/sf/l2j/gameserver/handler/chathandlers/ChatTell.java
@@ -1,5 +1,7 @@
package net.sf.l2j.gameserver.handler.chathandlers;
 
+import com.elfocrash.roboto.FakePlayer;
+
 import net.sf.l2j.gameserver.handler.IChatHandler;
 import net.sf.l2j.gameserver.model.BlockList;
 import net.sf.l2j.gameserver.model.World;
@@ -21,7 +23,7 @@ public void handleChat(int type, Player activeChar, String target, String text)
 			return;
 		
 		final Player receiver = World.getInstance().getPlayer(target);
-		if (receiver == null || receiver.getClient().isDetached())
+		if (receiver == null || receiver.getClient().isDetached() && !(receiver instanceof FakePlayer))
 		{
 			activeChar.sendPacket(SystemMessageId.TARGET_IS_NOT_FOUND_IN_THE_GAME);
 			return;
erorr
Jan 20, 2020 10:19:03 AM net.sf.l2j.gameserver.network.clientpackets.L2GameClientPacket run
SEVERE: Client: [Character: leon - Account: admin - IP: 85.75.10.25] - Failed reading: [C] Say2 ; java.lang.NullPointerException
java.lang.NullPointerException
	at net.sf.l2j.gameserver.handler.chathandlers.ChatTell.handleChat(ChatTell.java:26)
	at net.sf.l2j.gameserver.network.clientpackets.Say2.runImpl(Say2.java:181)
	at net.sf.l2j.gameserver.network.clientpackets.L2GameClientPacket.run(L2GameClientPacket.java:50)
	at net.sf.l2j.gameserver.network.L2GameClient.run(L2GameClient.java:755)
	at net.sf.l2j.commons.concurrent.ThreadPool$TaskWrapper.run(ThreadPool.java:248)
	at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
	at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
	at java.lang.Thread.run(Thread.java:748)

 

7 answers to this question

Recommended Posts

  • 0
Posted
1 hour ago, xFranky said:

I am not too sure if this is going to fix ur issue but try this:


if (receiver == null || receiver != null && receiver.getClient().isDetached() && !(receiver instanceof FakePlayer))

 

Pointless to add check for not null, because condition throw up TRUE after first null check if object null.

 

This will always throw up NullException for Fake Players.

 

receiver.getClient().isDetached()

The reason - client is null.

 

if (receiver == null || (receiver.getClient() != null && receiver.getClient().isDetached() && !(receiver instanceof FakePlayer)))

Something like this.

  • Thanks 1
  • 0
Posted
57 minutes ago, loukas1978 said:

hi im new here and i would like some help i have puted the code to @Elfocrash on pack 272 to l2jacis 
when a player is going to send message to a bot it shows this error
and the message doesnt 
go ... can you help me to fix that 

 

 

 

Are you using aCis 272? Why not update to 370? It is free also https://gitlab.com/Tryskell/acis_public

  • 0
Posted

I am not too sure if this is going to fix ur issue but try this:

if (receiver == null || receiver != null && receiver.getClient().isDetached() && !(receiver instanceof FakePlayer))
  • 0
Posted
if (receiver == null || (receiver.getClient() != null && receiver.getClient().isDetached() && !(receiver instanceof FakePlayer)))

i put the code below and it worked great thanks for your help!!!

  • 0
Posted (edited)
7 hours ago, xFranky said:

I am not too sure if this is going to fix ur issue but try this:


if (receiver == null || receiver != null && receiver.getClient().isDetached() && !(receiver instanceof FakePlayer))

this is wrong in so many ways :D

equivalent to if (true or false && ...) mean is always true to 

return;
Edited by DenArt Designs
  • 0
Posted (edited)
9 hours ago, Rootware said:

 

Pointless to add check for not null, because condition throw up TRUE after first null check if object null.

 

This will always throw up NullException for Fake Players.

 


receiver.getClient().isDetached()

The reason - client is null.

 


if (receiver == null || (receiver.getClient() != null && receiver.getClient().isDetached() && !(receiver instanceof FakePlayer)))

Something like this.

I had way more than I could handle alcohol in my body last night. Now that I look at it, it was pointless. The worst I have come up with yet while I'm drunk in coding!

 

Locked

Edited by xFranky
Guest
This topic is now closed to further replies.


  • Posts

    • For the first time in thousands of posts I've read on this forum, I’ve actually found a message that is enriching on both a personal and professional level. I’ll take your advice to heart: I’m going to start creating more and stop overthinking things that get me nowhere. I totally agree about the toxic community; it's a shame. Time to keep working. Thanks a lot for your input.   Exactly, that’s why the Scryde method and their merge system work so well. People don't lose their progress and can still keep rushing new servers. Obviously, gameplay has mutated into something much faster-paced, but obviously, this happens in real life too, everyone is more accelerated and on edge. Thanks to social media and mental conditioning. But, well, it’s something we have to accept. Don't even get me started on gambling and online casinos; that’s a whole other topic regarding all the P2W servers.   Really, amen bro.
    • Hello, the server lifespan isn't something that only affects Argentina; just look at the South American and European communities. Those distant days you mentioned, when we were younger, which I completely agree with, are long gone. Today, the community plays RUSH for 30 or 60 days and seeks the adrenaline rush of starting over. As for free or paid packs, there are many options, but in all of them, you'll have to create your own unique style.  
    • Introducing: NimeraCP V2! What's New: Realtime Tickets (Receive + Send messages without refreshing page, instant delivery to player) Powered by WebSockets Realtime Rankings/Stats (Receive instant updates without refreshing page) Powered by WebSockets - PvP/Boss Rankings/Clan Rankings etc... oAuth Login + Register (VK, Discord, Google) Two Factor Authentication (Authenticator App) Passkey coming soon! Theme Editor New Arcade Game: Rock Paper Scissors Let players gamble wagering their topped up wallet balance! Discord Webhooks: Receive messages to discord via Bot or Webhook for certain events New Player registration New Payment received New Ticket Opened and more Complete UI Overhaul NimeracCP V2 is now fully multilangual supporting the following languages: English Ελληνικά Português / Brasileiro Español Русский Українська 한국어 Onboarding: Easy installation wizard via /onboarding on first use of the panel for easy installation. Feature Flags: You have full control over the UI. Disable/Enable pages + features via Admin CP CloudFlare R2 Bucket integration: The panel comes with Bucket storage integration for all kinds of assets uploaded to the panel.   A new website shop at https://nimeracp.com/ is also coming soon, including full installation docs.  You can join the discord for further updates/questions: https://discord.nimeracp.com/
    • thanks for choosing me ! 
  • Topics

×
×
  • Create New...

Important Information

This community uses essential cookies to function properly. Non-essential cookies and third-party services are used only with your consent. Read our Privacy Policy and We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue..

AdBlock Extension Detected!

Our website is made possible by displaying online advertisements to our members.

Please disable AdBlock browser extension first, to be able to use our community.

I've Disabled AdBlock