lama-0.8a/
lama-0.8a/data/character/
lama-0.8a/data/class/
lama-0.8a/data/map/
lama-0.8a/data/race/
lama-0.8a/doc/
lama-0.8a/log/
lama-0.8a/src/
lama-0.8a/src/ext/
lama-0.8a/txt/
--[[
    lama is a MUD server made in Lua.
    Copyright (C) 2013 Curtis Erickson

    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/>.
]]

--- Cloneable:MapObject that represents the lowest-level MapObject location on a Map.
-- @author milkmanjack
module("obj.MapTile", package.seeall)

local MapObject	= require("obj.MapObject")

--- Cloneable:MapObject that represents the lowest-level MapObject location on a Map.
-- @class table
-- @name MapTile
-- @field name Name of the MapTile.
-- @field description Complete description of the MapTile.
-- @field x X location.
-- @field y Y location.
-- @field z Z location.
local MapTile	= MapObject:clone()

-- we have a tricky situation here cause MapTiles inherit from MapObjects (which I think I should change).
-- cause MapTiles are the things that MapObjects generally are gonna inhabit, on top of other MapObjects.
-- MapTiles essentially will be the only thing with an x/y/z coordinate, and MapObjects will just borrow those values

-- maptile settings
MapTile.name		= "a void"
MapTile.description	= "a vast, undefineable void..."

-- runtime data
MapTile.x			= 0
MapTile.y			= 0
MapTile.z			= 0

--- Creates a unique contents table per MapObject.
-- Also has the potential to assign a Map and XYZ location.
-- @param map Map to be moved to.
-- @param x X loc to be assigned.
-- @param y Y loc to be assigned.
-- @param z Z loc to be assigned.
function MapTile:initialize()
	self.contents	= {}
end

--- Assigns a complete XYZ location.
-- @param x X location to set.
-- @param y Y location to set.
-- @param z Z location to set.
function MapTile:setXYZLoc(x,y,z)
	self.x = x
	self.y = y
	self.z = z
end

--- MapTiles cannot inhabit any other MapObject, so this simply returns self.
-- @return self
function MapTile:getLoc()
	return self
end

--- Get current x location.
-- @return Current x location.
function MapTile:getX()
	return self.x
end

--- Get current y location.
-- @return Current y location.
function MapTile:getY()
	return self.y
end

--- Get current z location.
-- @return Current z location.
function MapTile:getZ()
	return self.z
end

return MapTile