Jump to content

Question

11 answers to this question

Recommended Posts

  • 0
Posted

Yep Clay I checked it "The only way to resolve this, is by checking all the calls of this method" Xerus problem is related to movement.
 

Starts at :
 at com.l2jesios.gameserver.ai.L2CharacterAI.maybeMoveToPawn(L2CharacterAI.java:934)

and loops here for ever..


 at com.l2jesios.gameserver.ai.AbstractAI.moveTo(AbstractAI.java:582)
 at com.l2jesios.gameserver.ai.AbstractAI.moveToPawn(AbstractAI.java:538)
 at com.l2jesios.gameserver.ai.L2CharacterAI.maybeMoveToPawn(L2CharacterAI.java:948)

He probably fixed with movement rework. That's what I'm interesting about.

  • 0
Posted

These are some examples: (Project: Acis (latest))

Exception in thread "AISTPool-1" java.lang.StackOverflowError
	at net.sf.l2j.gameserver.model.L2WorldRegion.revalidateZones(L2WorldRegion.java:84)
	at net.sf.l2j.gameserver.model.actor.instance.L2PcInstance.revalidateZone(L2PcInstance.java:1406)
	at net.sf.l2j.gameserver.ai.L2CharacterAI.onEvtArrived(L2CharacterAI.java:623)
	at net.sf.l2j.gameserver.ai.AbstractAI.notifyEvent(AbstractAI.java:353)
	at net.sf.l2j.gameserver.ai.AbstractAI.notifyEvent(AbstractAI.java:276)
	at net.sf.l2j.gameserver.model.actor.L2Character.moveToLocation(L2Character.java:3577)
	at net.sf.l2j.gameserver.model.actor.L2Character$AIAccessor.moveTo(L2Character.java:2803)
	at net.sf.l2j.gameserver.ai.AbstractAI.moveTo(AbstractAI.java:510)
	at net.sf.l2j.gameserver.ai.AbstractAI.moveToPawn(AbstractAI.java:467)
	at net.sf.l2j.gameserver.ai.L2CharacterAI.maybeMoveToPawn(L2CharacterAI.java:861)
	at net.sf.l2j.gameserver.ai.L2PlayerAI.thinkCast(L2PlayerAI.java:235)
	at net.sf.l2j.gameserver.ai.L2PlayerAI.onEvtThink(L2PlayerAI.java:312)
	at net.sf.l2j.gameserver.ai.L2CharacterAI.onEvtArrived(L2CharacterAI.java:638)
	at net.sf.l2j.gameserver.ai.AbstractAI.notifyEvent(AbstractAI.java:353)
	at net.sf.l2j.gameserver.ai.AbstractAI.notifyEvent(AbstractAI.java:276)
	at net.sf.l2j.gameserver.model.actor.L2Character.moveToLocation(L2Character.java:3577)
	at net.sf.l2j.gameserver.model.actor.L2Character$AIAccessor.moveTo(L2Character.java:2803)
-------------------------------------AFTER 1001 ROWS OF THIS LOOP---------------------------------------------
	at net.sf.l2j.gameserver.ai.AbstractAI.moveTo(AbstractAI.java:510)
	at net.sf.l2j.gameserver.ai.AbstractAI.moveToPawn(AbstractAI.java:467)
	at net.sf.l2j.gameserver.ai.L2CharacterAI.maybeMoveToPawn(L2CharacterAI.java:861)
	at net.sf.l2j.gameserver.ai.L2PlayerAI.thinkCast(L2PlayerAI.java:235)
	at net.sf.l2j.gameserver.ai.L2PlayerAI.onEvtThink(L2PlayerAI.java:312)
	at net.sf.l2j.gameserver.ai.L2CharacterAI.onEvtArrived(L2CharacterAI.java:638)
	at net.sf.l2j.gameserver.ai.AbstractAI.notifyEvent(AbstractAI.java:353)

null

Exception in thread "AISTPool-3" java.lang.StackOverflowError
	at net.sf.l2j.gameserver.model.actor.L2Character.moveToLocation(L2Character.java:3514)
	at net.sf.l2j.gameserver.model.actor.L2Character$AIAccessor.moveTo(L2Character.java:2803)
	at net.sf.l2j.gameserver.ai.AbstractAI.moveTo(AbstractAI.java:510)
	at net.sf.l2j.gameserver.ai.AbstractAI.moveToPawn(AbstractAI.java:467)
	at net.sf.l2j.gameserver.ai.L2CharacterAI.maybeMoveToPawn(L2CharacterAI.java:861)
	at net.sf.l2j.gameserver.ai.L2PlayerAI.thinkCast(L2PlayerAI.java:235)
	at net.sf.l2j.gameserver.ai.L2PlayerAI.onEvtThink(L2PlayerAI.java:312)
	at net.sf.l2j.gameserver.ai.L2CharacterAI.onEvtArrived(L2CharacterAI.java:638)
	at net.sf.l2j.gameserver.ai.AbstractAI.notifyEvent(AbstractAI.java:353)
	at net.sf.l2j.gameserver.ai.AbstractAI.notifyEvent(AbstractAI.java:276)
	at net.sf.l2j.gameserver.model.actor.L2Character.moveToLocation(L2Character.java:3577)
	at net.sf.l2j.gameserver.model.actor.L2Character$AIAccessor.moveTo(L2Character.java:2803)
	at net.sf.l2j.gameserver.ai.AbstractAI.moveTo(AbstractAI.java:510)
	at net.sf.l2j.gameserver.ai.AbstractAI.moveToPawn(AbstractAI.java:467)
	at net.sf.l2j.gameserver.ai.L2CharacterAI.maybeMoveToPawn(L2CharacterAI.java:861)
	at net.sf.l2j.gameserver.ai.L2PlayerAI.thinkCast(L2PlayerAI.java:235)
	at net.sf.l2j.gameserver.ai.L2PlayerAI.onEvtThink(L2PlayerAI.java:312)
	at net.sf.l2j.gameserver.ai.L2CharacterAI.onEvtArrived(L2CharacterAI.java:638)
	at net.sf.l2j.gameserver.ai.AbstractAI.notifyEvent(AbstractAI.java:353)
	at net.sf.l2j.gameserver.ai.AbstractAI.notifyEvent(AbstractAI.java:276)
	at net.sf.l2j.gameserver.model.actor.L2Character.moveToLocation(L2Character.java:3577)
	at net.sf.l2j.gameserver.model.actor.L2Character$AIAccessor.moveTo(L2Character.java:2803)
------------------------------AFTER 993 ROWS OF THIS LOOP-----------------------------------
	at net.sf.l2j.gameserver.ai.AbstractAI.moveTo(AbstractAI.java:510)
	at net.sf.l2j.gameserver.ai.AbstractAI.moveToPawn(AbstractAI.java:467)
	at net.sf.l2j.gameserver.ai.L2CharacterAI.maybeMoveToPawn(L2CharacterAI.java:861)
	at net.sf.l2j.gameserver.ai.L2PlayerAI.thinkCast(L2PlayerAI.java:235)
	at net.sf.l2j.gameserver.ai.L2PlayerAI.onEvtThink(L2PlayerAI.java:312)
	at net.sf.l2j.gameserver.ai.L2CharacterAI.onEvtArrived(L2CharacterAI.java:638)
	at net.sf.l2j.gameserver.ai.AbstractAI.notifyEvent(AbstractAI.java:353)
	at net.sf.l2j.gameserver.ai.AbstractAI.notifyEvent(AbstractAI.java:276)
	at net.sf.l2j.gameserver.model.actor.L2Character.moveToLocation(L2Character.java:3577)
	at net.sf.l2j.gameserver.model.actor.L2Character$AIAccessor.moveTo(L2Character.java:2803)
	at net.sf.l2j.gameserver.ai.AbstractAI.moveTo(AbstractAI.java:510)
	at net.sf.l2j.gameserver.ai.AbstractAI.moveToPawn(AbstractAI.java:467)

Also this loop start from:

Exception in thread "AISTPool-9" java.lang.StackOverflowError
	at net.sf.l2j.gameserver.model.actor.stat.CharStat.getRunSpeed(CharStat.java:427)
	at net.sf.l2j.gameserver.model.actor.stat.PlayableStat.getRunSpeed(PlayableStat.java:168)
	at net.sf.l2j.gameserver.model.actor.stat.PcStat.getRunSpeed(PcStat.java:333)
	at net.sf.l2j.gameserver.model.actor.stat.CharStat.getMoveSpeed(CharStat.java:543)
	at net.sf.l2j.gameserver.model.actor.L2Character.moveToLocation(L2Character.java:3514)
	at net.sf.l2j.gameserver.model.actor.L2Character$AIAccessor.moveTo(L2Character.java:2803)
	at net.sf.l2j.gameserver.ai.AbstractAI.moveTo(AbstractAI.java:510)

Exception in thread "AISTPool-7" java.lang.StackOverflowError
	at net.sf.l2j.gameserver.model.zone.L2ZoneType.revalidateInZone(L2ZoneType.java:141)
	at net.sf.l2j.gameserver.model.L2WorldRegion.revalidateZones(L2WorldRegion.java:84)
	at net.sf.l2j.gameserver.model.actor.instance.L2PcInstance.revalidateZone(L2PcInstance.java:1406)
	at net.sf.l2j.gameserver.ai.L2CharacterAI.onEvtArrived(L2CharacterAI.java:623)
	at net.sf.l2j.gameserver.ai.AbstractAI.notifyEvent(AbstractAI.java:353)
	at net.sf.l2j.gameserver.ai.AbstractAI.notifyEvent(AbstractAI.java:276)
	at net.sf.l2j.gameserver.model.actor.L2Character.moveToLocation(L2Character.java:3577)
	at net.sf.l2j.gameserver.model.actor.L2Character$AIAccessor.moveTo(L2Character.java:2803)
	at net.sf.l2j.gameserver.ai.AbstractAI.moveTo(AbstractAI.java:510)


Exception in thread "AISTPool-6" java.lang.StackOverflowError
	at net.sf.l2j.gameserver.model.actor.L2Character.getDEX(L2Character.java:5360)
	at net.sf.l2j.gameserver.skills.funcs.FuncMoveSpeed.calc(FuncMoveSpeed.java:39)
	at net.sf.l2j.gameserver.skills.Calculator.calc(Calculator.java:135)
	at net.sf.l2j.gameserver.model.actor.stat.CharStat.calcStat(CharStat.java:74)
	at net.sf.l2j.gameserver.model.actor.stat.CharStat.getRunSpeed(CharStat.java:427)
	at net.sf.l2j.gameserver.model.actor.stat.PlayableStat.getRunSpeed(PlayableStat.java:168)
	at net.sf.l2j.gameserver.model.actor.stat.PcStat.getRunSpeed(PcStat.java:333)
	at net.sf.l2j.gameserver.model.actor.stat.CharStat.getMoveSpeed(CharStat.java:543)
	at net.sf.l2j.gameserver.model.actor.L2Character.moveToLocation(L2Character.java:3514)
	at net.sf.l2j.gameserver.model.actor.L2Character$AIAccessor.moveTo(L2Character.java:2803)
	at net.sf.l2j.gameserver.ai.AbstractAI.moveTo(AbstractAI.java:510)
	at net.sf.l2j.gameserver.ai.AbstractAI.moveToPawn(AbstractAI.java:467)
  • 0
Posted

I didn't change anything related to DEX / Speed / Zones.

I have no idea where that happened.

aCis, latest revision.

 

Here are the lines:

 

1) net.sf.l2j.gameserver.model.actor.stat.CharStat.getRunSpeed(CharStat.java:427)

	/**
	 * @return the RunSpeed (base+modifier) of the L2Character in function of the Armour Expertise Penalty.
	 */
	public int getRunSpeed()
	{
		return (int) calcStat(Stats.RUN_SPEED, _activeChar.getTemplate().getBaseRunSpd(), null, null);
	}

2) net.sf.l2j.gameserver.model.zone.L2ZoneType.revalidateInZone(L2ZoneType.java:141)

		// If the character can't be affected by this zone return
		if (!isAffected(character))
			return;			

3) net.sf.l2j.gameserver.model.actor.L2Character.getDEX(L2Character.java:5360)

	public int getDEX()
	{
		return getStat().getDEX();
	}
	/**
	 * @return the DEX of the L2Character (base+modifier).
	 */
	public final int getDEX()
	{
		return (int) calcStat(Stats.STAT_DEX, _activeChar.getTemplate().getBaseDEX(), null, null);
	}

4) net.sf.l2j.gameserver.model.actor.L2Character.moveToLocation(L2Character.java:3514)

	public void moveToLocation(int x, int y, int z, int offset)
	{
		// get movement speed of character
		float speed = getStat().getMoveSpeed(); // line 3514
		if (speed <= 0 || isMovementDisabled())
			return;
		
	public int getMoveSpeed()
	{
		if (_activeChar == null)
			return 1;
		
		if (_activeChar.isRunning())
			return getRunSpeed();
		
		return getWalkSpeed();
	}

5)net.sf.l2j.gameserver.model.L2WorldRegion.revalidateZones(L2WorldRegion.java:84)

		for (L2ZoneType z : getZones())
		{
			if (z != null)
				z.revalidateInZone(character); //line 84
		}
	public void revalidateInZone(L2Character character)
	{
		// If the character can't be affected by this zone return
		if (!isAffected(character))
			return;			
		
		// If the object is inside the zone...
		if (isInsideZone(character.getX(), character.getY(), character.getZ()))
		{
			// Was the character not yet inside this zone?
			if (!_characterList.contains(character))
			{
				List<Quest> quests = getQuestByEvent(QuestEventType.ON_ENTER_ZONE);
				if (quests != null)
				{
					for (Quest quest : quests)
						quest.notifyEnterZone(character, this);
				}
				_characterList.add(character);
				onEnter(character);
			}
		}
		else
		{
			// Was the character inside this zone?
			if (_characterList.contains(character))
			{
				List<Quest> quests = getQuestByEvent(QuestEventType.ON_EXIT_ZONE);
				if (quests != null)
				{
					for (Quest quest : quests)
						quest.notifyExitZone(character, this);
				}
				_characterList.remove(character);
				onExit(character);
			}
		}
	}
  • 0
Posted

you attatch the patches yourself when you updating acis?

if yes you might did this by mistake

i cant think anything else better ask in their forum of what happent

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

    • EspadaWorld Reborn - Lineage 2 High Five Private Server Official Website: https://l2espadaworld.com   GitHub Presentation: https://github.com/worldespada-cloud/EspadaWorld   About EspadaWorld Reborn   EspadaWorld Reborn is a cinematic Lineage 2 High Five private server project built on a customized FandC / L2J-style High Five core. The project is focused on balanced gameplay, PvP competition, PvE progression, custom systems, vote rewards, rankings, protection integration, website features, and long-term stability. EspadaWorld is not a clean stock pack. The server has been extended with custom systems, website integration, vote reward logic, protection-related modules, custom instance content, gameplay improvements, and server-side adjustments. Server Foundation Chronicle: Lineage 2 High Five Base: FandC High Five core, heavily customized Core style: L2J-based server architecture Build system: Apache Ant Java target: Java 25 Database: MySQL Project type: Active development / production server environment Main Features - Custom Lineage 2 High Five server environment - FandC-based core with custom improvements - Custom Community Board systems - Player ranking systems - PvP-focused gameplay logic - PvE progression support - Custom Espada instance and custom gameplay content - Vote reward system with multiple vote website integrations - Unified .getreward command - Website, account, ranking, vote, media, and download integration - Protection module integration - Admin tools and server management systems - Datapack and server packaging scripts Vote Reward System EspadaWorld includes a custom vote reward flow based around the .getreward command. The system verifies votes from all enabled vote websites and gives one unified global reward only after all required votes are confirmed. Current vote integration includes: - iTopZ - HopZone - L2Network - L2JBrasil - L2TopZone - L2Votes Vote system features: - Unified reward after all votes are confirmed - Configurable global reward list - Item amount and chance configuration - Cooldown / reuse protection - HWID / IP-based reward protection - Debug logging for vote verification - Anti-abuse logic for repeated reward claims Protection & Security The project includes protection-related modules and integration points designed to improve server and client-side security. Protection-related areas include: - Runtime protection module integration - Client protection support - Server-side validation systems - Anti-abuse logic around vote rewards and account actions - Configuration-driven security behavior - Release packaging support for protected builds Private protection details, keys, internal configuration, and production security data are not public. Custom Gameplay Content EspadaWorld Reborn includes custom gameplay work designed to give the server its own identity while keeping the Lineage 2 High Five feeling. Examples of custom content and systems: - Custom Espada instance - PvP-oriented systems and zones - PvE progression systems - Ranking and competition systems - Community Board extensions - Custom HTML and datapack content - Gameplay scripts and server-side feature extensions - Vote reward progression Website & Community Platform EspadaWorld also includes a modern web platform connected to the server community. Website features include: - Modern responsive website - Account panel - Download section - Vote section - Ranking pages - Media section - News and information system - Admin-controlled website settings - Theme/template system - SEO optimization - Performance optimization The website has been optimized for speed, accessibility, best practices, and SEO, offering a clean public presentation for the server and community. Useful Links Website: https://l2espadaworld.com   GitHub Presentation: https://github.com/worldespada-cloud/EspadaWorld   EspadaWorld Reborn is a cinematic Lineage 2 High Five private server project built on a customized FandC-based core.
    • Hi,im looking for "stable" mid rate high five l2j files source included,i prefer not clean files but something already used by another server in the past,if you have something intrested and not shared pm me.
    • Hello, We are currently looking for an experienced Lineage 2 High Five client developer for our project EldoriaWorld. At the moment we need help with: High Five client edits Launcher integration Interface/UI improvements Branding changes Textures/icons/loading screens System modifications Client optimization We already have website, launcher setup and server infrastructure prepared. If interested, please message me with: your experience previous projects/work contact details Contact: Telegram: FrankJan Discord: LosBanannos Regards, Frank EldoriaWorld
    • Hi guys, I am interested. Added you on Telegram. Please reply.
  • 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..