Jump to content

Recommended Posts

Posted

line 78 -  boolean canReward = false;                  (playerIps empty array in that position)

line 80 -  if (playerIps.containsKey(pIp))                (won't enter here .> array empty)

 

line 96 - if (canReward)                                            (won't enter here .> boolean is false)

 

I think we should think what are we posting before doing it, not?

Posted

Try this...

 

public class MiniReward
{
static HashMap<String, Integer> Ips = new HashMap<String, Integer>();
        
public static void getInstance()
{
	ThreadPoolManager.getInstance().scheduleGeneralAtFixedRate(new Runnable()
	{
		@Override
		public void run()
		{
			Collection<L2PcInstance> pls = L2World.getInstance().getAllPlayers().values();

			for (L2PcInstance p : pls)
                {
				String pIp = p.getClient().getConnection().getInetAddress().getHostAddress();
                        
				if (!Ips.containsKey(pIp))
                    {
					Ips.put(pIp, 1);
					reward(p);
                    }
				else
				{
					int count = Ips.get(pIp);
                
					if (count < Config.DUALBOXES_ALLOWED)
                    {
						Ips.remove(pIp);
						Ips.put(pIp, count+1);
						reward(p);
                    }
					else
                    {
						p.sendMessage("Already "+Config.DUALBOXES_ALLOWED+" character(s) of your ip have been rewarded, so this character won't be rewarded.");
                    }

				}
                }
			Ips.clear();
		}             
	}, 0, 86400 * 1000);
}

private static void reward(L2PcInstance player)
{
	for (int i : Config.MINI_REWARD.keySet())
        {
		player.addItem("Mini Reward.", i, Config.MINI_REWARD.get(i), player, true);
        }
}
}

  • 1 year later...
Posted (edited)

Put size() instead of values.

 

L2World.getInstance().getAllPlayers().size();

 

Else you can try like

 

L2World.getInstance().getAllPlayersArray(); - if he use(d) l2j method ..

 

If you still get error then use search option for "L2World.getInstance().getAllPlayers()" and you will see how it is @ reunion.

Edited by SweeTs
Posted

1st of all, when you say "error" tell us what error.. 2nd thing, just do as I said aka use search option for that, you will find the answer on your own.

Posted


/*

* This program is free software: you can redistribute it and/or modify it under

* the terms of the GNU General Public License as published by the Free Software

* Foundation, either version 3 of the License, or (at your option) any later

* version.

*

* This program is distributed in the hope that it will be useful, but WITHOUT

* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS

* FOR A PARTICULAR PURPOSE. See the GNU General Public License for more

* details.

*

* You should have received a copy of the GNU General Public License along with

* this program. If not, see <http://www.gnu.org/licenses/>.

*/

package l2r.gameserver.model.entity;

 

import java.util.HashMap;

 

import l2r.Config;

import l2r.gameserver.ThreadPoolManager;

import l2r.gameserver.model.L2World;

import l2r.gameserver.model.actor.instance.L2PcInstance;

 

/**

* @author Loses

*/

public class MiniReward

{

static HashMap<String, Integer> Ips = new HashMap<>();

 

public static void getInstance()

{

ThreadPoolManager.getInstance().scheduleGeneralAtFixedRate(new Runnable()

{

@Override

public void run()

{

L2PcInstance[] pls = L2World.getInstance().getAllPlayersArray();

 

for (L2PcInstance p : pls)

{

String pIp = p.getClient().getConnection().getInetAddress().getHostAddress();

 

if (!Ips.containsKey(pIp))

{

Ips.put(pIp, 1);

reward(p);

}

else

{

int count = Ips.get(pIp);

 

if (count < Config.DUALBOXES_ALLOWED)

{

Ips.remove(pIp);

Ips.put(pIp, count + 1);

reward(p);

}

else

{

p.sendMessage("Already " + Config.DUALBOXES_ALLOWED + " character(s) of your ip have been rewarded, so this character won't be rewarded.");

}

 

}

}

Ips.clear();

}

}, 0, 14400 * 1000);

}

 

static void reward(L2PcInstance player)

{

for (int i : Config.MINI_REWARD.keySet())

{

player.addItem("Mini Reward.", i, Config.MINI_REWARD.get(i), player, true);

}

}

}

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

    • 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
    • thats new SEO level tricks you know nothing of noob - bottom line: exposed.
    • Warning: This guy is a big scammer, trying to sell everything, advertising for servers etc. That's his mail address evgesha.nrnr@gmail.com , stay away!   @Atom @Celestine
  • 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