Jump to content
  • 0

Question

Posted (edited)

Hello, I recently created a model to edit my config in xml, but I have a doubt, to restore the status of the players after restart you will have to create a loop? Because I don't think it would be a good idea to do that, I would like your opinion.

 

for (Vip vip : VipData.getInstance().getVip())
		{
			if (player.getMemos().getLong(vip.getType().toString(), 0) > 0)	
			{
				long now = Calendar.getInstance().getTimeInMillis();
				long endDay = player.getMemos().getLong(vip.getType().toString());
				
				if (now > endDay)
					player.deleteVip(vip.getType());
				else
				{
					player.setVip(vip);
					
					if (!vip.getMessage().isEmpty())
						World.announceToOnlinePlayers(player.getClan() != null ? vip.getMessageClan().replace("%player%", player.getName()).replace("%clan%", player.getClan().getName()) : vip.getMessage().replace("%player%", player.getName()), true);
					
					player.broadcastUserInfo();
				}
			}
		}

 

Edited by Vision

5 answers to this question

Recommended Posts

  • 0
Posted

This doesn't look bad, but you should move such logic in VipData. Also, I'm pretty sure VipData can be improved, but I can't know how until I see it.

 

You should move 'long now' outside of the for loop and 'long endDay' outside of the if statement and use it in the if like 'if (endDay > 0)'.

 

Also, you probably need some way to remove vip for players that vip time runs out, but there probably is a task already in VipData (can't know till I see it).

  • 0
Posted
6 hours ago, xdem said:

code makes no sense

He probably has some xml with different vip types and to activate vip on enter world he loops through the possible vips to check if the player has a bonus applied. It's crap, but the code he asked help for looks correct, if what I assumed is right.

  • 0
Posted
On 10/8/2022 at 7:34 PM, An4rchy said:

He probably has some xml with different vip types and to activate vip on enter world he loops through the possible vips to check if the player has a bonus applied. It's crap, but the code he asked help for looks correct, if what I assumed is right.

 

I created a task to calculate the end of time

 


	@Override
	public final void run()
	{
		if (_players.isEmpty())
			return;
		
		for (Map.Entry<Integer, Long> entry : _players.entrySet())
		{
			final Player player = World.getInstance().getPlayer(entry.getKey());
			if (player == null)
				continue;
			
			final VipType type = player.getVip().getType();
			if (player.getMemos().getLong(type.toString(), 0) < System.currentTimeMillis())
			{
				player.deleteVip(type);
				remove(player.getObjectId());
			}
		}
	}

 

 

removed the loop to check vips when entering

 

Vip vip = VipData.getInstance().getVip(VipType.BRONZE);
        if (vip != null)
        {
            if (player.getMemos().getLong(vip.getType().toString(), 0) > 0)    
            {
                long now = Calendar.getInstance().getTimeInMillis();
                long endDay = player.getMemos().getLong(vip.getType().toString());
                
                if (now > endDay)
                    player.deleteVip(vip.getType());
                else
                {
                    player.setVip(vip);
                    
                    if (!vip.getMessage().isEmpty())
                        World.announceToOnlinePlayers(player.getClan() != null ? vip.getMessageClan().replace("%player%", player.getName()).replace("%clan%", player.getClan().getName()) : vip.getMessage().replace("%player%", player.getName()), true);
                    
                    player.broadcastUserInfo();
                }
            }
        }

  • 0
Posted

Feels too much complicated logic. It could be sharply simplified and cleaned up.

 

First of all, on EnterWorld you should only have a reference of a method, example:  onEnterWorld(PlayerInstance player) reference, you dont need anything more there.

 

Then make sure on server launch/shutdown you load/save such a map "Map<Integer, Map<Long, VipType>>" which structure will actually be explained as {playerObjId, (timeToExpireOnMillis, VipType)}.

 

Once you have such structure the only thing you actually have to do in onEnterWorld is to check if the player that is logging in has any Vip Type time active by comparing timeToExpireOnMillis with currentTimeOnMillis and then give him the coresponding Vip benefits.

 

You could also make such check on real time by scheduling a task at fixed rate.

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

    • Lol another crappy server if you wanna x5000 rates go play l2java or damage, at least not gonna die in few months when server rent and cheap meth will fade out lol
    • Why the shitty interface then?
    • Wtf you even selling no clue at all, stop use this crappy AI 
    • We are a small team of developers from this community who used to play on the Interlude version of L2Pride, almost 20 years ago. There have been many attempts over the years to replicate this server, specifically the very first version of it that came on Interlude(C6) and all of them were met with failure. We decided to take it upon ourselves again since we remember every little detail that made this server unique and also were fortunate enough to get our hands in some of the old code that made the server unique. Some features about the server: ⚔️ Original Castle Reward System 🏹 Classic L2Pride Class Balance & Hunter's Village S-Grade PvP 🎯 12 Subclasses • Automatic TVT / CTF / DM / VIP Events 🔄 Fully Functional Rebirth System 🏆 PvP Rewards every 1,000 PvP Points 👑 Fully Working Olympiad ☠️ Cursed Weapons with Void Burst & Void Flow 💰 Beleth's Bronze, Silver & Gold Currency System since Adena is too easy to get ⭐ Safe Enchant +6 • Max Enchant +25 📍 Start: Cave of Trials • ⚔️ Leveling: Varka Silenos 🏛️ Farm Instances: Cave of Trials & Cemetery 🤖 Optional Autofarm & Healbot • 🚀 Teleport Stone The server is strictly focusing around PvP while minimizing PvE to the minimum, all classes have been balanced and tweaked for PvP, even dumb classes like Prophets and Bladedancers are now useful and fun to play PvP with. Posting this since there has been a lot of interest and approval from this subreddit, you can stay tuned and up to date about the opening here: https://discord.com/invite/2Knae6mmTx This is also our website made after the classic version of the game: https://www.l2belle.org/ (you can find more info and guides here) Since this is a server focused heavily on PvP we are expecting a lot of clans and people to join and make this a joyful ride. See you soon
    • TG Support: https://t.me/buyingproxysup | Channel: https://t.me/buyingproxycom Discord support: #buyingproxy | Server: Join the BuyingProxy Discord Server!  Create your free account here
  • 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..