#ifndef MWGUI_CONSOLE_H #define MWGUI_CONSOLE_H #include #include #include #include #include #include #include #include #include #include #include "../mwscript/compilercontext.hpp" #include "../mwscript/interpretercontext.hpp" namespace MWGui { class Console : private OEngine::GUI::Layout, private Compiler::ErrorHandler { private: MWScript::CompilerContext mCompilerContext; MWWorld::Environment& mEnvironment; std::vector mNames; bool compile (const std::string& cmd, Compiler::Output& output); /// Report error to the user. virtual void report (const std::string& message, const Compiler::TokenLoc& loc, Type type); /// Report a file related error virtual void report (const std::string& message, Type type); void listNames(); ///< Write all valid identifiers and keywords into mNames and sort them. /// \note If mNames is not empty, this function is a no-op. /// \note The list may contain duplicates (if a name is a keyword and an identifier at the same /// time). public: MyGUI::EditPtr command; MyGUI::EditPtr history; typedef std::list StringList; // History of previous entered commands StringList command_history; StringList::iterator current; std::string editString; Console(int w, int h, MWWorld::Environment& environment, const Compiler::Extensions& extensions); void enable(); void disable(); void setFont(const std::string &fntName); void clearHistory(); // Print a message to the console. Messages may contain color // code, eg. "#FFFFFF this is white". void print(const std::string &msg); // These are pre-colored versions that you should use. /// Output from successful console command void printOK(const std::string &msg); /// Error message void printError(const std::string &msg); private: void keyPress(MyGUI::WidgetPtr _sender, MyGUI::KeyCode key, MyGUI::Char _char); void acceptCommand(MyGUI::EditPtr _sender); std::string complete( std::string input, std::vector &matches ); }; } #endif