Jump to content

Recommended Posts

Posted
### Eclipse Workspace Patch 1.0
#P L2jfreecore_trunk
Index: src/main/java/com/l2jfree/Config.java
===================================================================
--- src/main/java/com/l2jfree/Config.java	(revision 4957)
+++ src/main/java/com/l2jfree/Config.java	(working copy)
@@ -986,6 +986,7 @@
	public static boolean			DEVELOPER;													// Enable/disable DEVELOPER TREATMENT
	public static boolean			TEST_KNOWNLIST			= false;							// Internal properties for developers tests only
	public static boolean			ALLOW_WEDDING;
+	public static boolean           ALLOW_MAMMON_VOICE;
	public static boolean			SERVER_LIST_BRACKET;										// Displays [] in front of server name ?
	public static boolean			SERVER_LIST_CLOCK;											// Displays a clock next to the server name ?
	public static boolean			SERVER_LIST_TESTSERVER;									// Display test server in the list of servers ?
@@ -1180,6 +1181,7 @@
			ALLOW_PET_WALKERS = Boolean.parseBoolean(optionsSettings.getProperty("AllowPetWalkers", "False"));
			ALLOW_CURSED_WEAPONS = Boolean.parseBoolean(optionsSettings.getProperty("AllowCursedWeapons", "False"));
			ALLOW_WEDDING = Boolean.parseBoolean(optionsSettings.getProperty("AllowWedding", "False"));
+			ALLOW_MAMMON_VOICE = Boolean.parseBoolean(optionsSettings.getProperty("AllowMammonVoice", "False"));
			ALLOW_GUARDS = Boolean.parseBoolean(optionsSettings.getProperty("AllowGuards", "False"));

			DEFAULT_GLOBAL_CHAT = ChatMode.valueOf(optionsSettings.getProperty("GlobalChat", "REGION").toUpperCase());
Index: src/main/java/com/l2jfree/gameserver/handler/VoicedCommandHandler.java
===================================================================
--- src/main/java/com/l2jfree/gameserver/handler/VoicedCommandHandler.java	(revision 4861)
+++ src/main/java/com/l2jfree/gameserver/handler/VoicedCommandHandler.java	(working copy)
@@ -48,6 +48,10 @@
		registerVoicedCommandHandler(new CastleDoors());
		registerVoicedCommandHandler(new Hellbound());
		registerVoicedCommandHandler(new VersionInfo());
+		if (Config.ALLOW_MAMMON_VOICE)
+		{
+		registerVoicedCommandHandler(new Mammon());
+		}
		if (Config.ALLOW_WEDDING)
		{
			registerVoicedCommandHandler(new Wedding());
Index: src/main/java/com/l2jfree/gameserver/handler/voicedcommandhandlers/Mammon.java
===================================================================
--- src/main/java/com/l2jfree/gameserver/handler/voicedcommandhandlers/Mammon.java	(revision 0)
+++ src/main/java/com/l2jfree/gameserver/handler/voicedcommandhandlers/Mammon.java	(revision 0)
@@ -0,0 +1,107 @@
+/*
+ * 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 com.l2jfree.gameserver.handler.voicedcommandhandlers;
+
+import com.l2jfree.gameserver.SevenSigns;
+import com.l2jfree.gameserver.datatables.SpawnTable;
+import com.l2jfree.gameserver.handler.IVoicedCommandHandler;
+import com.l2jfree.gameserver.instancemanager.TownManager;
+import com.l2jfree.gameserver.model.actor.instance.L2PcInstance;
+import com.l2jfree.gameserver.model.entity.Town;
+import com.l2jfree.gameserver.model.L2Spawn;
+
+
+/*
+ * @author  EverDreaM,Ph@t3
+ */
+
+public class Mammon implements IVoicedCommandHandler
+{
+    private static String[] _voicedCommands = { "mammon", "mmammon", "bmammon" };
+    private String mnearestTown, bnearestTown;
+    private SpawnTable s = SpawnTable.getInstance();
+
+    public boolean useVoicedCommand(String command, L2PcInstance activeChar, String target)
+    {
+        if(command.startsWith("mammon"))
+            return MammonInfo(activeChar);
+        else if(command.startsWith("mmammon"))
+            return MMammonInfo(activeChar);
+        else if(command.startsWith("bmammon"))
+            return BMammonInfo(activeChar);
+        return false;
+    }
+    
+    public boolean initMammon(L2PcInstance activeChar)
+    {
+        if (!SevenSigns.getInstance().isSealValidationPeriod())
+        {
+            activeChar.sendMessage("The competition period is currently in effect.");
+            return false;
+        }
+        else
+        	{
+        	  mnearestTown = findNPCLocTown(SevenSigns.MAMMON_MERCHANT_ID);
+        	  bnearestTown = findNPCLocTown(SevenSigns.MAMMON_BLACKSMITH_ID);
+        	  return true;
+        	}
+    }
+    
+    public String findNPCLocTown(int npcId)
+   	{
+    		String nearestTown = "";
+    		for (L2Spawn spawn : s.getSpawnTable().values())
+    			if (npcId == spawn.getNpcid()) {
+    		Town town = TownManager.getInstance().getClosestTown(spawn.getLocx(), spawn.getLocy(), spawn.getLocz());
+            if (town != null)
+    			nearestTown = TownManager.getInstance().getTownName(town.getTownId());
+    		else
+    			nearestTown = "None";
+    			}
+            return nearestTown;
+			             
+   	}
+    
+    public boolean MammonInfo(L2PcInstance activeChar)
+    {
+    	if (initMammon(activeChar))
+    	{
+            activeChar.sendMessage("The Merchant of Mammon is near " + mnearestTown); 
+        	activeChar.sendMessage("The Blacksmith of Mammon is near " + bnearestTown); 
+    	}	
+    	return true;
+    }
+    public boolean MMammonInfo(L2PcInstance activeChar)
+    {
+    	if (initMammon(activeChar))
+    	{
+            activeChar.sendMessage("The Merchant of Mammon is near " + mnearestTown); 
+    	}	
+    	return true;
+    }
+    public boolean BMammonInfo(L2PcInstance activeChar)
+    {
+    	if (initMammon(activeChar))
+    	{
+        	activeChar.sendMessage("The Blacksmith of Mammon is near " + bnearestTown); 
+    	}	
+    	return true;
+    }
+
+    public String[] getVoicedCommandList()
+    {
+        return _voicedCommands;
+    }
+}
Index: config/options.properties
===================================================================
--- config/options.properties	(revision 4957)
+++ config/options.properties	(working copy)
@@ -330,4 +330,7 @@
EnableJythonShell = False

# Interval in ms to check for deadlocks, 0 to disable
-DeadLockCheck = 10000
\ No newline at end of file
+DeadLockCheck = 10000
+
+#Allow Voice Command Handler for Mammons spawn location
+AllowMammonVoice = False
\ No newline at end of file

Posted

pios apo olous pou dinei ena source code apo allo site dinei kai credits? prwti fora to akouw auto..

 

O.O dld ean kaneis esy ena share edw kai sto paroune se allo forum kai to parusiazoune xwreis credits tha s arese??

 

Einai o sevasmos pou prosfereis ston creator tou code gia tin douleia tou!!

  • 1 month later...

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

    • ## SuperPoint Editor   SuperPoint Editor is a practical visual editor for Lineage II PTS 'SuperPoint.bin' files. It is built for people who need to inspect, fix, rebuild, and draw server routes without digging through binary data by hand.   ### What You Can Do   - Open and edit 'SuperPoint.bin' files. - Export BIN data into a readable TXT format. - Save edited data back into a valid BIN file. - Validate routes before saving. - Work with SuperPoint routes, points, directed connections, and path records in tables. - Add, duplicate, delete, and reorder points. - Create direct and reverse connections between route points. - Automatically generate connections between neighboring points. - Edit raw point coordinates: 'X', 'Y', 'Z', 'Index', and 'Delay'. - Keep route names and internal route data organized. - Use either English or Ukrainian interface language.   ### C4 Server Support   Some C4 servers have 'SuperPoint.bin', but do not have 'superpointinfo.txt' in scripts. The editor supports this case directly. When 'superpointinfo.txt' is not found near the BIN file, the editor can open the BIN in C4 mode. In this mode, 'Fstring ID' is disabled because that value belongs to 'superpointinfo.txt', not to the BIN itself. The editor will not generate or modify 'superpointinfo.txt' while working in this mode. This keeps C4 data clean and avoids creating script files that the server does not actually use.   ### superpointinfo.txt Support   For chronicles that do use 'superpointinfo.txt', the editor can load and synchronize it together with the BIN data. When saving, the editor updates route nodes and coordinates while preserving existing metadata such as: - 'npc_name' - 'move_type' - 'fstring_index' - 'social_number' - 'delay' New nodes are generated with safe default values, so existing script metadata is not accidentally wiped.   ### Geodata Tools   The editor can also open converted geodata '.dat' files and display them as a map. This makes route editing much more visual. You can: - Load geodata and inspect the terrain by layer. - Zoom and pan around the map. - Create a new SuperPoint directly from a map cell. - Draw a route by clicking on the geodata. - Drag existing points to new positions. - Automatically snap 'X/Y' to the selected geo cell. - Use the selected geodata layer to fill the point 'Z'. - See all routes on the map or focus only on the selected one. This is especially useful when building new NPC movement paths or correcting bad route coordinates.   ### Connections and Paths   SuperPoint connections are directional. A connection from point '3' to point '2' is not the same as a connection from point '2' to point '3'. The editor makes this explicit by separating: - route points, - directed connections, - and the actual path records used by each connection. For simple cases, it can create direct path records automatically. For more complex movement, you can edit the path points manually. ### Built for Safe Editing The editor includes validation before saving, so common structural problems can be caught before a broken BIN is produced. It also verifies rebuilt BIN files through the converter engine. The goal is simple: edit quickly, but do not silently damage server data.   ### Unknown Field   This small 'Unknown' field is part of the original BIN structure. Most official-looking files keep it as '0', and for regular route editing there is usually no reason to change it. The editor exposes it so nothing from the BIN is hidden or lost. If you do not know exactly what your server uses it for, keep it at '0'. Download
    • NpcGrp não salva no interlúdio e da crítico quando coloca ele no cliente, já testei ele antes.
  • 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..