Jump to content
  • 0

Error no ChamberOfProphecies (Prelude Of War)Mobius


Question

Posted

I need help for this error on mobius 

Logs:

Spoiler

fev. 05, 2020 6:39:58 PM org.l2jmobius.gameserver.model.quest.Quest showError
WARNING: C:\Users\Administrator\Documents\L2J_Prime\game\data\scripts\instances\ChamberOfProphecies\ChamberOfProphecies.java
java.lang.NullPointerException
   at instances.ChamberOfProphecies.ChamberOfProphecies.onAdvEvent(ChamberOfProphecies.java:91)
   at org.l2jmobius.gameserver.model.quest.Quest.notifyEvent(Quest.java:586)
   at org.l2jmobius.gameserver.model.quest.QuestTimer$ScheduleTimerTask.run(QuestTimer.java:47)
   at org.l2jmobius.commons.concurrent.RunnableWrapper.run(RunnableWrapper.java:38)
   at java.base/java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:515)
   at java.base/java.util.concurrent.FutureTask.runAndReset(FutureTask.java:305)
   at java.base/java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:305)
   at java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1130)
   at java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:630)
   at java.base/java.lang.Thread.run(Thread.java:832)

fev. 05, 2020 6:39:58 PM org.l2jmobius.gameserver.model.quest.Quest showError
WARNING: C:\Users\Administrator\Documents\L2J_Prime\game\data\scripts\instances\ChamberOfProphecies\ChamberOfProphecies.java
java.lang.NullPointerException
   at instances.ChamberOfProphecies.ChamberOfProphecies.onAdvEvent(ChamberOfProphecies.java:91)
   at org.l2jmobius.gameserver.model.quest.Quest.notifyEvent(Quest.java:586)
   at org.l2jmobius.gameserver.model.quest.QuestTimer$ScheduleTimerTask.run(QuestTimer.java:47)
   at org.l2jmobius.commons.concurrent.RunnableWrapper.run(RunnableWrapper.java:38)
   at java.base/java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:515)
   at java.base/java.util.concurrent.FutureTask.runAndReset(FutureTask.java:305)
   at java.base/java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:305)
   at java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1130)
   at java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:630)
   at java.base/java.lang.Thread.run(Thread.java:832)

 

GS show erro log and it:

Spoiler

[05/02 18:44:43] Wrong reschedule for CeremonyOfChaosManager end up run in 16 seconds!
[05/02 18:44:55] Wrong reschedule for CeremonyOfChaosManager end up run in 4 seconds!
[05/02 18:44:59] Wrong reschedule for CeremonyOfChaosManager end up run in 0 seconds!
[05/02 18:49:47] Wrong reschedule for CeremonyOfChaosManager end up run in 12 seconds!
[05/02 18:49:57] Wrong reschedule for CeremonyOfChaosManager end up run in 2 seconds!
[05/02 18:49:59] Wrong reschedule for CeremonyOfChaosManager end up run in 0 seconds!
[05/02 18:51:49] Wrong reschedule for CeremonyOfChaosManager end up run in 10 seconds!
[05/02 18:51:56] Wrong reschedule for CeremonyOfChaosManager end up run in 3 seconds!
[05/02 18:51:59] Wrong reschedule for CeremonyOfChaosManager end up run in 0 seconds!
[05/02 18:52:50] Wrong reschedule for CeremonyOfChaosManager end up run in 9 seconds!
[05/02 18:52:57] Wrong reschedule for CeremonyOfChaosManager end up run in 2 seconds!
[05/02 18:52:59] Wrong reschedule for CeremonyOfChaosManager end up run in 0 seconds!

 

Java CODE:

Spoiler

/*
 * This file is part of the L2J Mobius project.
 * 
 * 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 instances.ChamberOfProphecies;

import org.l2jmobius.gameserver.ai.CtrlIntention;
import org.l2jmobius.gameserver.enums.ChatType;
import org.l2jmobius.gameserver.model.Location;
import org.l2jmobius.gameserver.model.World;
import org.l2jmobius.gameserver.model.actor.Attackable;
import org.l2jmobius.gameserver.model.actor.Creature;
import org.l2jmobius.gameserver.model.actor.Npc;
import org.l2jmobius.gameserver.model.actor.instance.MonsterInstance;
import org.l2jmobius.gameserver.model.actor.instance.PlayerInstance;
import org.l2jmobius.gameserver.model.instancezone.Instance;
import org.l2jmobius.gameserver.model.quest.QuestState;
import org.l2jmobius.gameserver.network.NpcStringId;
import org.l2jmobius.gameserver.network.SystemMessageId;
import org.l2jmobius.gameserver.network.serverpackets.ExShowScreenMessage;
import org.l2jmobius.gameserver.network.serverpackets.ExShowUsm;
import org.l2jmobius.gameserver.network.serverpackets.NpcSay;
import org.l2jmobius.gameserver.network.serverpackets.PlaySound;
import org.l2jmobius.gameserver.network.serverpackets.SystemMessage;

import instances.AbstractInstance;
import quests.Q10753_WindsOfFateChoices.Q10753_WindsOfFateChoices;

/**
 * Chamber of Prophecies instance.
 * @author Gigi, Mobius
 */
public class ChamberOfProphecies extends AbstractInstance
{
    // NPCs
    private static final int KAIN_VAN_HALTER = 31639;
    private static final int VAN_HALTER = 33999;
    private static final int FERIN = 34001;
    private static final int GRAIL = 33996;
    private static final int MYSTERIOUS_WIZARD = 33980;
    // Misc
    private static final int DOOR_2 = 17230102;
    private static final int DOOR_3 = 17230103;
    private static final int DOOR_4 = 17230104;
    private static final int TEMPLATE_ID = 255;
    private static final int PROPHECY_MACHINE = 39540;
    private static final int ATELIA = 39542;
    private static final Location FIRST_ROOM_LOC = new Location(-88503, 184754, -10440, 48891);
    
    public ChamberOfProphecies()
    {
        super(TEMPLATE_ID);
        addStartNpc(KAIN_VAN_HALTER);
        addFirstTalkId(KAIN_VAN_HALTER, GRAIL, MYSTERIOUS_WIZARD);
        addTalkId(KAIN_VAN_HALTER, GRAIL, MYSTERIOUS_WIZARD);
        addSeeCreatureId(FERIN);
        addSeeCreatureId(VAN_HALTER);
    }
    
    @Override
    public String onAdvEvent(String event, Npc npc, PlayerInstance player)
    {
        String htmltext = null;
        if (event.equals("enterInstance"))
        {
            final QuestState qs = player.getQuestState(Q10753_WindsOfFateChoices.class.getSimpleName());
            if (qs != null)
            {
                enterInstance(player, npc, TEMPLATE_ID);
                if (hasQuestItems(player, PROPHECY_MACHINE))
                {
                    takeItems(player, PROPHECY_MACHINE, 1);
                }
                qs.setCond(16, true);
            }
        }
        else
        {
            final Instance world = npc.getInstanceWorld();
            if (!isInInstance(world))
            {
                return null;
            }
            
            switch (event)
            {
                case "31639-01.html":
                case "33996-01.html":
                case "33980-01.html":
                case "33980-02.html":
                {
                    htmltext = event;
                    break;
                }
                case "33996-02.html":
                {
                    world.broadcastPacket(ExShowUsm.USM_Q015_E); // TODO not show usim movie
                    world.despawnGroup("q10753_16_instance_grail");
                    world.spawnGroup("q10753_16_instance_wizard");
                    giveItems(player, ATELIA, 1);
                    showOnScreenMsg(player, NpcStringId.TALK_TO_THE_MYSTERIOUS_WIZARD, ExShowScreenMessage.TOP_CENTER, 6000);
                    htmltext = event;
                    break;
                }
                case "33980-03.html":
                {
                    showOnScreenMsg(player, NpcStringId.THIS_CHOICE_CANNOT_BE_REVERSED, ExShowScreenMessage.TOP_CENTER, 6000);
                    htmltext = event;
                    break;
                }
                case "33980-04.html":
                {
                    showOnScreenMsg(player, NpcStringId.THIS_CHOICE_CANNOT_BE_REVERSED, ExShowScreenMessage.TOP_CENTER, 6000);
                    htmltext = event;
                    break;
                }
                case "33980-05.html":
                {
                    world.spawnGroup("q10753_16_instance_halter_2");
                    world.setStatus(6);
                    startQuestTimer("DESPAWN_WIZARD", 2000, npc, player);
                    htmltext = event;
                    break;
                }
                case "status":
                {
                    if (world.isStatus(0))
                    {
                        htmltext = "31639-01.html";
                        break;
                    }
                    htmltext = "31639-02.html";
                    break;
                }
                case "teleport":
                {
                    world.getNpc(FERIN).deleteMe(); // probably needs another npc id for initial room
                    world.spawnGroup("q10753_16_instance_halter_1_1");
                    world.spawnGroup("wof_room1");
                    player.teleToLocation(FIRST_ROOM_LOC);
                    cancelQuestTimers("CHECK_STATUS");
                    startQuestTimer("CHECK_STATUS", 7000, world.getNpc(KAIN_VAN_HALTER), null);
                    break;
                }
                case "CHECK_STATUS":
                {
                    switch (world.getStatus())
                    {
                        case 0:
                        {
                            if (world.getAliveNpcs(MonsterInstance.class).isEmpty())
                            {
                                final PlayerInstance pl = world.getFirstPlayer();
                                startQuestTimer("SEY2", 14000, world.getNpc(FERIN), pl);
                                startQuestTimer("SEY_KAIN", 24000, world.getNpc(VAN_HALTER), pl);
                                startQuestTimer("OPEN_DOOR1", 5000, npc, pl);
                            }
                            startQuestTimer("CHECK_STATUS", 7000, npc, null);
                            break;
                        }
                        case 1:
                        {
                            if (world.getAliveNpcs(MonsterInstance.class).isEmpty())
                            {
                                world.spawnGroup("wof_room2_1");
                                world.setStatus(2);
                            }
                            startQuestTimer("CHECK_STATUS", 7000, npc, null);
                            break;
                        }
                        case 2:
                        {
                            if (world.getAliveNpcs(MonsterInstance.class).isEmpty())
                            {
                                final PlayerInstance pl = world.getFirstPlayer();
                                startQuestTimer("SEY3", 8000, world.getNpc(FERIN), pl);
                                startQuestTimer("OPEN_DOOR2", 5000, npc, pl);
                            }
                            startQuestTimer("CHECK_STATUS", 7000, npc, null);
                            break;
                        }
                        case 3:
                        {
                            if (world.getAliveNpcs(MonsterInstance.class).isEmpty())
                            {
                                world.setStatus(4);
                                world.spawnGroup("wof_room3_2");
                                world.openCloseDoor(DOOR_3, false);
                                startQuestTimer("SEY_KAIN_1", 5000, world.getNpc(VAN_HALTER), world.getFirstPlayer());
                            }
                            startQuestTimer("CHECK_STATUS", 7000, npc, null);
                            break;
                        }
                        case 4:
                        {
                            if (world.getAliveNpcs(MonsterInstance.class).isEmpty())
                            {
                                world.setStatus(5);
                                world.spawnGroup("wof_room4");
                                final PlayerInstance pl = world.getFirstPlayer();
                                startQuestTimer("SEY_KAIN_2", 3000, world.getNpc(VAN_HALTER), pl);
                                startQuestTimer("SEY4", 7000, world.getNpc(FERIN), pl);
                            }
                            else
                            {
                                startQuestTimer("CHECK_STATUS", 7000, npc, null);
                            }
                            break;
                        }
                    }
                    break;
                }
                case "ATTACK":
                case "ATTACK1":
                case "ATTACK2":
                {
                    npc.setRunning();
                    ((Attackable) npc).setCanReturnToSpawnPoint(false);
                    if (npc.isScriptValue(0) && world.getAliveNpcs(MonsterInstance.class).isEmpty())
                    {
                        npc.setTarget(player);
                        npc.getAI().setIntention(CtrlIntention.AI_INTENTION_FOLLOW, player);
                    }
                    else if (npc.getAI().getIntention() != CtrlIntention.AI_INTENTION_ATTACK)
                    {
                        World.getInstance().forEachVisibleObjectInRange(npc, MonsterInstance.class, 3000, monster ->
                        {
                            addAttackDesire(npc, monster);
                            return;
                        });
                    }
                    break;
                }
                case "OPEN_DOOR1":
                {
                    cancelQuestTimers("ATTACK");
                    world.setStatus(1);
                    world.openCloseDoor(DOOR_2, true);
                    world.spawnGroup("wof_room2");
                    break;
                }
                case "OPEN_DOOR2":
                {
                    cancelQuestTimers("ATTACK1");
                    startQuestTimer("ATTACK2", 200, world.getNpc(VAN_HALTER), player, true);
                    world.setStatus(3);
                    world.spawnGroup("wof_room3");
                    world.openCloseDoor(DOOR_3, true);
                    break;
                }
                case "BROADCAST_TEXT":
                {
                    npc.setTarget(player);
                    npc.setRunning();
                    npc.getAI().setIntention(CtrlIntention.AI_INTENTION_FOLLOW, player);
                    npc.broadcastPacket(new NpcSay(npc.getObjectId(), ChatType.NPC_GENERAL, npc.getId(), NpcStringId.THAT_GUY_KAIN_HAS_A_SMARMY_FACE));
                    player.sendPacket(new PlaySound(3, "Npcdialog1.apple_quest_7", 0, 0, 0, 0, 0));
                    break;
                }
                case "SEY2":
                {
                    if (npc.getId() == FERIN)
                    {
                        npc.broadcastPacket(new NpcSay(npc.getObjectId(), ChatType.NPC_GENERAL, npc.getId(), NpcStringId.YOU_CAN_T_DIE_HERE_I_DIDN_T_LEARN_RESURRECT_YET));
                        player.sendPacket(new PlaySound(3, "Npcdialog1.apple_quest_4", 0, 0, 0, 0, 0));
                    }
                    break;
                }
                case "SEY_KAIN":
                {
                    if (npc.getId() == VAN_HALTER)
                    {
                        startQuestTimer("ATTACK1", 200, npc, player, true);
                        npc.broadcastPacket(new NpcSay(npc.getObjectId(), ChatType.NPC_GENERAL, npc.getId(), NpcStringId.GISELLE_WAS_SUCH_A_SWEET_CHILD));
                        player.sendPacket(new PlaySound(3, "Npcdialog1.holter_quest_1", 0, 0, 0, 0, 0));
                    }
                    break;
                }
                case "SEY3":
                {
                    if (npc.getId() == FERIN)
                    {
                        npc.broadcastPacket(new NpcSay(npc.getObjectId(), ChatType.NPC_GENERAL, npc.getId(), NpcStringId.DO_YOU_THINK_I_LL_GROW_TALLER_IF_I_EAT_LOTS_AND_LOTS));
                        player.sendPacket(new PlaySound(3, "Npcdialog1.apple_quest_6", 0, 0, 0, 0, 0));
                    }
                    break;
                }
                case "SEY_KAIN_1":
                {
                    if (npc.getId() == VAN_HALTER)
                    {
                        npc.broadcastPacket(new NpcSay(npc.getObjectId(), ChatType.NPC_GENERAL, npc.getId(), NpcStringId.SUCH_MONSTERS_IN_A_PLACE_LIKE_THIS_UNBELIEVABLE));
                    }
                    break;
                }
                case "SEY_KAIN_2":
                {
                    if (npc.getId() == VAN_HALTER)
                    {
                        npc.broadcastPacket(new NpcSay(npc.getObjectId(), ChatType.NPC_GENERAL, npc.getId(), NpcStringId.THAT_S_THE_MONSTER_THAT_ATTACKED_FAERON_YOU_RE_OUTMATCHED_HERE_GO_AHEAD_I_LL_CATCH_UP));
                        player.sendPacket(new PlaySound(3, "Npcdialog1.holter_quest_6", 0, 0, 0, 0, 0));
                        startQuestTimer("SEY_KAIN_3", 7000, npc, player);
                    }
                    break;
                }
                case "SEY4":
                {
                    if (npc.getId() == FERIN)
                    {
                        npc.broadcastPacket(new NpcSay(npc.getObjectId(), ChatType.NPC_GENERAL, npc.getId(), NpcStringId.GO_NOW_KAIN_CAN_HANDLE_THIS));
                        startQuestTimer("REST", 5000, npc, player);
                        npc.setScriptValue(1);
                    }
                    break;
                }
                case "SEY_KAIN_3":
                {
                    if (npc.getId() == VAN_HALTER)
                    {
                        npc.broadcastPacket(new NpcSay(npc.getObjectId(), ChatType.NPC_GENERAL, npc.getId(), NpcStringId.LEAVE_THIS_TO_ME_GO));
                        startQuestTimer("SEY_KAIN_4", 1000, npc, player);
                        npc.setScriptValue(1);
                    }
                    break;
                }
                case "REST":
                {
                    if (npc.getId() == FERIN)
                    {
                        npc.getAI().setIntention(CtrlIntention.AI_INTENTION_IDLE, player);
                        cancelQuestTimers("BROADCAST_TEXT");
                    }
                    break;
                }
                case "SEY_KAIN_4":
                {
                    world.setStatus(5);
                    world.spawnGroup("q10753_16_instance_grail");
                    showOnScreenMsg(player, NpcStringId.LEAVE_THIS_PLACE_TO_KAIN_NGO_TO_THE_NEXT_ROOM, ExShowScreenMessage.TOP_CENTER, 6000);
                    world.openCloseDoor(DOOR_4, true);
                    cancelQuestTimers("ATTACK2");
                    npc.getAI().setIntention(CtrlIntention.AI_INTENTION_ACTIVE, player);
                    startQuestTimer("CLOSE", 15000, world.getNpc(GRAIL), player);
                    break;
                }
                case "CLOSE":
                {
                    if (player.calculateDistance2D(world.getNpc(GRAIL)) < 390)
                    {
                        world.openCloseDoor(DOOR_4, false);
                        world.despawnGroup("q10753_16_instance_halter_1_1");
                        world.despawnGroup("wof_room4");
                    }
                    else
                    {
                        startQuestTimer("CLOSE", 3000, npc, player);
                    }
                    break;
                }
                case "DESPAWN_WIZARD":
                {
                    world.despawnGroup("q10753_16_instance_wizard");
                    break;
                }
                case "exit":
                {
                    startQuestTimer("finish", 3000, npc, player);
                    player.sendPacket(new SystemMessage(SystemMessageId.THIS_DUNGEON_WILL_EXPIRE_IN_S1_MINUTE_S_YOU_WILL_BE_FORCED_OUT_OF_THE_DUNGEON_WHEN_THE_TIME_EXPIRES).addInt((int) 1.0D));
                    final QuestState qs = player.getQuestState(Q10753_WindsOfFateChoices.class.getSimpleName());
                    if (qs != null)
                    {
                        qs.setCond(17, true);
                    }
                    break;
                }
                case "finish":
                {
                    world.finishInstance(0);
                    break;
                }
            }
        }
        return htmltext;
    }
    
    @Override
    public String onFirstTalk(Npc npc, PlayerInstance player)
    {
        final QuestState qs = player.getQuestState(Q10753_WindsOfFateChoices.class.getSimpleName());
        String htmltext = null;
        switch (npc.getId())
        {
            case KAIN_VAN_HALTER:
            {
                if ((qs != null) && qs.isCond(16))
                {
                    htmltext = "31639.html";
                }
                break;
            }
            case GRAIL:
            {
                htmltext = "33996.html";
                break;
            }
            case MYSTERIOUS_WIZARD:
            {
                if ((qs != null) && qs.isCond(16))
                {
                    htmltext = "33980.html";
                }
                break;
            }
        }
        return htmltext;
    }
    
    @Override
    public String onSeeCreature(Npc npc, Creature creature, boolean isSummon)
    {
        final Instance world = npc.getInstanceWorld();
        if (world != null)
        {
            switch (npc.getId())
            {
                case FERIN:
                {
                    if (creature.isPlayer() && !creature.isDead() && npc.isScriptValue(0))
                    {
                        startQuestTimer("BROADCAST_TEXT", 12000, npc, (PlayerInstance) creature);
                    }
                    break;
                }
                case VAN_HALTER:
                {
                    if (creature.isPlayer() && !creature.isDead() && world.isStatus(0))
                    {
                        startQuestTimer("ATTACK", 2000, npc, (PlayerInstance) creature, true);
                    }
                    break;
                }
            }
        }
        return super.onSeeCreature(npc, creature, isSummon);
    }
    
    public static void main(String[] args)
    {
        new ChamberOfProphecies();
    }
}

 

0 answers to this question

Recommended Posts

There have been no answers to this question yet

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Answer this question...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.



×
×
  • Create New...