Jump to content
  • 0

[HELP] IOException error


Question

Posted

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.

8 answers to this question

Recommended Posts

  • 0
Posted

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);
	}
}
}

  • 0
Posted

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.

  • 0
Posted

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.

Guest
This topic is now closed to further replies.


  • Posts

    • L2-LORENA x100 MID RATE   Interlude Nostalgia Meets Modern Gameplay   OFFICIAL OPENING:  April 4 (Saturday)  19:00 UTC+1 ⸻  MAIN INFORMATION  Adena: x5  Drop: x10  Spoil: x10  Raid Boss: x10  Seal Stones: x2  Quests: x10 ⸻  FEATURES  GM Shop up to B-Grade  Full Buffer  Premium System (x2 bonuses)  AutoFarm – FREE for everyone ⸻  SERVER CONCEPT  Classic Interlude nostalgia  Enhanced with modern interface & mechanics  Balanced PvP & PvE gameplay  Active development & custom features ⸻  WHY JOIN L2-LORENA?  No Pay-to-Win  Smooth gameplay & stable server  Competitive PvP environment  Friendly & active community ⸻  JOIN US NOW L2-LORENA 100X <<< LINK Discord: https://discord.gg/TYZ88Tgx4b  Facebook: https://www.facebook.com/share/18kwbkaYZY/?mibextid=wwXIfr   L2-LORENA Link << Discord: https://discord.gg/TYZ88Tgx4b  Facebook: https://www.facebook.com/share/18kwbkaYZY/?mibextid=wwXIfr
    • https://web.archive.org/web/20260306183214/https://maxcheaters.com/topic/241828-l2j-l2damage/page/3/ https://l2topzone.com/forum/l2-server-support-problems/9/l2damage-stopped/30514 Also we will try to push longer seasons ever ! (1135-100)/9 = 115 online
    • ONE SIDE – AND EVERYTHING BREAKS ▪ Looks like a simple case: Florida DL, back side, barcode – “clean and minimal”. ▪ In reality, these are exactly the tasks that fail most often. – data provided as plain text – request only for the back side – focus on the barcode (PDF417) ▪ And here’s the key point: ▪ A barcode is not just a “picture on the back”. It’s compressed logic of the entire document. ▪ If it doesn’t match the front, format, and data structure – the system flags it instantly. ▪ Many create a “similar-looking” code. But systems don’t read “similar” – they read by specification. ▪ In cases like this, it’s not about design. It’s about correct data assembly and how it behaves inside the format. ▪ Today only – 15% off for verification cases. ▪ Want it to pass, not just look right? Describe your case – we’ll show where even clean files break. › TG: @mustang_service ( https:// t.me/ mustang_service ) › Channel: Mustang Service ( https:// t.me/ +JPpJCETg-xM1NjNl ) #editing #photoshop #documents #verification #case
    • Your anonymity is a corpse. Blockchain forgets nothing. Your transactions are direct footprints in the hands of anyone who takes an interest. [✘] Still believe in "mixing"? Forget it. Classic Bitcoin mixers are an illusion of security. For Chainalysis and Elliptic algorithms, any attempt to hide tracks in the ledger is transparent. Your "mixing" is an artifact that gets filtered out in seconds. Every transaction leaves a trail that leads to frozen assets or unwanted questions from exchanges.  We don't mix. We break the link. [-] Input: Your "dirty" coins (Dirty BTC/ETH) with all their history and digital markers stay with us. [+] Output: You receive absolutely clean assets (Clean Crypto) from our reserves, which have never intersected with your past. This isn't a game of hide and seek. This is the surgical removal of your financial history from the system.   ------------------------------------------------------------------- Technical indexing: Bitcoin Mixer, Crypto Mixer, Clean BTC, Clean ETH, Anti-Chainalysis, Best Bitcoin Mixer, Anonymous Crypto Exchange, NoLog Mixing Service.
  • 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..