summaryrefslogtreecommitdiffstats
path: root/src/BlockEntities
diff options
context:
space:
mode:
Diffstat (limited to 'src/BlockEntities')
-rw-r--r--src/BlockEntities/CommandBlockEntity.cpp26
1 files changed, 20 insertions, 6 deletions
diff --git a/src/BlockEntities/CommandBlockEntity.cpp b/src/BlockEntities/CommandBlockEntity.cpp
index 98ef53b86..a1e4932ba 100644
--- a/src/BlockEntities/CommandBlockEntity.cpp
+++ b/src/BlockEntities/CommandBlockEntity.cpp
@@ -163,6 +163,11 @@ void cCommandBlockEntity::Execute()
return;
}
+ if (m_Command.empty())
+ {
+ return;
+ }
+
class CommandBlockOutCb :
public cCommandOutputCallback
{
@@ -175,21 +180,30 @@ void cCommandBlockEntity::Execute()
{
// Overwrite field
m_CmdBlock->SetLastOutput(cClientHandle::FormatChatPrefix(m_CmdBlock->GetWorld()->ShouldUseChatPrefixes(), "SUCCESS", cChatColor::Green, cChatColor::White) + a_Text);
+ m_CmdBlock->GetWorld()->BroadcastBlockEntity(m_CmdBlock->GetPos());
}
} CmdBlockOutCb(this);
+ AString RealCommand = m_Command;
+
+ // Remove leading slash if it exists, since console commands don't use them
+ if (RealCommand[0] == '/')
+ {
+ RealCommand = RealCommand.substr(1, RealCommand.length());
+ }
+
// Administrator commands are not executable by command blocks:
if (
- (m_Command != "stop") &&
- (m_Command != "restart") &&
- (m_Command != "kick") &&
- (m_Command != "ban") &&
- (m_Command != "ipban")
+ (RealCommand != "stop") &&
+ (RealCommand != "restart") &&
+ (RealCommand != "kick") &&
+ (RealCommand != "ban") &&
+ (RealCommand != "ipban")
)
{
cServer * Server = cRoot::Get()->GetServer();
LOGD("cCommandBlockEntity: Executing command %s", m_Command.c_str());
- Server->ExecuteConsoleCommand(m_Command, CmdBlockOutCb);
+ Server->ExecuteConsoleCommand(RealCommand, CmdBlockOutCb);
}
else
{