/**
* @file llpathfindingcharacter.cpp
* @brief Definition of a pathfinding character that contains various properties required for havok pathfinding.
* @author Stinson@lindenlab.com
*
* $LicenseInfo:firstyear=2012&license=viewerlgpl$
* Second Life Viewer Source Code
* Copyright (C) 2012, Linden Research, Inc.
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation;
* version 2.1 of the License only.
*
* This library 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
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA
*
* Linden Research, Inc., 945 Battery Street, San Francisco, CA  94111  USA
* $/LicenseInfo$
*/


#include "llviewerprecompiledheaders.h"

#include "llpathfindingcharacter.h"

#include <string>

#include "llpathfindingobject.h"
#include "llsd.h"

#define CHARACTER_CPU_TIME_FIELD   "cpu_time"
#define CHARACTER_HORIZONTAL_FIELD "horizontal"
#define CHARACTER_LENGTH_FIELD     "length"
#define CHARACTER_RADIUS_FIELD     "radius"

//---------------------------------------------------------------------------
// LLPathfindingCharacter
//---------------------------------------------------------------------------

LLPathfindingCharacter::LLPathfindingCharacter(const std::string &pUUID, const LLSD& pCharacterData)
    : LLPathfindingObject(pUUID, pCharacterData),
    mCPUTime(0U),
    mIsHorizontal(false),
    mLength(0.0f),
    mRadius(0.0f)
{
    parseCharacterData(pCharacterData);
}

LLPathfindingCharacter::LLPathfindingCharacter(const LLPathfindingCharacter& pOther)
    : LLPathfindingObject(pOther),
    mCPUTime(pOther.mCPUTime),
    mIsHorizontal(pOther.mIsHorizontal),
    mLength(pOther.mLength),
    mRadius(pOther.mRadius)
{
}

LLPathfindingCharacter::~LLPathfindingCharacter()
{
}

LLPathfindingCharacter& LLPathfindingCharacter::operator =(const LLPathfindingCharacter& pOther)
{
    dynamic_cast<LLPathfindingObject &>(*this) = pOther;

    mCPUTime = pOther.mCPUTime;
    mIsHorizontal = pOther.mIsHorizontal;
    mLength = pOther.mLength;
    mRadius = pOther.mRadius;

    return *this;
}

void LLPathfindingCharacter::parseCharacterData(const LLSD &pCharacterData)
{
    llassert(pCharacterData.has(CHARACTER_CPU_TIME_FIELD));
    llassert(pCharacterData.get(CHARACTER_CPU_TIME_FIELD).isReal());
    mCPUTime = (F32)pCharacterData.get(CHARACTER_CPU_TIME_FIELD).asReal();

    llassert(pCharacterData.has(CHARACTER_HORIZONTAL_FIELD));
    llassert(pCharacterData.get(CHARACTER_HORIZONTAL_FIELD).isBoolean());
    mIsHorizontal = pCharacterData.get(CHARACTER_HORIZONTAL_FIELD).asBoolean();

    llassert(pCharacterData.has(CHARACTER_LENGTH_FIELD));
    llassert(pCharacterData.get(CHARACTER_LENGTH_FIELD).isReal());
    mLength = (F32)pCharacterData.get(CHARACTER_LENGTH_FIELD).asReal();

    llassert(pCharacterData.has(CHARACTER_RADIUS_FIELD));
    llassert(pCharacterData.get(CHARACTER_RADIUS_FIELD).isReal());
    mRadius = (F32)pCharacterData.get(CHARACTER_RADIUS_FIELD).asReal();
}