Jump to content
  • 0

[HELP] IOException error


xEviLxGG3L

Question

Hello,

 

I've been getting an error and I have no idea how to get rid of it, if anyone can just tell me what is causing it...

 

I just want to know what the problem is, I'll try to fix it my self.

 

Ok then, this is my error:

 

Error on loading dimensional rift spawns: java.io.IOException
java.io.IOException
        at com.l2jmod.gameserver.instancemanager.DimensionalRiftManager.loadS
pawns(DimensionalRiftManager.java:149)
        at com.l2jmod.gameserver.L2GameServer.loadSpawns(L2GameServer.java:31
5)
        at com.l2jmod.gameserver.L2GameServer.load(L2GameServer.java:245)
        at com.ll2jmod.gameserver.L2GameServer.main(L2GameServer.java:584)

 

I just how someone will help me with any info, thanks.

Link to comment
Share on other sites

8 answers to this question

Recommended Posts

  • 0

Thanks for your help.

 

This is the entire packet (P.S. the "bad" line is 128):

package com.l2jmod.gameserver.instancemanager;

import java.awt.Polygon;
import java.awt.Shape;
import java.io.File;
import java.io.IOException;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;

import javax.xml.parsers.DocumentBuilderFactory;

import javolution.util.FastList;
import javolution.util.FastMap;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.w3c.dom.Document;
import org.w3c.dom.NamedNodeMap;
import org.w3c.dom.Node;

import com.l2jmod.Config;
import com.l2jmod.database.DatabaseFactory;
import com.l2jmod.gameserver.datatables.NpcTable;
import com.l2jmod.gameserver.datatables.SpawnTable;
import com.l2jmod.gameserver.model.L2ItemInstance;
import com.l2jmod.gameserver.model.L2Spawn;
import com.l2jmod.gameserver.model.actor.L2Npc;
import com.l2jmod.gameserver.model.actor.L2Player;
import com.l2jmod.gameserver.model.entity.DimensionalRift;
import com.l2jmod.gameserver.network.serverpackets.NpcHtmlMessage;
import com.l2jmod.gameserver.templates.actor.L2NpcTemplate;
import com.l2jmod.tools.Rnd;

public class DimensionalRiftManager
{

private static Log _log = LogFactory.getLog(DimensionalRiftManager.class.getName());
private static DimensionalRiftManager _instance;
private final FastMap<Byte, FastMap<Byte, DimensionalRiftRoom>> _rooms = new FastMap<Byte, FastMap<Byte, DimensionalRiftRoom>>();
private final short DIMENSIONAL_FRAGMENT_ITEM_ID = 7079;

public static DimensionalRiftManager getInstance()
{
	if (_instance == null)
		_instance = new DimensionalRiftManager();

	return _instance;
}

public DimensionalRiftRoom getRoom(byte type, byte room)
{
	return _rooms.get(type) == null ? null : _rooms.get(type).get(room);
}

public void loadRooms()
{
	Connection con = null;

	try
	{
		con = DatabaseFactory.getInstance().getConnection();
		PreparedStatement s = con.prepareStatement("SELECT * FROM dimensional_rift");
		ResultSet rs = s.executeQuery();

		while (rs.next())
		{
			// 0 waiting room, 1 recruit, 2 soldier, 3 officer, 4 captain , 5 commander, 6 hero
			byte type = rs.getByte("type");
			byte room_id = rs.getByte("room_id");

			//coords related
			int xMin = rs.getInt("xMin");
			int xMax = rs.getInt("xMax");
			int yMin = rs.getInt("yMin");
			int yMax = rs.getInt("yMax");
			int z1 = rs.getInt("zMin");
			int z2 = rs.getInt("zMax");
			int xT = rs.getInt("xT");
			int yT = rs.getInt("yT");
			int zT = rs.getInt("zT");
			boolean isBossRoom = rs.getByte("boss") > 0;

			if (!_rooms.containsKey(type))
				_rooms.put(type, new FastMap<Byte, DimensionalRiftRoom>());

			_rooms.get(type).put(room_id, new DimensionalRiftRoom(type, room_id, xMin, xMax, yMin, yMax, z1, z2, xT, yT, zT, isBossRoom));
		}

		s.close();
		con.close();
	}
	catch (Exception e)
	{
		_log.warn("Can't load Dimension Rift zones. " + e);
	}
	finally
	{
		try
		{
			con.close();
		}
		catch (Exception e)
		{ /*do nothing */
		}
	}

	int typeSize = _rooms.keySet().size();
	int roomSize = 0;

	for (Byte b : _rooms.keySet())
		roomSize += _rooms.get(b).keySet().size();

	_log.info("DimensionalRiftManager: Loaded " + typeSize + " room types with " + roomSize + " rooms.");
}

  public void loadSpawns()
  {
    int countGood = 0; int countBad = 0;
    try
    {
      DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
      factory.setValidating(false);
      factory.setIgnoringComments(true);

      File file = new File(Config.DATAPACK_ROOT + "/data/dimensionalRift.xml");
      if (!file.exists()) {
        throw new IOException();
      }
      Document doc = factory.newDocumentBuilder().parse(file);

      for (Node rift = doc.getFirstChild(); rift != null; rift = rift.getNextSibling())
      {
        if (!"rift".equalsIgnoreCase(rift.getNodeName()))
          continue;
        for (Node area = rift.getFirstChild(); area != null; area = area.getNextSibling())
        {
          if (!"area".equalsIgnoreCase(area.getNodeName()))
            continue;
          NamedNodeMap attrs = area.getAttributes();
          byte type = Byte.parseByte(attrs.getNamedItem("type").getNodeValue());

          for (Node room = area.getFirstChild(); room != null; room = room.getNextSibling())
          {
            if (!"room".equalsIgnoreCase(room.getNodeName()))
              continue;
            attrs = room.getAttributes();
            byte roomId = Byte.parseByte(attrs.getNamedItem("id").getNodeValue());

            for (Node spawn = room.getFirstChild(); spawn != null; spawn = spawn.getNextSibling())
            {
              if (!"spawn".equalsIgnoreCase(spawn.getNodeName()))
                continue;
              attrs = spawn.getAttributes();
              int mobId = Integer.parseInt(attrs.getNamedItem("mobId").getNodeValue());
              int delay = Integer.parseInt(attrs.getNamedItem("delay").getNodeValue());
              int count = Integer.parseInt(attrs.getNamedItem("count").getNodeValue());

              L2NpcTemplate template = NpcTable.getInstance().getTemplate(mobId);
              if (template == null) _log.warn("Template " + mobId + " not found!");
              if (!this._rooms.containsKey(Byte.valueOf(type))) _log.warn("Type " + type + " not found!");
              else if (!((FastMap)this._rooms.get(Byte.valueOf(type))).containsKey(Byte.valueOf(roomId))) _log.warn("Room " + roomId + " in Type " + type + " not found!");

              for (int i = 0; i < count; i++)
              {
                DimensionalRiftRoom riftRoom = (DimensionalRiftRoom)((FastMap)this._rooms.get(Byte.valueOf(type))).get(Byte.valueOf(roomId));
                int x = riftRoom.getRandomX();
                int y = riftRoom.getRandomY();
                int z = riftRoom.getTeleportCoords()[2];

                if ((template != null) && (this._rooms.containsKey(Byte.valueOf(type))) && (((FastMap)this._rooms.get(Byte.valueOf(type))).containsKey(Byte.valueOf(roomId))))
                {
                  L2Spawn spawnDat = new L2Spawn(template);
                  spawnDat.setAmount(1);
                  spawnDat.setLocx(x);
                  spawnDat.setLocy(y);
                  spawnDat.setLocz(z);
                  spawnDat.setHeading(-1);
                  spawnDat.setRespawnDelay(delay);
                  SpawnTable.getInstance().addNewSpawn(spawnDat, false);
                  ((DimensionalRiftRoom)((FastMap)this._rooms.get(Byte.valueOf(type))).get(Byte.valueOf(roomId))).getSpawns().add(spawnDat);
                  countGood++;
                }
                else
                {
                  countBad++;
                }
              }
            }

          }

        }

      }

    }
    catch (Exception e)
    {
      _log.warn("Error on loading dimensional rift spawns: " + e);
      e.printStackTrace();
    }
    _log.info("DimensionalRiftManager: Loaded " + countGood + " dimensional rift spawns, " + countBad + " errors.");
  }

public void reload()
{
	for (Byte b : _rooms.keySet())
	{
		for (int i : _rooms.get(b).keySet())
		{
			_rooms.get(b).get(i).getSpawns().clear();
		}
		_rooms.get(b).clear();
	}
	_rooms.clear();
	loadRooms();
	loadSpawns();
}

public boolean checkIfInRiftZone(int x, int y, int z, boolean ignorePeaceZone)
{
	if (ignorePeaceZone)
		return _rooms.get((byte) 0).get((byte) 1).checkIfInZone(x, y, z);
	else
		return _rooms.get((byte) 0).get((byte) 1).checkIfInZone(x, y, z) && !_rooms.get((byte) 0).get((byte) 0).checkIfInZone(x, y, z);
}

public boolean checkIfInPeaceZone(int x, int y, int z)
{
	return _rooms.get((byte) 0).get((byte) 0).checkIfInZone(x, y, z);
}

public void teleportToWaitingRoom(L2Player player)
{
	int[] coords = getRoom((byte) 0, (byte) 0).getTeleportCoords();
	player.teleToLocation(coords[0], coords[1], coords[2]);
}

public void start(L2Player player, byte type, L2Npc npc)
{
	boolean canPass = true;
	if (!player.isInParty())
	{
		showHtmlFile(player, "data/html/seven_signs/rift/NoParty.htm", npc);
		return;
	}

	if (player.getParty().getPartyLeaderOID() != player.getObjectId())
	{
		showHtmlFile(player, "data/html/seven_signs/rift/NotPartyLeader.htm", npc);
		return;
	}

	if (player.getParty().isInDimensionalRift())
	{
		handleCheat(player, npc);
		return;
	}

	if (player.getParty().getMemberCount() < Config.RIFT_MIN_PARTY_SIZE)
	{
		NpcHtmlMessage html = new NpcHtmlMessage(npc.getObjectId());
		html.setFile("data/html/seven_signs/rift/SmallParty.htm");
		html.replace("%npc_name%", npc.getName());
		html.replace("%count%", new Integer(Config.RIFT_MIN_PARTY_SIZE).toString());
		player.sendPacket(html);
		return;
	}

	for (L2Player p : player.getParty().getPartyMembers())
		if (!checkIfInPeaceZone(p.getX(), p.getY(), p.getZ()))
			canPass = false;

	if (!canPass)
	{
		showHtmlFile(player, "data/html/seven_signs/rift/NotInWaitingRoom.htm", npc);
		return;
	}

	L2ItemInstance i;
	for (L2Player p : player.getParty().getPartyMembers())
	{
		i = p.getInventory().getItemByItemId(DIMENSIONAL_FRAGMENT_ITEM_ID);

		if (i == null)
		{
			canPass = false;
			break;
		}

		if (i.getCount() > 0)
			if (i.getCount() < getNeededItems(type))
				canPass = false;
	}

	if (!canPass)
	{
		NpcHtmlMessage html = new NpcHtmlMessage(npc.getObjectId());
		html.setFile("data/html/seven_signs/rift/NoFragments.htm");
		html.replace("%npc_name%", npc.getName());
		html.replace("%count%", new Integer(getNeededItems(type)).toString());
		player.sendPacket(html);
		return;
	}

	for (L2Player p : player.getParty().getPartyMembers())
	{
		i = p.getInventory().getItemByItemId(DIMENSIONAL_FRAGMENT_ITEM_ID);
		p.destroyItem("RiftEntrance", i.getObjectId(), getNeededItems(type), null, false);
	}

	new DimensionalRift(player.getParty(), type, (byte) Rnd.get(1, 9));
}

public void killRift(DimensionalRift d)
{
	if (d.getTeleportTimerTask() != null)
		d.getTeleportTimerTask().cancel();
	d.setTeleportTimerTask(null);

	if (d.getTeleportTimer() != null)
		d.getTeleportTimer().cancel();
	d.setTeleportTimer(null);

	if (d.getSpawnTimerTask() != null)
		d.getSpawnTimerTask().cancel();
	d.setSpawnTimerTask(null);

	if (d.getSpawnTimer() != null)
		d.getSpawnTimer().cancel();
	d.setSpawnTimer(null);
}

public class DimensionalRiftRoom
{
	protected final byte _type;
	protected final byte _room;
	private final int _xMin;
	private final int _xMax;
	private final int _yMin;
	private final int _yMax;
	private final int _zMin;
	private final int _zMax;
	private final int[] _teleportCoords;
	private final Shape _s;
	private final boolean _isBossRoom;
	private final FastList<L2Spawn> _roomSpawns;
	protected final FastList<L2Npc> _roomMobs;

	public DimensionalRiftRoom(byte type, byte room, int xMin, int xMax, int yMin, int yMax, int zMin, int zMax, int xT, int yT, int zT, boolean isBossRoom)
	{
		_type = type;
		_room = room;
		_xMin = (xMin + 128);
		_xMax = (xMax - 128);
		_yMin = (yMin + 128);
		_yMax = (yMax - 128);
		_zMin = zMin;
		_zMax = zMax;
		_teleportCoords = new int[] { xT, yT, zT };
		_isBossRoom = isBossRoom;
		_roomSpawns = new FastList<L2Spawn>();
		_roomMobs = new FastList<L2Npc>();
		_s = new Polygon(new int[] { xMin, xMax, xMax, xMin }, new int[] { yMin, yMin, yMax, yMax }, 4);
	}

	public int getRandomX()
	{
		return Rnd.get(_xMin, _xMax);
	}

	public int getRandomY()
	{
		return Rnd.get(_yMin, _yMax);
	}

	public int[] getTeleportCoords()
	{
		return _teleportCoords;
	}

	public boolean checkIfInZone(int x, int y, int z)
	{
		return _s.contains(x, y) && z >= _zMin && z <= _zMax;
	}

	public boolean isBossRoom()
	{
		return _isBossRoom;
	}

	public FastList<L2Spawn> getSpawns()
	{
		return _roomSpawns;
	}

	public void spawn()
	{
		for (L2Spawn spawn : _roomSpawns)
		{
			spawn.doSpawn();
			spawn.startRespawn();
		}
	}

	public void unspawn()
	{
		for (L2Spawn spawn : _roomSpawns)
		{
			spawn.stopRespawn();
			if (spawn.getLastSpawn() != null)
				spawn.getLastSpawn().deleteMe();
		}
	}
}

private int getNeededItems(byte type)
{
	switch (type)
	{
		case 1:
			return Config.RIFT_ENTER_COST_RECRUIT;
		case 2:
			return Config.RIFT_ENTER_COST_SOLDIER;
		case 3:
			return Config.RIFT_ENTER_COST_OFFICER;
		case 4:
			return Config.RIFT_ENTER_COST_CAPTAIN;
		case 5:
			return Config.RIFT_ENTER_COST_COMMANDER;
		case 6:
			return Config.RIFT_ENTER_COST_HERO;
		default:
			return 999999;
	}
}

public void showHtmlFile(L2Player player, String file, L2Npc npc)
{
	NpcHtmlMessage html = new NpcHtmlMessage(npc.getObjectId());
	html.setFile(file);
	html.replace("%npc_name%", npc.getName());
	player.sendPacket(html);
}

public void handleCheat(L2Player player, L2Npc npc)
{
	showHtmlFile(player, "data/html/seven_signs/rift/Cheater.htm", npc);
	if (!player.isGM())
	{
		_log.warn("Player " + player.getName() + "(" + player.getObjectId() + ") was cheating in dimension rift area!");
		player.getGuard().handleIllegalPlayerAction(player, "Warning!! Character " + player.getName() + " tried to cheat in dimensional rift.", Config.DEFAULT_PUNISH);
	}
}
}

Link to comment
Share on other sites

  • 0

Akken stop saying bs :P.

 

1 - it's not an NPE, it's an IOException error.

2 - it's not Archid, it's l2jmod.

 

----

 

About problem you got at line 128 as the topic creator said :

 

     File file = new File(Config.DATAPACK_ROOT + "/data/dimensionalRift.xml");

     if (!file.exists()) {

       throw new IOException();

     }

 

The second line means if the "file" doesn't exists, then throw an error. If you refer to the first line you got the name of the file, "dimensionalRift.xml"

 

To correct, you have to add the file to the good location : data/dimensionalRift.xml, so to the root of data folder.

 

To be simple you miss a file in your datapack named dimensionalRift.xml, and the gameserver doesn't like it and says to you "Hehehe, you miss a file noob ! I powned your ass !". Add the file and it will be fine.

Link to comment
Share on other sites

  • 0

l2jmod is based on the standard archid  i see same errors same shits.... so i solved it like this :D

 

But yes you are right... seems i am 0 skilled

 

Think before you say. Lol.

Link to comment
Share on other sites

  • 0

This pack is a mix of other packs including L2JArchid.

 

Thank all of you for all your help, even for your sarcasm ::)

locked.
Link to comment
Share on other sites

Guest
This topic is now closed to further replies.


  • Posts

    • You claim you thought I was a "serious" person before. Well, maybe you just never took the time to actually know me. People evolve, but I stay true to what I do and believe in. If you’re that hung up on what I’ve been doing, maybe it's time to stop speculating and start focusing on yourself. 🙂
    • Well, at least it's clear that you don't respect the work of others. Secondly, everyone knows that you code nothing. Your group has devs. known that you've asked for a lot of help and code exchange with some well-known BRs. there are chats and I can prove it, then don't come playing the good guy because you're not. So, Celestine, I'm not judging you. I'm saying that I know that your group helped vraekar steal the codes, and I have proof. In the past, I thought you were a serious, good-natured guy, but lately, you're a different person. Your text above speaks for you.
    • What I do or who I work with is none of your concern, and honestly, I couldn't care less. Lately, I've seen a lot of people trying to make a quick buck off scams, so let's not even mention names you wouldn't want them getting upset, right? 🙂  As for the projects I've been involved with, there's a server about to launch that I’m personally waiting for, and when it does, I’ll release the work publicly for free because people deserve better than what these so called "developers" are pushing. I’m not here to defend anyone, but if you had any real knowledge, you’d see how poorly written some of these scripts are. I’ve worked with Vraekar in the past, and I know for a fact he’s never sold anything I’ve created. So before you start running your mouth, ask yourself: why are you even juding me?
    • I didn't even want to touch on your name Celestine, but it took a while to want to protect it, right? But then I say, everyone knows that you and your group helped Vraekar in deobfuscating the interfaces, do you want me to post here the dates and videos of the releases of the OMG and Silence interfaces?, and then see Vraekar's?, do you want?, a blatant copy, even their variable names, the theft is blatant, and you who are an admin here at Max and say you are the right one, helped him decrypt and remove the code obfuscation, everyone knows that, and now you come and tell me that his code is not copied?, if you want I can put all the evidence here and this will be very ugly even for you, since those you helped Vraekar and the interface dev community know this, they know about the thefts, very ugly indeed my friend that you still come and tell such a lie.   ps. And just one more thing, did you say that all the code he wrote? you became a joker? Vraekar doesn't program a single line of code, the guy works as a data analyst, what he learned was to copy and paste ready-made codes, but he doesn't write a single line of code.
    • I'd like to join aCis community but i can't handle the contributions that often due to my job. I'm returning to L2 development after a few years away and it would be awesome getting this source to work. I can (and would like to) contribute with reviews and code now and then (i'm software engineer for global companies), but sadly i can't commit the time.   I have a hard sense of ethical to not not leak anything (my current web project is paid from nkdev even when there's a leaked version floating around.)   Please let me know when/if acceptance through donations is available again. @Tryskell   In the mean time, gl on your project. Sounds amazing.
  • Topics

×
×
  • Create New...