Jump to content
  • 0

Quest Bug


Sabrent

Question

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.

Link to comment
Share on other sites

13 answers to this question

Recommended Posts

  • 0

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
Link to comment
Share on other sites

  • 0

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
Link to comment
Share on other sites

  • 0

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
Link to comment
Share on other sites

  • 0

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.

Link to comment
Share on other sites

  • 0
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.

Link to comment
Share on other sites

  • 0

 

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
Link to comment
Share on other sites

  • 0
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
Link to comment
Share on other sites

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

    • DISCORD : utchiha_market telegram : https://t.me/utchiha_market SELLIX STORE : https://utchihamkt.mysellix.io/ Join our server for more products : https://discord.gg/hood-services https://campsite.bio/utchihaamkt  
    • Server Rates: » Xp 500x. » Sp 500x. » Aden 500x. » Drop 1x. » PartyXp 2x. » PartySp 2x. » Starting character level -61. Enchant rates: » Safe enchant +4. » Blessed and simple scrolls max enchant (+16). » Crystal scrolls max enchant (+20). » Simple enchant scrolls chance – 65%. » Blessed enchant scrolls chance – 100%. » Crystal enchant scrolls chance – 50% Augmentations: » Mid life stone skill chance – 5%. » High life stone skill chance – 10%. » Top life stone skill chance – 20%. » Augments 1+1 Unique features: » Main town – Giran » Automatic-Manual Potions. » Working 2 castle sieges. (Giran-Aden) » SPS cancel lasts 10 seconds and than buffs come back. » Stackable scrolls, lifestones, book of giants. » Unique pvp zone » More then 11 active raid bosses. » Wedding system. » Unique farming areas. » Npc skill enchanter. » Full npc buffer with auto buff. » Max count of buffs – 55. » Max subclasses – 4. » Free and no quest class change. » Free and no quest sub class. » Raid boss drop nobless item. » No weight limit. » Unique protection anti-hwy armor for archers/daggers etc. » Ingame password change. » Top pvp/pk/online ranks NPC. » Unique monsters & NPC. » Interlude retail skills. » Server up-time [24/7] [99]%. » Perfect class balance (all class can kill all class depending on players skill and setup knowledge,gear,augmentations). » Announcements on double kills triple kills etc. » Announcements on Grand Boss death , with the name of the killer as well as clan name of the player. » Information Npc in game with all servers infromations. Custom server gear : 1). Titanium Armor Lv.1 2). Epic Armor Lv.2 3). Epic Weapons-Kamikaze-Black S grade (Same Stats) 4). Demonic-Angelic Wings-Baium Hair-Custom Accessories (SameStats) 5). Custom Fighter/Mage tattoo Lv1-Lv2-Lv3 6). Shirt (STR,CON,INT +1) 7). Custom Shields Server Commands: .tvtjoin .tvtleave – Join or leave tvt event. .ctfjoin .ctfleave – Join or leave ctf event. .dmjoin .dmleave – Join of leave dm event. .online – current online players count. .repair – repairs stuck character in world. .menu – opens online menu panel. .exit – PVP zone exit in case you are bullied. .changepassword - Opens online menu then u can change ur password in game. .farm - Enable/disable autofarm Event system: » TVT event » CTF event » DM event » Tournament Event » Party Zone » Unique event shop. Olympiad game: » Retail olympiad game. » Competition period [1] week. » Olympiad start time [18:00] end [00:00] GMT+2. » New Heroes every Sunday.
    • Tomorrow grand opening lests go 🙂 
    • New season of Warfire X150 has been postponed to September 28th.
  • Topics

×
×
  • Create New...