aboutsummaryrefslogtreecommitdiff
path: root/Minecraft.World/FlintAndSteelItem.cpp
blob: 18f6bb1846ef9beb5c2b1f3f46dbc4a1c61e2aa3 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
#include "stdafx.h"
#include "net.minecraft.world.entity.player.h"
#include "net.minecraft.world.phys.h"
#include "net.minecraft.world.level.h"
#include "net.minecraft.world.level.tile.h"
#include "net.minecraft.stats.h"
#include "Material.h"
#include "ItemInstance.h"
#include "FlintAndSteelItem.h"
#include "SoundTypes.h"

FlintAndSteelItem::FlintAndSteelItem(int id) : Item( id )
{
	maxStackSize = 1;
	setMaxDamage(64);
}

bool FlintAndSteelItem::useOn(shared_ptr<ItemInstance> instance, shared_ptr<Player> player, Level *level, int x, int y, int z, int face, float clickX, float clickY, float clickZ, bool bTestUseOnOnly) 
{
	// 4J-PB - Adding a test only version to allow tooltips to be displayed
	if (face == 0) y--;
	if (face == 1) y++;
	if (face == 2) z--;
	if (face == 3) z++;
	if (face == 4) x--;
	if (face == 5) x++;
	
	if (!player->mayUseItemAt(x, y, z, face, instance)) return false;

	int targetType = level->getTile(x, y, z);

	if(!bTestUseOnOnly)
	{	
		if (targetType == 0) 
		{
			if( level->getTile(x, y-1, z) == Tile::obsidian_Id )
			{
				if( Tile::portalTile->trySpawnPortal(level, x, y, z, false) )
				{
					player->awardStat(
						GenericStats::portalsCreated(),
						GenericStats::param_noArgs()
						);

					// 4J : WESTY : Added for achievement.
					player->awardStat(GenericStats::InToTheNether(),GenericStats::param_InToTheNether());
				}
			}

			level->playSound(x + 0.5, y + 0.5, z + 0.5, eSoundType_FIRE_NEWIGNITE, 1, random->nextFloat() * 0.4f + 0.8f);
			level->setTileAndUpdate(x, y, z, Tile::fire_Id);
		}

		instance->hurtAndBreak(1, player);
	}
	else
	{
		if(targetType == 0)
		{
			return true;
		}
		else
		{
			return false;
		}
	}

	// 4J-PB - this function shouldn't really return true all the time, but I've added a special case for my test use for the tooltips display
	// and will leave it as is for the game use

	return true;
}