Jump to content

Recommended Posts

Posted

Hello ppl. its my first java post

i used  as a source a post from Rizel

i tried his fix to my server and it didnt fix the bug

so i fixed the code

here it is :

L2PcInstance.java

 

At line 497

 

    private int _apprentice = 0;

    private int _sponsor = 0;

 

+    public boolean _allowTrade = true;

   

private long _clanJoinExpiryTime;

private long _clanCreateExpiryTime;

 

 

 

At line 8121

 

    public void setClanPrivileges(int n)

    {

        _clanPrivileges = n;

    }

 

+    public boolean getAllowTrade()

+    {

+    return _allowTrade;

+    }

+   

+    public void setAllowTrade(boolean a)

+    {

+    _allowTrade = a;

+    }

 

-----------------------------------------------

AnswerTradeRequest.java

 

At line 60

 

        L2PcInstance partner = player.getActiveRequester();

        if (partner == null || L2World.getInstance().findObject(partner.getObjectId()) == null)

        {

+        if (partner.getAllowTrade() == true)

+       {

+      partner.sendPacket(new SendTradeDone(0));

+      player.sendPacket(new SendTradeDone(0));

+      return; }

       

At line 74

            player.sendPacket(msg);

+          player.setAllowTrade(true);

            player.setActiveRequester(null);

At line 80

 

-          if (_response == 1) player.startTrade(partner);

 

+    if (_response == 1)

+    {

+  player.startTrade(partner);

+            partner.setAllowTrade(true);

+            player.setAllowTrade(true);

+    }

 

else

{

SystemMessage msg = new SystemMessage(SystemMessageId.S1_DENIED_TRADE_REQUEST);

msg.addString(player.getName());

+                         partner.setAllowTrade(true);

+                         player.setAllowTrade(true);

partner.sendPacket(msg);

 

 

msg = null;

 

-----------------------------------------------

TradeRequest.java

 

At line 112

 

            player.sendMessage("Target is in trade refusal mode");

            return;

        }

+              if (player.getAllowTrade() == false)

+              {

+                player.sendMessage("You are not allowed to make more than one trade request at the same time.");

+                return;

+                }

+              if (partner.getAllowTrade() == false)

+          {

+            player.sendMessage("The target is not allowed to make more than one trade request at the same time.");

+            return;

+            }

+        partner.setAllowTrade(false);

+        player.setAllowTrade(false);

player.onTransactionRequest(partner);

 

-------------------------------------------

TradeDone.java

 

At line 79

 

        }

        trade.confirm();

+         player.setAllowTrade(true);

 

}

else player.cancelActiveTrade();

+        player.setAllowTrade(true);

 

}

 

Posted

This is ENGLISH not GREEK section, topic locked.

 


 

Unlocked as requested, translate this thread to english.

  • 2 months later...
  • 3 weeks later...
Posted

Well you don't need to always check like this:

if (player.getAllowTrade == true).

 

If you wanna see if the getAllowTrade is false then do this

if (!player.getAllowTrade)

 

else if you wanna be true do this

if (player.getAllowTrade)

 

Just my opinion :)

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now


  • Posts

    • New user panel SOURCE $ 200 for source code. R$ 1000,00 BRL for source code.    
    • Hello everyone, we are one of the top gaming currency stores. We work exclusively with top projects. If you are interested in anything like Adena, Coins, Equip, write to us Discord - pchelacoin Telegram - https://t.me/ipchelacoin BOHPTS, KETRAWARS, EURO-PVP, L2REBORN, E-GLOBAL, LA2DREAM TOP PRICE !!!!!!!
    • L2Elixir – Patch 4 Is Live!   We’re working non-stop, day and night, to deliver the best possible quality and bring back what made L2Elixir special. This project is built with passion, not shortcuts — for the old-school players who remember, and the new ones who want to experience it properly. Thank you for being part of the journey. Together, we’re making L2Elixir great again ❤️ The legends never fade.    ⚙️ General Enabled Class Change service (same class type only) ALT + B → Services → Character Development Enabled Shift + Click on Treasure Chests Players can now identify real chests (Adena, scroll drops) and use Key / Unlock Event deaths now cancel only debuffs, All self buffs are preserved, fixes issues with Root and similar effects Bladedancer class can now log in even when Max Clients (2) is reached. Since an active Bladedancer is not available for every damage dealer and some players tried to abuse this via VPN or a second PC, this feature was added to keep things fair. protections applies, requires testing!    🎒 Items Crystallizing enchanted items now gives the correct increased crystal amount (retail-like behavior) Removed Agathion Seal Bracelet: Rudolph from Santa rewards (Gracia Final item) Added Dualsword Craft Stamp into Milestone Exchange list    🧙 Skills Fixed Banish Undead lethal chance Hot Springs Malaria and similar effects now level up faster while being attacked
  • Topics

×
×
  • Create New...

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