Jump to content
  • 0

L2j Problem with L2PCInstance


Question

Posted

i have one problem with l2j gameserver (instances. L2PCinstance) when every player log in game lose all skills active and passive..

 

this is the file (i just added a part of the problem)

 

// Remove a skill from the L2Character and its Func objects from calculator set of the L2Character
        final L2Skill oldSkill = super.removeSkill(skill);
        if (oldSkill != null)
        {
            Connection con = null;
            try
            {
                // Remove or update a L2PcInstance skill from the character_skills table of the database
                con = L2DatabaseFactory.getInstance().getConnection();
                PreparedStatement statement = con.prepareStatement(DELETE_SKILL_FROM_CHAR);
                
                statement.setInt(1, oldSkill.getId());
                statement.setInt(2, getObjectId());
                statement.setInt(3, getClassIndex());
                statement.execute();
                statement.close();
            }
            catch (Exception e)
            {
                _log.log(Level.WARNING, "Error could not delete skill: " + e.getMessage(), e);
            }
            finally
            {
                L2DatabaseFactory.close(con);
            }
        }
        
        if (transformId() > 0 || isCursedWeaponEquipped())
            return oldSkill;
        
        final L2ShortCut[] allShortCuts = getAllShortCuts();
        for (L2ShortCut sc : allShortCuts)
        {
            if ((sc != null) && (skill != null) && (sc.getId() == skill.getId()) && (sc.getType() == L2ShortCut.TYPE_SKILL)
                && !(skill.getId() >= 3080 && skill.getId() <= 3259)) // FIXME: Rough fix for shortcuts of augments getting removed. Find a better way
                deleteShortCut(sc.getSlot(), sc.getPage());
        }
        return oldSkill;
    }
    

 

Here my gameserver errors when i log in - ingame problem:

 

1)l2servproblem1.png

 

2)l2servproblem2.png

 

i hope i gave all the infos to have a respone.. if i am not right reply me what other to upload ... any answer is weclome.

Recommended Posts

  • 0
Posted

here is l2pcinstance that i searched with ctr + h..

 

_log.log(Level.WARNING, "Could not restore character " + this + " skills: " + e.getMessage(), e);

}

finally

{

L2DatabaseFactory.close(con);

}

}

 

/**

* Retrieve from the database all skill effects of this L2PcInstance and add them to the player.

*/

@Override

public void restoreEffects()

{

Connection con = null;

 

try

{

con = L2DatabaseFactory.getInstance().getConnection();

PreparedStatement statement;

ResultSet rset;

 

statement = con.prepareStatement(RESTORE_SKILL_SAVE);

statement.setInt(1, getObjectId());

statement.setInt(2, getClassIndex());

rset = statement.executeQuery();

 

while (rset.next())

{

int effectCount = rset.getInt("effect_count");

int effectCurTime = rset.getInt("effect_cur_time");

long reuseDelay = rset.getLong("reuse_delay");

long systime = rset.getLong("systime");

int restoreType = rset.getInt("restore_type");

 

final L2Skill skill = SkillTable.getInstance().getInfo(rset.getInt("skill_id"), rset.getInt("skill_level"));

if (skill == null)

continue;

 

final long remainingTime = systime - System.currentTimeMillis();

if (remainingTime > 10)

{

disableSkill(skill, remainingTime);

addTimeStamp(skill, reuseDelay, systime);

}

 

/**

*  Restore Type 1

*  The remaning skills lost effect upon logout but

*  were still under a high reuse delay.

*/

if (restoreType > 0)

continue;

 

/**

*  Restore Type 0

*  These skill were still in effect on the character

*  upon logout. Some of which were self casted and

*  might still have had a long reuse delay which also

*  is restored.

*

*/

if (skill.hasEffects())

{

Env env = new Env();

env.player = this;

env.target = this;

env.skill = skill;

L2Effect ef;

for (EffectTemplate et : skill.getEffectTemplates())

{

ef = et.getEffect(env);

if (ef != null)

{

ef.setCount(effectCount);

ef.setFirstTime(effectCurTime);

ef.scheduleEffect();

}

}

}

}

 

rset.close();

statement.close();

 

statement = con.prepareStatement(DELETE_SKILL_SAVE);

statement.setInt(1, getObjectId());

statement.setInt(2, getClassIndex());

statement.executeUpdate();

statement.close();

}

catch (Exception e)

{

_log.log(Level.WARNING, "Could not restore "+this+" active effect data: " + e.getMessage(), e);

}

finally

{

L2DatabaseFactory.close(con);

}

}

Guest
This topic is now closed to further replies.


  • Posts

    • Migrating a legacy Interlude server to PostgreSQL while adding real observability is basically forcing 2006 MMO engineering to attend a 2026 infrastructure conference at gunpoint. PS: which revision of aCis? PS: 🧻what was broken during this whatever you call it.    AAC Guard beign asked to adapt to this be like: - Creating bugs since early 2018
    • OH MY LORDDDDDDDDDDDDDDDDDDDDD   FINALLY
    • 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
    • I came out of my cave as I do once every 5 years. By now, I know nobody really cares about L2, but I still find it fun to experiment. Everything you see here will be free and open source. I have no interest in selling anything.   Long story short, I like to revisit Interlude and apply what I've learned to see how far I can push it. Here's Outerlude, a public fork of aCis for the modern age.   Video demo:   Work that has been done:   Redone the netcode from scratch to be async The NPC AI was completely redone based on Finite State Machines Moved to PostgreSQL and using some of its cool features Lots of config that should be hot reloadable has moved to the database OpenTelemetry instrumentation, where it makes sense, and a Grafana dashboard A built-in REST API for server management A built-in MCP Server for LLMs Nidrah AI, an AI Agent to make managing the server easier Real-time server map view Chat auditing and live snooping A new Fake Players Engine with a Node logic system and a new LLM planner for any behavior Just watch the video   If there is interest in this and I'm happy with it, or I get bored (which I always do), I will open-source it. Let me know what you think and if there is some feature you'd like me to implement.
  • 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..