Jump to content

Recommended Posts

Posted

statement activeChar.getLevel() >= 1

 

>= biger or Equal

 

< Smaller

> Bigger

<= Smaler-equal

>= Bigger-equal

== Equal (two Equal Symbols)

Posted

this statement activeChar.getLevel() >= 1 you should to be level 0 to use this command ?

lol >= equal or lower

Posted

/java/net/sf/l2j/gameserver/handler/voicedcommandhandlers/newbiegift.java@2

/*
2	 * This program is free software: you can redistribute it and/or modify it under
3	 * the terms of the GNU General Public License as published by the Free Software
4	 * Foundation, either version 3 of the License, or (at your option) any later
5	 * version.
6	 *
7	 * This program is distributed in the hope that it will be useful, but WITHOUT
8	 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
9	 * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
10	 * details.
11	 *
12	 * You should have received a copy of the GNU General Public License along with
13	 * this program. If not, see <http://www.gnu.org/licenses/>.
14	 */
15	package net.sf.l2j.gameserver.handler.voicedcommandhandlers;
16	
17	import net.sf.l2j.gameserver.handler.IVoicedCommandHandler;
18	import net.sf.l2j.gameserver.model.actor.instance.L2PcInstance;
19	import net.sf.l2j.util.Rnd;
20	
21	/**
22	+*
23	+* @author eko
24	+*/
25	public class newbiegift implements IVoicedCommandHandler
26	{
27	        private static final String[] VOICED_COMMANDS = { "newbiegift" };
28	           
29	public boolean useVoicedCommand(String command, L2PcInstance activeChar, String target)
30	{
31	        if (command.equalsIgnoreCase("newbiegift"))
32	        {
33	                if (activeChar.getLevel() >= 1 && activeChar.isNewbie())
34	                {
35	                        activeChar.sendMessage("You are allready Used that Command.");
36	                        return true;
37	                }
38	                else if (activeChar.getInventory().getItemByItemId(3434).getCount() >= 1)
39	                {
40	                        activeChar.getInventory().destroyItemByItemId("newbiegift", 3434, 1, activeChar, activeChar.getTarget());
41	                        // {ItemID, Item Ammount}
42	                int[][] items = { {8557, 1}, {8184, 1}, { 8187, 1}, { 8552, 1}, { 8185, 1}, { 8563, 1}, { 8562, 1}, { 8561, 1}, { 8560, 1} };
43	            // How many Items Aviable on the List
44	                int[] ar = items[Rnd.get(9)];
45	                activeChar.addItem(command,  ar[0], ar[1], activeChar, true);
46	                        activeChar.sendMessage("You Recived a Newbiegift!");
47	            activeChar.broadcastUserInfo();
48	                }
49	                else
50	                {
51	                        activeChar.sendMessage("Missing Coke to Create your Gift.");
52	                        return true;
53	                }
54	        }
55	        return false;
56	}
57	public String[] getVoicedCommandList()
58	{
59	        return VOICED_COMMANDS;
60	}
61	}

this is ok now:/java/net/sf/l2j/Config.java


   public static int L2JMOD_WEDDING_DIVORCE_COSTS; 
884	884	 
	885	    //Newbie Gift Config 
	886	    public static boolean  NewbieGift           = true; 
	887	     
885	888	    // Packet information 
886	889	    /** Count the amount of packets per minute ? */ 
…	…	 
1860	1863	                L2JMOD_WEDDING_DIVORCE_COSTS            = Integer.parseInt(L2JModSettings.getProperty("WeddingDivorceCosts", "20")); 
1861	1864	 
	1865	                //Newbie gift 
	1866	                NewbieGift              = Boolean.parseBoolean(L2JModSettings.getProperty("NewbieGift ", "True")); 
	1867	                 
1862	1868	                if (TVT_EVENT_PARTICIPATION_NPC_ID == 0) 
1863	1869	                { 

2nd part : java/net/sf/l2j/gameserver/GameServer.java

import net.sf.l2j.gameserver.handler.voicedcommandhandlers.Wedding; 
200	200	import net.sf.l2j.gameserver.handler.voicedcommandhandlers.stats; 
	201	import net.sf.l2j.gameserver.handler.voicedcommandhandlers.newbiegift; 
201	202	import net.sf.l2j.gameserver.idfactory.IdFactory; 
202	203	import net.sf.l2j.gameserver.instancemanager.AuctionManager; 
…	…	 
587	588	 
588	589	        _log.config("UserCommandHandler: Loaded " + _userCommandHandler.size() + " handlers."); 
589	 	 
	590	                 
	591	 
	592	                 
590	593	                _voicedCommandHandler = VoicedCommandHandler.getInstance(); 
591	594	                _voicedCommandHandler.registerVoicedCommandHandler(new stats()); 
592	595	 
	596	                if(Config.NewbieGift) 
	597	                        _voicedCommandHandler.registerVoicedCommandHandler(new newbiegift()); 
	598	                 
593	599	                if(Config.L2JMOD_ALLOW_WEDDING) 
594	600	                        _voicedCommandHandler.registerVoicedCommandHandler(new Wedding()); 
	601	 
595	602	 
596	603	                _log.config("VoicedCommandHandler: Loaded " + _voicedCommandHandler.size() + " handlers."); 

Final: /java/config/l2jmods.properties


94	94	#--------------------------------------------------------------- 
	95	# Newbie Gift                     - 
	96	#--------------------------------------------------------------- 
	97	 
	98	NewbieGift=True 
	99	 
	100	#--------------------------------------------------------------- 
95	101	# Team vs. Team Event Engine (by FBIagent)                     - 
96	102	#--------------------------------------------------------------- 

 

 

What about this? :P

Posted

hehe well i dont think you have to put everywhere a config for everything, its easy to change thats why i left it hardcoded

 

anyway make it as a patch and i put it in my topic

Posted

+1 karma from me.

and thanks i need smth like this.

thanks again :)

 

yay! Abusing comes 'n' goes.

Okay, let me see..

 

if (activeChar.getLevel() >= 1 && activeChar.isNewbie())
+		{
+			activeChar.sendMessage("You are allready Used that Command.");
+			return true;
+		}

 

Since when that check defines whether the player has used the command before or not? It can be spammed soo fυcking hard and of course it won't work, since the check you have added is a non-sense level check (jeez, >= 1? A player can't be level 0 -.-) and a isNewbie() check, unrelated with how many times a user has used this command.

 

activeChar.sendMessage("Missing Coke to Create your Gift.");
+			return true;

 

Missing.. whaaa?

 

@FDB: The boolean's value has to be set on False by default. (Non retail shit, just matter of detailed configuration)

 


 

Pretty wrong-coded and kinda useless.

Anyway, keep it up, soon you may come up with something better.

Posted

yay! Abusing comes 'n' goes.

Okay, let me see..

 

if (activeChar.getLevel() >= 1 && activeChar.isNewbie())
+		{
+			activeChar.sendMessage("You are allready Used that Command.");
+			return true;
+		}

 

Since when that check defines whether the player has used the command before or not? It can be spammed soo fυcking hard and of course it won't work, since the check you have added is a non-sense level check (jeez, >= 1? A player can't be level 0 -.-) and a isNewbie() check, unrelated with how many times a user has used this command.

 

activeChar.sendMessage("Missing Coke to Create your Gift.");
+			return true;

 

Missing.. whaaa?

 

@FDB: The boolean's value has to be set on False by default. (Non retail shit, just matter of detailed configuration)

 


 

Pretty wrong-coded and kinda useless.

Anyway, keep it up, soon you may come up with something better.

this statement activeChar.getLevel() >= 1 you should to be level 0 to use this command ?

statement activeChar.getLevel() >= 1

 

>= biger or Equal

 

< Smaller

> Bigger

<= Smaler-equal

>= Bigger-equal

== Equal (two Equal Symbols)

god bless, finally 1 guy

Posted

Ohh coyote you have right if i got it enabled so the config will not work :/ thnks i will correct it on my project

 

@ eKo i will upload patches later

 

 

Posted

Ohh coyote you have right if i got it enabled so the config will not work :/ thnks i will correct it on my project

 

The Config won't work? LoL

I just pointed out a tiny tiny detail, that just has to be fixed in order for the code configuration to meet 'retail criteria'.

Posted

 

if (activeChar.getLevel() >= 1 && activeChar.isNewbie())
+		{
+			activeChar.sendMessage("You are allready Used that Command.");
+			return true;
+		}

 

Since when that check defines whether the player has used the command before or not? It can be spammed soo fυcking hard and of course it won't work, since the check you have added is a non-sense level check (jeez, >= 1? A player can't be level 0 -.-) and a isNewbie() check, unrelated with how many times a user has used this command.

 

that should be

if (activeChar.getLevel() < 1 || !activeChar.isNewbie())

that getLevel() could be to check if there is an error, its usuall to do things like

 

if (error)

activeChar.setLevel() = -1;

 

i could not find any, but maybe in the future some1 will need it

 

 

Of course the msg used is wrong

 

 

another thing that i wont to say is the use of the returns and else if, this is not too much important, but will make it a bit better. You can do

public boolean useVoicedCommand(String command, L2PcInstance activeChar, String target)
{
        if (command.equalsIgnoreCase("newbiegift"))
        {
                if (activeChar.getLevel() >= 1 && activeChar.isNewbie())
                {
                }
                [b]else[/b] if (activeChar.getInventory().getItemByItemId(3434).getCount() >= 1)
                {
                }
                else
                {
                }
                       [b]return true;[/b]
        }
        return false;
}

or

public boolean useVoicedCommand(String command, L2PcInstance activeChar, String target)
{
        if (command.equalsIgnoreCase("newbiegift"))
        {
                if (activeChar.getLevel() >= 1 && activeChar.isNewbie())
                {
                       return true
                }// if the first if was true, it will execute return, so there is no need to use else
                if (activeChar.getInventory().getItemByItemId(3434).getCount() >= 1)
                {
                       return true;
                }
                { //just to see that here goes the last code segment
                       return true;
                }
        }
        return false;
}

i repeat that this is not very important, but, its better to use it this way

Posted

that should be

if (activeChar.getLevel() < 1 || !activeChar.isNewbie())

 

How teh heck could somebody be level 0 or lower?

We are not talking about Access Level, but Character's Level.

And also, the isNewbie is supposed to be "&&" and without the exclamation mark which makes it negative.

The code should actually be

 

if (activeChar.getLevel() == 1 && activeChar.isNewbie())

 

But yet again, the check would not be able to determine whether the command has be used or not.

 

Conclusion: If set like that, the code won't work, but even if you fix this small 'symbols' issue, it will be abused and won't operate normally. So, either way the code won't work as supposed.

Posted

How teh heck could somebody be level 0 or lower?

We are not talking about Access Level, but Character's Level.

And also, the isNewbie is supposed to be "&&" and without the exclamation mark which makes it negative.

The code should actually be

 

if (activeChar.getLevel() == 1 && activeChar.isNewbie())

 

But yet again, the check would not be able to determine whether the command has be used or not.

 

Conclusion: If set like that, the code won't work, but even if you fix this small 'symbols' issue, it will be abused and won't operate normally. So, either way the code won't work as supposed.

 

seems like you didnt even read the code properly.

adenaman is right i put a few errors in it, exclamation mark which makes it negative is right since it checks if the char is the first char or the second. and Normally only the first char is a Newbie.

 

second == dosent work on L2J or at least at my pack thats why <= check if its lvl 0 or lvl 1( or did i learn java wrong at school??).

 

third the code will work only when the player has the item coke

 

anyway gonna update the code,and thanks for those answers(coyote,adaman) it helps me i am not mad more happy since its helpfull to me to get more intro l2j and fix my mistakes so this wont happen again

Guest
This topic is now closed to further replies.



  • Posts

    • I'm using Myext64 HF and recently tried to replicate the "br_xmas09_event" Raising Rudolph Event. Detailed event information can be found at https://legacy-lineage2.com/news/_rudolf_the_red.html After configuring .eventdata.xml and starting the server, t  server log shows: 12/02/2025 15:39:01.809, [NO_ERROR] SpawnEx2 [br_xmas2009_invisible][schuttgart20_npc2213_xs03m1] [1][0][0][0][0][346796390] 12/02/2025 15:39:02.057, DummyPacket received from L2Server 12/02/2025 15:39:02.058, server socket close 312ac(f0820224) error(997) 12/02/2025 15:39:02.058, [CallStack][tid:0][tick:2][0] Begin 12/02/2025 15:39:02.058, [CallStack][tid:0][tick:2][1][0] void __cdecl IOThreadCallback::IOThread_common(void) 12/02/2025 15:39:02.059, [CallStack][tid:0][tick:2][2][1] void IOThread_common 1 12/02/2025 15:39:02.059, [CallStack][tid:0][tick:2][3][2] void __cdecl CIOSocketEx<class CIOBufferEx<16384> >::Close(void) 12/02/2025 15:39:02.059, [CallStack][tid:0][tick:2][4][3] void __cdecl CServerSocket::OnClose(void) 12/02/2025 15:39:02.059, [CallStack][tid:0][tick:2][5] End l2server log: 12/02/2025 15:39:02.112, npc server closed(127.0.0.1) error: 64 read buffer size: (server:0 npc:0) 12/02/2025 15:39:02.112, [NO_ERROR] L2Server is under protection mode!!! 12/02/2025 15:39:02.112, [NO_ERROR] L2Server is under protection mode!!! 12/02/2025 15:39:02.112, [NO_ERROR] L2Server is under protection mode!!! 12/02/2025 15:39:02.131, dwTime[0] < 80 !!!!!!! 12/02/2025 15:39:02.131, [CallStack][tid:7][tick:1][0] Begin 12/02/2025 15:39:02.132, [CallStack][tid:7][tick:1][1][0] void __cdecl IOThreadCallback::IOThread_common(void) 12/02/2025 15:39:02.132, [CallStack][tid:7][tick:1][2][1] void IOThread_common 1 12/02/2025 15:39:02.132, [CallStack][tid:7][tick:1][4][3] void __cdecl NpcSocket::OnClose(void) 12/02/2025 15:39:02.132, [CallStack][tid:7][tick:1][3][2] void __cdecl CIOSocketEx<class CIOBufferEx<16384> >::Close(void) 12/02/2025 15:39:02.132, [CallStack][tid:7][tick:1][5] End 12/02/2025 15:39:31.767, server closed(127.0.0.1) Error: 64 Read buffer size: (server:0 npc:0) 12/02/2025 15:39:31.768, [NO_ERROR] Logout All Characters : 1   The NPC server sent a packet to the L2 server while generating the br_xmas2009_invisible game NPC server, and the NPC server subsequently crashed.     After some digging, I found a clue in a very old MXC post, but the fix was for the GF version. The whole problem is in l2server side support for NPC function CreateOnePrivateNearUser. It sends CreatePacket but Koreans made some changes in it (added instance ID) so it got broken. As Santa event is the only AI that uses this function, they probably don't know about it    So is there a way to fix this problem, specifically for Myext64 HF? I'd be happy to buy him coffee.
    • Offtopic, personal attacks, probably too old to use that much memes and what's YOUR actual contribution to L2J, in order I laugh aswell ?   The main poster quotes my pack so I answer accordingly, while you advertise L2JFrozen in both of your posts - discontinued since 2014 (? 1132 rev), with none taking back the open source lead while anyone could.   If you're somewhat affiliated to hopzone, you probably packed way more money than me. Packs don't make any type of money (barely 100e/month) and if you would follow me, you would know there are ways to handle it or even getting paid.   Hope I was short enough, 🧂🤡.
    • Hi guys, this is a CMS im sharing for lineage 2 servers, im tired of the crap i see on new release servers. Dont let me start on the IA developed ones lmao.   📋 Description Free and open source template to create landing pages for Lineage 2 private servers. Designed with a dark fantasy theme and modern animations. ✨ Current Features This FREE version includes: Complete Landing Page - Professional design ready to use Multi-language Support - Spanish, English, Portuguese Dark Fantasy Theme - With animated UI elements Server Information - Rates, features, and rules Olympiad Ranking - Rankings display Download Section - For game client Skins and Animations Gallery Streaming Widget - Twitch/Kick integration Fully Customizable - Via configuration files ❌ Not Included in Free Version ❌ User Registration System ❌ Online Players Counter ❌ Donation Panel 💎 Premium Integrations IntegrationPrice Registration System $50 USD Online Players Counter $50 USD Donation Panel $50 USD   📧 Contact: https://gh0tstudio.com 🛠️ Tech Stack Technology    Version    Description React              19.2.0       UI Library TypeScript       5.8.2        Static typing Vite                 6.2.0         Build tool TailwindCSS   CDNCSS    Framework Lucide React   0.554.0         Icons i18next           23.16.0       Internationalization react-i18next   15.1.0        React bindings for i18n All documentation provided for AI AGENTS to make changes on the ui texts and so on. u can have a look on the cms fully working with donation panel, online count and register via: https://crmlineage2.vercel.app/ https://github.com/6h0T/CRM-LINEAGE2-FREE If u are in the lookings to develop a unique website for ur projects, u can dm me or contact me throw my socials on my profile. all code has encrypted references so any type of rebranding, copying or selling without authorization will result in take downs
    • Hello dude, i can help u out, i reached to u via DM, my studio is https://gh0tstudio.com i have worked with almost 40 brands on developing Private Lineage and Mu online servers, dashboard for vote pages and more. I sent u some examples too
    • L2 TARTARUS - HTML DESIGN       L2 KOMBAT - ANIMATED BORDER   L2 SERENITY - ANIMATED LOGO   L2 ARCANE - COMMUNITY BOARD     L2 AMERIKA - ADVERTISING BANNER   L2 ZERON - ADVERTISING BANNER  
  • Topics

×
×
  • Create New...

AdBlock Extension Detected!

Our website is made possible by displaying online advertisements to our members.

Please disable AdBlock browser extension first, to be able to use our community.

I've Disabled AdBlock