mirror of
https://gitea.sffempire.ru/Kolyah35/minecraft-pe-0.6.1.git
synced 2026-03-30 20:13:31 +00:00
Compare commits
1 Commits
3cfa2d9ee7
...
dedicated-
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
5194575092 |
@@ -211,6 +211,7 @@ file(GLOB SERVER_SOURCES
|
|||||||
"src/world/level/tile/entity/*.cpp"
|
"src/world/level/tile/entity/*.cpp"
|
||||||
|
|
||||||
"src/world/phys/HitResult.cpp"
|
"src/world/phys/HitResult.cpp"
|
||||||
|
"src/commands/*.cpp"
|
||||||
)
|
)
|
||||||
|
|
||||||
file(GLOB CLIENT_SOURCES
|
file(GLOB CLIENT_SOURCES
|
||||||
@@ -292,6 +293,8 @@ file(GLOB CLIENT_SOURCES
|
|||||||
|
|
||||||
"src/AppPlatform_glfw.cpp"
|
"src/AppPlatform_glfw.cpp"
|
||||||
"src/main.cpp"
|
"src/main.cpp"
|
||||||
|
|
||||||
|
"src/commands/*.cpp"
|
||||||
)
|
)
|
||||||
|
|
||||||
if (${PLATFORM} STREQUAL "Desktop")
|
if (${PLATFORM} STREQUAL "Desktop")
|
||||||
|
|||||||
@@ -2,6 +2,7 @@
|
|||||||
#include "Options.h"
|
#include "Options.h"
|
||||||
#include "client/Options.h"
|
#include "client/Options.h"
|
||||||
#include "client/player/input/IBuildInput.h"
|
#include "client/player/input/IBuildInput.h"
|
||||||
|
#include "commands/CommandManager.hpp"
|
||||||
#include "platform/input/Keyboard.h"
|
#include "platform/input/Keyboard.h"
|
||||||
#include "world/item/Item.h"
|
#include "world/item/Item.h"
|
||||||
#include "world/item/ItemInstance.h"
|
#include "world/item/ItemInstance.h"
|
||||||
@@ -175,7 +176,8 @@ Minecraft::Minecraft() :
|
|||||||
_powerVr(false),
|
_powerVr(false),
|
||||||
commandPort(4711),
|
commandPort(4711),
|
||||||
reserved_d1(0),reserved_d2(0),
|
reserved_d1(0),reserved_d2(0),
|
||||||
reserved_f1(0),reserved_f2(0), options(this)
|
reserved_f1(0),reserved_f2(0), options(this),
|
||||||
|
m_commandManager()
|
||||||
{
|
{
|
||||||
//#ifdef ANDROID
|
//#ifdef ANDROID
|
||||||
|
|
||||||
@@ -1597,3 +1599,11 @@ void Minecraft::optionUpdated(OptionId option, int value ) {
|
|||||||
setSize(width, height);
|
setSize(width, height);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Minecraft::addMessage(const std::string& msg) {
|
||||||
|
#ifndef STANDALONE_SERVER
|
||||||
|
gui.addMessage(msg);
|
||||||
|
#else
|
||||||
|
LOGI("%s", msg.c_str());
|
||||||
|
#endif
|
||||||
|
}
|
||||||
@@ -2,6 +2,7 @@
|
|||||||
#define NET_MINECRAFT_CLIENT__Minecraft_H__
|
#define NET_MINECRAFT_CLIENT__Minecraft_H__
|
||||||
|
|
||||||
#include "Options.h"
|
#include "Options.h"
|
||||||
|
#include "commands/CommandManager.hpp"
|
||||||
#ifndef STANDALONE_SERVER
|
#ifndef STANDALONE_SERVER
|
||||||
#include "MouseHandler.h"
|
#include "MouseHandler.h"
|
||||||
#include "gui/Gui.h"
|
#include "gui/Gui.h"
|
||||||
@@ -122,11 +123,15 @@ public:
|
|||||||
void optionUpdated(OptionId option, int value);
|
void optionUpdated(OptionId option, int value);
|
||||||
|
|
||||||
int getTicks() { return ticks; }
|
int getTicks() { return ticks; }
|
||||||
|
|
||||||
|
void addMessage(const std::string& msg);
|
||||||
#ifdef __APPLE__
|
#ifdef __APPLE__
|
||||||
bool _isSuperFast;
|
bool _isSuperFast;
|
||||||
bool isSuperFast() { return _isSuperFast; }
|
bool isSuperFast() { return _isSuperFast; }
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
CommandManager& commandManager() { return m_commandManager; }
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
void _levelGenerated();
|
void _levelGenerated();
|
||||||
|
|
||||||
@@ -227,6 +232,8 @@ private:
|
|||||||
|
|
||||||
PerfRenderer* _perfRenderer;
|
PerfRenderer* _perfRenderer;
|
||||||
CommandServer* _commandServer;
|
CommandServer* _commandServer;
|
||||||
|
|
||||||
|
CommandManager m_commandManager;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif /*NET_MINECRAFT_CLIENT__Minecraft_H__*/
|
#endif /*NET_MINECRAFT_CLIENT__Minecraft_H__*/
|
||||||
|
|||||||
@@ -8,6 +8,7 @@
|
|||||||
#include "../../../network/ServerSideNetworkHandler.h"
|
#include "../../../network/ServerSideNetworkHandler.h"
|
||||||
#include "../../../network/packet/ChatPacket.h"
|
#include "../../../network/packet/ChatPacket.h"
|
||||||
#include "../../../platform/log.h"
|
#include "../../../platform/log.h"
|
||||||
|
#include "util/StringUtils.h"
|
||||||
|
|
||||||
#include <sstream>
|
#include <sstream>
|
||||||
#include <cstdlib>
|
#include <cstdlib>
|
||||||
@@ -54,141 +55,33 @@ void ConsoleScreen::charPressed(char inputChar)
|
|||||||
_input += inputChar;
|
_input += inputChar;
|
||||||
}
|
}
|
||||||
|
|
||||||
// ---------------------------------------------------------------------------
|
|
||||||
// execute: run _input as a command, print result, close screen
|
|
||||||
// ---------------------------------------------------------------------------
|
|
||||||
void ConsoleScreen::execute()
|
void ConsoleScreen::execute()
|
||||||
{
|
{
|
||||||
|
if (!minecraft->level) return;
|
||||||
|
|
||||||
if (_input.empty()) {
|
if (_input.empty()) {
|
||||||
minecraft->setScreen(NULL);
|
return minecraft->setScreen(NULL);
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (_input[0] == '/') {
|
if (_input[0] == '/') {
|
||||||
// Command
|
// Command
|
||||||
std::string result = processCommand(_input);
|
_input = Util::stringTrim(_input.substr(1));
|
||||||
if (!result.empty())
|
minecraft->commandManager().execute(*minecraft, _input);
|
||||||
minecraft->gui.addMessage(result);
|
|
||||||
} else {
|
} else {
|
||||||
// Chat message: <name> message
|
// @ai @rewrite
|
||||||
std::string msg = std::string("<") + minecraft->player->name + "> " + _input;
|
|
||||||
if (minecraft->netCallback && minecraft->raknetInstance->isServer()) {
|
if (minecraft->netCallback && minecraft->raknetInstance->isServer()) {
|
||||||
// Hosting a LAN game: displayGameMessage shows locally + broadcasts MessagePacket to clients
|
static_cast<ServerSideNetworkHandler*>(minecraft->netCallback)->displayGameMessage(_input);
|
||||||
static_cast<ServerSideNetworkHandler*>(minecraft->netCallback)->displayGameMessage(msg);
|
|
||||||
} else if (minecraft->netCallback) {
|
} else if (minecraft->netCallback) {
|
||||||
// Connected client: send ChatPacket to server; server echoes it back as MessagePacket
|
ChatPacket chatPkt(_input);
|
||||||
ChatPacket chatPkt(msg);
|
|
||||||
minecraft->raknetInstance->send(chatPkt);
|
minecraft->raknetInstance->send(chatPkt);
|
||||||
} else {
|
} else {
|
||||||
// Singleplayer: show locally only
|
minecraft->gui.addMessage(_input);
|
||||||
minecraft->gui.addMessage(msg);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
minecraft->setScreen(NULL);
|
minecraft->setScreen(NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
// ---------------------------------------------------------------------------
|
|
||||||
// processCommand
|
|
||||||
// ---------------------------------------------------------------------------
|
|
||||||
static std::string trim(const std::string& s) {
|
|
||||||
size_t a = s.find_first_not_of(" \t");
|
|
||||||
if (a == std::string::npos) return "";
|
|
||||||
size_t b = s.find_last_not_of(" \t");
|
|
||||||
return s.substr(a, b - a + 1);
|
|
||||||
}
|
|
||||||
|
|
||||||
std::string ConsoleScreen::processCommand(const std::string& raw)
|
|
||||||
{
|
|
||||||
// strip leading '/'
|
|
||||||
std::string line = raw;
|
|
||||||
if (!line.empty() && line[0] == '/') line = line.substr(1);
|
|
||||||
line = trim(line);
|
|
||||||
|
|
||||||
// tokenise
|
|
||||||
std::vector<std::string> args;
|
|
||||||
{
|
|
||||||
std::istringstream ss(line);
|
|
||||||
std::string tok;
|
|
||||||
while (ss >> tok) args.push_back(tok);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (args.empty()) return "";
|
|
||||||
|
|
||||||
Level* level = minecraft->level;
|
|
||||||
if (!level) return "No level loaded.";
|
|
||||||
|
|
||||||
// -----------------------------------------------------------------------
|
|
||||||
// /time ...
|
|
||||||
// -----------------------------------------------------------------------
|
|
||||||
if (args[0] == "time") {
|
|
||||||
if (args.size() < 2)
|
|
||||||
return "Usage: /time <add|set|query> ...";
|
|
||||||
|
|
||||||
const std::string& sub = args[1];
|
|
||||||
|
|
||||||
// -- time add <value> -----------------------------------------------
|
|
||||||
if (sub == "add") {
|
|
||||||
if (args.size() < 3) return "Usage: /time add <value>";
|
|
||||||
long delta = std::atol(args[2].c_str());
|
|
||||||
long newTime = level->getTime() + delta;
|
|
||||||
level->setTime(newTime);
|
|
||||||
std::ostringstream out;
|
|
||||||
out << "Set the time to " << (newTime % Level::TICKS_PER_DAY);
|
|
||||||
return out.str();
|
|
||||||
}
|
|
||||||
|
|
||||||
// -- time set <value|day|night|noon|midnight> -----------------------
|
|
||||||
if (sub == "set") {
|
|
||||||
if (args.size() < 3) return "Usage: /time set <value|day|night|noon|midnight>";
|
|
||||||
const std::string& val = args[2];
|
|
||||||
|
|
||||||
long t = -1;
|
|
||||||
if (val == "day") t = 1000;
|
|
||||||
else if (val == "noon") t = 6000;
|
|
||||||
else if (val == "night") t = 13000;
|
|
||||||
else if (val == "midnight") t = 18000;
|
|
||||||
else {
|
|
||||||
// numeric — accept positive integers only
|
|
||||||
bool numeric = true;
|
|
||||||
for (char c : val)
|
|
||||||
if (!std::isdigit((unsigned char)c)) { numeric = false; break; }
|
|
||||||
if (!numeric) return std::string("Unknown value: ") + val;
|
|
||||||
t = std::atol(val.c_str());
|
|
||||||
}
|
|
||||||
|
|
||||||
// Preserve the total day count so only the time-of-day changes
|
|
||||||
long dayCount = level->getTime() / Level::TICKS_PER_DAY;
|
|
||||||
long newTime = dayCount * Level::TICKS_PER_DAY + (t % Level::TICKS_PER_DAY);
|
|
||||||
level->setTime(newTime);
|
|
||||||
std::ostringstream out;
|
|
||||||
out << "Set the time to " << t;
|
|
||||||
return out.str();
|
|
||||||
}
|
|
||||||
|
|
||||||
// -- time query <daytime|gametime|day> ------------------------------
|
|
||||||
if (sub == "query") {
|
|
||||||
if (args.size() < 3) return "Usage: /time query <daytime|gametime|day>";
|
|
||||||
const std::string& what = args[2];
|
|
||||||
|
|
||||||
long total = level->getTime();
|
|
||||||
long daytime = total % Level::TICKS_PER_DAY;
|
|
||||||
long day = total / Level::TICKS_PER_DAY;
|
|
||||||
|
|
||||||
std::ostringstream out;
|
|
||||||
if (what == "daytime") { out << "The time of day is " << daytime; }
|
|
||||||
else if (what == "gametime") { out << "The game time is " << total; }
|
|
||||||
else if (what == "day") { out << "The day is " << day; }
|
|
||||||
else return std::string("Unknown query: ") + what;
|
|
||||||
return out.str();
|
|
||||||
}
|
|
||||||
|
|
||||||
return "Unknown sub-command. Usage: /time <add|set|query> ...";
|
|
||||||
}
|
|
||||||
|
|
||||||
return std::string("Unknown command: /") + args[0];
|
|
||||||
}
|
|
||||||
|
|
||||||
// ---------------------------------------------------------------------------
|
// ---------------------------------------------------------------------------
|
||||||
// render
|
// render
|
||||||
// ---------------------------------------------------------------------------
|
// ---------------------------------------------------------------------------
|
||||||
|
|||||||
@@ -25,7 +25,6 @@ public:
|
|||||||
|
|
||||||
private:
|
private:
|
||||||
void execute();
|
void execute();
|
||||||
std::string processCommand(const std::string& cmd);
|
|
||||||
|
|
||||||
std::string _input;
|
std::string _input;
|
||||||
int _cursorBlink; // tick counter for cursor blink
|
int _cursorBlink; // tick counter for cursor blink
|
||||||
|
|||||||
25
src/commands/Command.hpp
Normal file
25
src/commands/Command.hpp
Normal file
@@ -0,0 +1,25 @@
|
|||||||
|
#pragma once
|
||||||
|
#include <string>
|
||||||
|
#include <vector>
|
||||||
|
|
||||||
|
enum CommandFlags {
|
||||||
|
COMMAND_FLAG_SINGLEPLAYER_ONLY = (1 << 1),
|
||||||
|
COMMAND_FLAG_NO_ARGS = (1 << 2),
|
||||||
|
};
|
||||||
|
|
||||||
|
class Minecraft;
|
||||||
|
|
||||||
|
class Command {
|
||||||
|
public:
|
||||||
|
const std::string& getName() { return m_name; }
|
||||||
|
const CommandFlags getFlags() { return m_flags; }
|
||||||
|
|
||||||
|
virtual void execute(Minecraft& mc, const std::vector<std::string>& args) = 0;
|
||||||
|
virtual void printHelp(Minecraft& mc) = 0;
|
||||||
|
|
||||||
|
protected:
|
||||||
|
Command(const std::string& name, CommandFlags flags = (CommandFlags)0) : m_name(name), m_flags(flags) {}
|
||||||
|
|
||||||
|
const std::string m_name;
|
||||||
|
const CommandFlags m_flags;
|
||||||
|
};
|
||||||
27
src/commands/CommandHelp.cpp
Normal file
27
src/commands/CommandHelp.cpp
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
#include "CommandHelp.hpp"
|
||||||
|
#include "commands/Command.hpp"
|
||||||
|
#include "CommandManager.hpp"
|
||||||
|
#include <client/Minecraft.h>
|
||||||
|
|
||||||
|
CommandHelp::CommandHelp() : Command("help") {}
|
||||||
|
|
||||||
|
void CommandHelp::execute(Minecraft& mc, const std::vector<std::string>& args) {
|
||||||
|
if (args.empty()) {
|
||||||
|
auto cmds = mc.commandManager().getListAllCommands();
|
||||||
|
|
||||||
|
mc.addMessage("Usage: /help <command>");
|
||||||
|
mc.addMessage("List of all commands:");
|
||||||
|
|
||||||
|
for (auto& cmd : cmds) {
|
||||||
|
mc.addMessage(" - " + cmd);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
Command* cmd = mc.commandManager().getCommand(args[0]);
|
||||||
|
|
||||||
|
if (cmd != nullptr) {
|
||||||
|
cmd->printHelp(mc);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void CommandHelp::printHelp(Minecraft& mc) {}
|
||||||
9
src/commands/CommandHelp.hpp
Normal file
9
src/commands/CommandHelp.hpp
Normal file
@@ -0,0 +1,9 @@
|
|||||||
|
#include "Command.hpp"
|
||||||
|
|
||||||
|
class CommandHelp : public Command {
|
||||||
|
public:
|
||||||
|
CommandHelp();
|
||||||
|
|
||||||
|
void execute(Minecraft& mc, const std::vector<std::string>& args);
|
||||||
|
void printHelp(Minecraft& mc);
|
||||||
|
};
|
||||||
37
src/commands/CommandKick.cpp
Normal file
37
src/commands/CommandKick.cpp
Normal file
@@ -0,0 +1,37 @@
|
|||||||
|
#include "CommandKick.hpp"
|
||||||
|
#include "commands/Command.hpp"
|
||||||
|
#include "network/RakNetInstance.h"
|
||||||
|
#include "raknet/RakPeer.h"
|
||||||
|
#include "world/level/Level.h"
|
||||||
|
#include <algorithm>
|
||||||
|
#include <client/Minecraft.h>
|
||||||
|
|
||||||
|
|
||||||
|
CommandKick::CommandKick() : Command("kick") {}
|
||||||
|
|
||||||
|
void CommandKick::execute(Minecraft& mc, const std::vector<std::string>& args) {
|
||||||
|
if (args.empty()) {
|
||||||
|
return printHelp(mc);
|
||||||
|
}
|
||||||
|
|
||||||
|
auto it = std::find_if(mc.level->players.begin(), mc.level->players.end(), [args] (auto& it) -> bool {
|
||||||
|
return it->name == args[0];
|
||||||
|
});
|
||||||
|
|
||||||
|
if (it == mc.level->players.end()) {
|
||||||
|
return mc.addMessage("kick: can't find player with name " + args[0]);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (*it == (Player*)mc.player) {
|
||||||
|
return mc.addMessage("kick: you can't kick urself lol");
|
||||||
|
}
|
||||||
|
|
||||||
|
mc.level->removePlayer(*it);
|
||||||
|
(*it)->remove();
|
||||||
|
mc.raknetInstance->getPeer()->CloseConnection((*it)->owner, true);
|
||||||
|
mc.addMessage("kick: successfully kicked player " + args[0]);
|
||||||
|
}
|
||||||
|
|
||||||
|
void CommandKick::printHelp(Minecraft& mc) {
|
||||||
|
mc.addMessage("Usage: /kick <player>");
|
||||||
|
}
|
||||||
9
src/commands/CommandKick.hpp
Normal file
9
src/commands/CommandKick.hpp
Normal file
@@ -0,0 +1,9 @@
|
|||||||
|
#include "Command.hpp"
|
||||||
|
|
||||||
|
class CommandKick : public Command {
|
||||||
|
public:
|
||||||
|
CommandKick();
|
||||||
|
|
||||||
|
void execute(Minecraft& mc, const std::vector<std::string>& args);
|
||||||
|
void printHelp(Minecraft& mc);
|
||||||
|
};
|
||||||
71
src/commands/CommandManager.cpp
Normal file
71
src/commands/CommandManager.cpp
Normal file
@@ -0,0 +1,71 @@
|
|||||||
|
#include "CommandManager.hpp"
|
||||||
|
#include <algorithm>
|
||||||
|
#include <string>
|
||||||
|
#include <vector>
|
||||||
|
#include "client/Minecraft.h"
|
||||||
|
#include "commands/Command.hpp"
|
||||||
|
#include "commands/CommandHelp.hpp"
|
||||||
|
#include "commands/CommandKick.hpp"
|
||||||
|
#include "network/packet/ChatPacket.h"
|
||||||
|
#include "network/RakNetInstance.h"
|
||||||
|
#include "world/level/Level.h"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
CommandManager::CommandManager() {
|
||||||
|
registerAllCommands();
|
||||||
|
}
|
||||||
|
|
||||||
|
void CommandManager::registerAllCommands() {
|
||||||
|
m_commands.push_back(new CommandHelp());
|
||||||
|
m_commands.push_back(new CommandKick());
|
||||||
|
}
|
||||||
|
|
||||||
|
std::vector<std::string> CommandManager::getListAllCommands() {
|
||||||
|
std::vector<std::string> ret;
|
||||||
|
|
||||||
|
for (auto& cmd : m_commands) {
|
||||||
|
ret.push_back(cmd->getName());
|
||||||
|
}
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
void CommandManager::execute(Minecraft& mc, const std::string& input) {
|
||||||
|
std::istringstream ss(input);
|
||||||
|
std::string cmd;
|
||||||
|
|
||||||
|
ss >> cmd;
|
||||||
|
|
||||||
|
auto it = std::find_if(m_commands.begin(), m_commands.end(), [cmd](auto& it) -> bool {
|
||||||
|
return it->getName() == cmd;
|
||||||
|
});
|
||||||
|
|
||||||
|
if (it == m_commands.end()) {
|
||||||
|
return mc.addMessage("Command /" + cmd + " not found");
|
||||||
|
}
|
||||||
|
|
||||||
|
std::vector<std::string> args;
|
||||||
|
|
||||||
|
std::string tok;
|
||||||
|
while (ss >> tok) args.push_back(tok);
|
||||||
|
|
||||||
|
if (!mc.level->isClientSide || (*it)->getFlags() & CommandFlags::COMMAND_FLAG_SINGLEPLAYER_ONLY) {
|
||||||
|
(*it)->execute(mc, args);
|
||||||
|
} else {
|
||||||
|
ChatPacket packet("/" + input);
|
||||||
|
mc.raknetInstance->send(packet);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Command* CommandManager::getCommand(const std::string& name) {
|
||||||
|
auto it = std::find_if(m_commands.begin(), m_commands.end(), [name](auto& it) -> bool {
|
||||||
|
return it->getName() == name;
|
||||||
|
});
|
||||||
|
|
||||||
|
if (it == m_commands.end()) {
|
||||||
|
return *it;
|
||||||
|
}
|
||||||
|
|
||||||
|
return nullptr;
|
||||||
|
}
|
||||||
21
src/commands/CommandManager.hpp
Normal file
21
src/commands/CommandManager.hpp
Normal file
@@ -0,0 +1,21 @@
|
|||||||
|
#pragma once
|
||||||
|
#include <string>
|
||||||
|
#include <vector>
|
||||||
|
|
||||||
|
#include "Command.hpp"
|
||||||
|
|
||||||
|
class CommandManager {
|
||||||
|
public:
|
||||||
|
CommandManager();
|
||||||
|
|
||||||
|
std::vector<std::string> getListAllCommands();
|
||||||
|
|
||||||
|
void execute(Minecraft& mc, const std::string& input);
|
||||||
|
|
||||||
|
Command* getCommand(const std::string& name);
|
||||||
|
|
||||||
|
private:
|
||||||
|
void registerAllCommands();
|
||||||
|
|
||||||
|
std::vector<Command*> m_commands;
|
||||||
|
};
|
||||||
Reference in New Issue
Block a user