colobot/src/CBot/CBotInstr/CBotDefClass.h

94 lines
2.5 KiB
C++

/*
* This file is part of the Colobot: Gold Edition source code
* Copyright (C) 2001-2021, Daniel Roux, EPSITEC SA & TerranovaTeam
* http://epsitec.ch; http://colobot.info; http://github.com/colobot
*
* 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://gnu.org/licenses
*/
#pragma once
#include "CBot/CBotInstr/CBotInstr.h"
namespace CBot
{
/**
* \brief Definition of class instance variable
*
* Examples:
* \code
* ClassName varname;
* ClassName varname();
* ClassName varname = new ClassName();
* ClassName varname = new ClassName(args);
* ClassName varname1(), varname2();
* ClassName varname1 = new ClassName(), varname2;
* \endcode
*/
class CBotDefClass : public CBotInstr
{
public:
CBotDefClass();
~CBotDefClass();
/*!
* \brief Compile Definition of pointer (s) to an object style CPoint A, B ;
* \param p
* \param pStack
* \param pClass
* \return
*/
static CBotInstr* Compile(CBotToken* &p, CBotCStack* pStack, CBotClass* pClass = nullptr);
/*!
* \brief Execute Declaration of the instance of a class, for example:
* CPoint A, B;
* \param pj
* \return
*/
bool Execute(CBotStack* &pj) override;
/*!
* \brief RestoreState
* \param pj
* \param bMain
*/
void RestoreState(CBotStack* &pj, bool bMain) override;
protected:
virtual const std::string GetDebugName() override { return "CBotClassInstr"; }
virtual std::map<std::string, CBotInstr*> GetDebugLinks() override;
private:
//! Variable to initialise.
CBotInstr* m_var;
//! Parameters to be evaluated for the contructor.
CBotInstr* m_parameters;
//! A value to put, if there is.
CBotInstr* m_expr;
//! Has it parameters.
bool m_hasParams;
//! Constructor method unique identifier
long m_nMethodeIdent;
//! Instruction to chain method calls after constructor
CBotInstr* m_exprRetVar;
};
} // namespace CBot