Jump to content
  • 0

Question

Posted

Hi guys.

 

I have some problems whit a quest, when finish the mission the items dont dissapers from inventory. :mellow:

 

No mistake in GameServer. :-\

 

L2JServer High Five.

 

sorry my bad ingles.

13 answers to this question

Recommended Posts

  • 0
Posted (edited)

Add items ids on registerQuestItems().

 

If you mean on the last condition, some items don't dissapear, fix your script around exitQuest( method uses (care about if there are multiple ways to end the quest).

Edited by Tryskell
  • 0
Posted (edited)

I was checking everything what you have said to me and I don't find anything bad.

 

Check the quest.java and it has his lines well to my seem.
/**
	 * Registers all items that have to be destroyed in case player abort the quest or finish it.
	 * @param items
	 */
	public void registerQuestItems(int... items)
	{
		questItemIds = items;
	}

 

I leave the whole complete code for if someone vee something that I ignore. :-\

 

http://pastebin.com/qAL42YCL

 

sorry my bad ingles.

 

Edited by Sabrent
  • 0
Posted (edited)

Check the code Quest.java again and I found this.

	/**
	 * @return the registered quest items Ids.
	 */
	public int[] getRegisteredItemIds()
	{
		return questItemIds;
	}

	/**
	 * Registers all items that have to be destroyed in case player abort the quest or finish it.
	 * @param items
	 */
	public void RegisteredItemIds(int... items)
	{
		questItemIds = items;
	}

Equally I did what you said to me and it gave to me mistakes in the GameServer with all the quest.

 

I found this chunk of code also in the quest.java and he is the manager also of eliminating the things of the inventory but nothing.

	/**
	 * Remove all quest items associated with this quest from the specified player's inventory.
	 * @param player the player whose quest items to remove
	 */
	public void removeRegisteredQuestItems(L2PcInstance player)
	{
		takeItems(player, -1, questItemIds);
	}

sorry my bad ingles.

Edited by Sabrent
  • 0
Posted

Quest.java

 

Here I leave the quest.java that I use.

 

http://pastebin.com/qAL42YCL

The method 

 

 

 

  1. public boolean takeItems(L2PcInstance player, int itemId, long amount)
  2.         {
  3.                 // Get object item from player's inventory list
  4.                 L2ItemInstance item = player.getInventory().getItemByItemId(itemId);
  5.                 if (item == null)
  6.                 {
  7.                         return false;
  8.                 }
  9.                
  10.                 // Tests on count value in order not to have negative value
  11.                 if ((amount < 0) || (amount > item.getCount()))
  12.                 {
  13.                         amount = item.getCount();
  14.                 }
  15.                
  16.                 // Destroy the quantity of items wanted
  17.                 if (item.isEquipped())
  18.                 {
  19.                         L2ItemInstance[] unequiped = player.getInventory().unEquipItemInBodySlotAndRecord(item.getItem().getBodyPart());
  20.                         InventoryUpdate iu = new InventoryUpdate();
  21.                         for (L2ItemInstance itm : unequiped)
  22.                         {
  23.                                 iu.addModifiedItem(itm);
  24.                         }
  25.                         player.sendPacket(iu);
  26.                         player.broadcastUserInfo();
  27.                 }
  28.                 return player.destroyItemByItemId("Quest", itemId, amount, player, true);
  29.         }

 

Looks fine to me no mistakes.

 

Maybe is visual bug? Maybe updateInventory..

After you finish quest try log out and then login again and check if you still have the items.

maybe the destroyItemByItemId miss a updateInventory or idk.

  • 0
Posted
For example I'm in a Pailaka and I have my scroll weapon updater , I talk with the NPC and look to replace the weapon it does is give me the next leaving the previous there too, at the end of the quest I get all the weapons all of the quest items you use.

 

As in all the server quest , check the Quest.java and compare it to other projects but I see no difference in corresponding to the themes of the quest line items .

 

 Also try to restart the server and PJ when completing the quest to discard a hypothesis that had but remain in the inventory.

  • 0
Posted (edited)

 

For example I'm in a Pailaka and I have my scroll weapon updater , I talk with the NPC and look to replace the weapon it does is give me the next leaving the previous there too, at the end of the quest I get all the weapons all of the quest items you use.
 
As in all the server quest , check the Quest.java and compare it to other projects but I see no difference in corresponding to the themes of the quest line items .
 
 Also try to restart the server and PJ when completing the quest to discard a hypothesis that had but remain in the inventory.

 

Well i cant know if every method of your source is perfect

maybe the destroyItemById no work properly... post the method here (control + left click on it) to open the method

because so far the takeItems() is correct..

 

or you can also check if the RegisterItem is the problem..

make a handler or usercommand or add a line in the quest somewhere

that return the id that registerQuestItems int[] hold.. like

 

for (int number=0 : registerQuestItems)

{

activeChar.sendMessage("Holds:" + number);

}

 

that way you will see after you get the quest if the registerQuestItems contains the quest id's or is empty.. 

if is empty we need check register if not we check the 1st part i said... 

Edited by AccessDenied
  • 0
Posted (edited)
L2Character.java	

public Inventory getInventory()
	{
		return null;
	}
	
	public boolean destroyItemByItemId(String process, int itemId, long count, L2Object reference, boolean sendMessage)
	{
		// Default: NPCs consume virtual items for their skills
		// TODO: should be logged if even happens.. should be false
		return true;
	}
	
	public boolean destroyItem(String process, int objectId, long count, L2Object reference, boolean sendMessage)
	{
		// Default: NPCs consume virtual items for their skills
		// TODO: should be logged if even happens.. should be false
		return true;
	}


 testing other method 

Edited by Sabrent

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.



  • Posts

    • Our sales are ongoing. Bump. 02 July 2025 Telegram: ContactDiscordAccS
    • Our sales are ongoing. Bump. 02 July 2025 Telegram: ContactDiscordAccS
    • just with this extender that I have shared it is not possible to start with c4 client, you have to make some changes to the extender and it works with c4 client perfectly. regarding the updates in this last revision   🔹dll is not packaged with vmprotect   New custom zone types have been added: 🔹 NO_NOBLESS begin MinX=84638 MaxX=92616 MinY=-87170 MaxY=-82018 MinZ=-6000 MaxZ=0 Type=NO_NOBLESS KickOutPos=83007/148057/-3464 end   ▶️ This zone checks if the character is noble. If it does not meet the condition, it will be automatically kicked to the indicated position (KickOutPos). 🔹 CUSTOM_SPAWN_ZONE begin MinX=77275 MaxX=85704 MinY=10122 MaxY=18066 MinZ=-8000 MaxZ=5000 Type=CUSTOM_SPAWN_ZONE OutPos=83007/148057/-3464 Spawns={{82984/18066/-5256}};{{79275/15147/-5248}};{{82922/14263/-5256}};{{83704/10122/-5288}} end ▶️ This zone allows characters, upon death, to respawn with full buff, CP, HP and MP if they press “Fixed”. They will only be able to revive in one of the positions defined in Spawns. 🔧 Both zones are fully configurable from territorydata.txt 🔧 Development Repository (SVN) GX-EXT supports open, collaborative, and professional development. That’s why we provide access to our public SVN repository where you can:   ✅ Compile your own version of the project ✅ Optimize and extend its features ✅ Learn from real production-quality source code   🔒 Delayed access: The repository is always 2 months behind the latest commercial release to prevent unauthorized reselling.   🔗 SVN URL: https://svn.l2servers.com.ar/!/#GX-EXT_INTERLUDE Username: gx Password: gx   You can use tools like TortoiseSVN to download and work with the code.
    • Could you tell me what changed in this update?   more one question: Is it possible to log in through the c4 client instead of interlude? That would be great  
    • ➡ Discount for your purchase: JULY2025 (11% discount) ➡ Our Online Shop: https://socnet.store  ➡ Our SMM-Boosting Panel: https://socnet.pro  ➡ Telegram Shop Bot: https://socnet.shop  ➡ Telegram Support: https://t.me/solomon_bog  ➡ Telegram Channel: https://t.me/accsforyou_shop  ➡ Discord Support: @AllSocialNetworksShop  ➡ Discord Server: https://discord.gg/y9AStFFsrh  ➡ WhatsApp Support: https://wa.me/79051904467 ➡ WhatsApp Channel: https://whatsapp.com/channel/0029Vau0CMX002TGkD4uHa2n  ➡ Email Support: solomonbog@socnet.store 
  • 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