Merge branch 'master' of github.com:MightyPirates/OpenComputers into MC1.7

Conflicts:
	src/main/scala/li/cil/oc/client/PacketHandler.scala
	src/main/scala/li/cil/oc/client/renderer/PetRenderer.scala
	src/main/scala/li/cil/oc/common/EventHandler.scala
	src/main/scala/li/cil/oc/common/Proxy.scala
	src/main/scala/li/cil/oc/common/tileentity/traits/Environment.scala
	src/main/scala/li/cil/oc/server/PacketHandler.scala
This commit is contained in:
Florian Nücke 2014-06-21 22:45:36 +02:00
commit 8f0eaeae09
18 changed files with 136 additions and 25 deletions

View File

@ -1,4 +1,6 @@
do
_G._OSVERSION = "OpenOS 1.2"
local component = component
local computer = computer
local unicode = unicode

View File

@ -249,7 +249,6 @@ sandbox = {
traceback = debug.traceback
},
_OSVERSION = "OpenOS 1.2",
checkArg = checkArg
}
sandbox._G = sandbox
@ -622,7 +621,7 @@ local function bootstrap()
end
end
if not init then
error("no bootable medium found" .. (reason and (": " .. tostring(reason)) or ""))
error("no bootable medium found" .. (reason and (": " .. tostring(reason)) or ""), 0)
end
return coroutine.create(init), {n=0}

View File

@ -820,5 +820,8 @@ opencomputers {
# on computers' save and load performance, so you should not enable
# this unless you're asked to.
verbosePersistenceErrors: false
# Whether to not show your special thinger (if you have one you know it).
hideOwnSpecial: false
}
}

View File

@ -210,6 +210,7 @@ class Settings(config: Config) {
val geolyzerRange = config.getInt("misc.geolyzerRange")
val disassembleAllTheThings = config.getBoolean("misc.disassembleAllTheThings")
val disassemblerBreakChance = config.getDouble("misc.disassemblerBreakChance") max 0 min 1
val hideOwnPet = config.getBoolean("misc.hideOwnSpecial")
}
object Settings {

View File

@ -4,6 +4,7 @@ import cpw.mods.fml.common.eventhandler.SubscribeEvent
import cpw.mods.fml.common.network.FMLNetworkEvent.ClientCustomPacketEvent
import li.cil.oc.{Localization, Settings}
import li.cil.oc.api.component
import li.cil.oc.client.renderer.PetRenderer
import li.cil.oc.common.tileentity._
import li.cil.oc.common.tileentity.traits._
import li.cil.oc.common.{PacketType, PacketHandler => CommonPacketHandler}
@ -40,6 +41,7 @@ object PacketHandler extends CommonPacketHandler {
case PacketType.HologramPowerChange => onHologramPowerChange(p)
case PacketType.HologramScale => onHologramScale(p)
case PacketType.HologramSet => onHologramSet(p)
case PacketType.PetVisibility => onPetVisibility(p)
case PacketType.PowerState => onPowerState(p)
case PacketType.RedstoneState => onRedstoneState(p)
case PacketType.RobotAnimateSwing => onRobotAnimateSwing(p)
@ -178,6 +180,19 @@ object PacketHandler extends CommonPacketHandler {
case _ => // Invalid packet.
}
def onPetVisibility(p: PacketParser) {
val count = p.readInt()
for (i <- 0 until count) {
val name = p.readUTF()
if (p.readBoolean()) {
PetRenderer.hidden -= name
}
else {
PetRenderer.hidden += name
}
}
}
def onPowerState(p: PacketParser) =
p.readTileEntity[PowerInformation]() match {
case Some(t) =>

View File

@ -1,5 +1,6 @@
package li.cil.oc.client
import li.cil.oc.Settings
import li.cil.oc.common.tileentity._
import li.cil.oc.common.tileentity.traits.Computer
import li.cil.oc.common.{CompressedPacketBuilder, PacketBuilder, PacketType}
@ -100,6 +101,14 @@ object PacketSender {
pb.sendToServer()
}
def sendPetVisibility() {
val pb = new PacketBuilder(PacketType.PetVisibility)
pb.writeBoolean(!Settings.get.hideOwnPet)
pb.sendToServer()
}
def sendRobotAssemblerStart(t: RobotAssembler) {
val pb = new PacketBuilder(PacketType.RobotAssemblerStart)

View File

@ -24,8 +24,9 @@ trait TextBuffer extends GuiScreen {
protected def bufferY: Int
protected var currentWidth, currentHeight = -1
protected var guiSizeChanged = false
protected var currentWidth, currentHeight = -1
private var showKeyboardMissing = 0L
@ -37,6 +38,7 @@ trait TextBuffer extends GuiScreen {
super.initGui()
BufferRenderer.init(Minecraft.getMinecraft.renderEngine)
Keyboard.enableRepeatEvents(true)
guiSizeChanged = true
}
override def onGuiClosed() = {
@ -58,7 +60,7 @@ trait TextBuffer extends GuiScreen {
currentWidth = 0
currentHeight = 0
}
scale = changeSize(currentWidth, currentHeight, oldWidth != currentWidth || oldHeight != currentHeight)
scale = changeSize(currentWidth, currentHeight, guiSizeChanged || oldWidth != currentWidth || oldHeight != currentHeight)
RenderState.checkError(getClass.getName + ".drawBufferLayer: entering (aka: wasntme)")

View File

@ -13,9 +13,12 @@ import net.minecraftforge.client.event.RenderPlayerEvent
import org.lwjgl.opengl.{GL11, GL12}
import scala.collection.convert.WrapAsScala._
import scala.collection.mutable
object PetRenderer {
private val entitledPlayers = Map("Kethtar" -> (0.3, 0.9, 0.6))
val hidden = mutable.Set.empty[String]
private val entitledPlayers = Map("Kethtar" ->(0.3, 0.9, 0.6))
private val petLocations = com.google.common.cache.CacheBuilder.newBuilder().
expireAfterAccess(5, TimeUnit.SECONDS).
@ -27,7 +30,7 @@ object PetRenderer {
@SubscribeEvent
def onPlayerRender(e: RenderPlayerEvent.Pre) {
val name = e.entityPlayer.getCommandSenderName
if (!entitledPlayers.contains(name)) return
if (hidden.contains(name) || !entitledPlayers.contains(name)) return
rendering = Some(entitledPlayers(name))
val worldTime = e.entityPlayer.getEntityWorld.getWorldTime

View File

@ -4,18 +4,22 @@ import codechicken.multipart.TMultiPart
import cpw.mods.fml.common.eventhandler.SubscribeEvent
import cpw.mods.fml.common.gameevent.PlayerEvent._
import cpw.mods.fml.common.gameevent.TickEvent.ServerTickEvent
import cpw.mods.fml.common.network.FMLNetworkEvent.ClientConnectedToServerEvent
import cpw.mods.fml.common.{FMLCommonHandler, Optional}
import ic2.api.energy.event.{EnergyTileLoadEvent, EnergyTileUnloadEvent}
import li.cil.oc._
import li.cil.oc.api.Network
import li.cil.oc.client.renderer.PetRenderer
import li.cil.oc.client.{PacketSender => ClientPacketSender}
import li.cil.oc.common.tileentity.traits.power
import li.cil.oc.server.{PacketSender => ServerPacketSender}
import li.cil.oc.util.LuaStateFactory
import li.cil.oc.util.mods.{Mods, ProjectRed}
import net.minecraft.client.Minecraft
import net.minecraft.entity.player.EntityPlayerMP
import net.minecraft.item.ItemStack
import net.minecraft.server.MinecraftServer
import net.minecraft.tileentity.TileEntity
import net.minecraft.util.{ChatComponentText, ChatComponentTranslation}
import net.minecraftforge.common.MinecraftForge
import org.apache.logging.log4j.Level
@ -69,22 +73,19 @@ object EventHandler {
if (FMLCommonHandler.instance.getEffectiveSide.isServer) e.player match {
case player: EntityPlayerMP =>
if (!LuaStateFactory.isAvailable) {
player.addChatMessage(new ChatComponentText("§aOpenComputers§f: ").appendSibling(
new ChatComponentTranslation(Settings.namespace + "gui.Chat.WarningLuaFallback")))
player.addChatMessage(Localization.Chat.WarningLuaFallback)
}
if (Mods.ProjectRed.isAvailable && !ProjectRed.isAPIAvailable) {
player.addChatMessage(new ChatComponentText("§aOpenComputers§f: ").appendSibling(
new ChatComponentTranslation(Settings.namespace + "gui.Chat.WarningProjectRed")))
player.addChatMessage(Localization.Chat.WarningProjectRed)
}
if (!Settings.get.pureIgnorePower && Settings.get.ignorePower) {
player.addChatMessage(new ChatComponentText("§aOpenComputers§f: ").appendSibling(
new ChatComponentTranslation(Settings.namespace + "gui.Chat.WarningPower")))
player.addChatMessage(Localization.Chat.WarningPower)
}
OpenComputers.tampered match {
case Some(event) => player.addChatMessage(new ChatComponentText("§aOpenComputers§f: ").appendSibling(
new ChatComponentTranslation(Settings.namespace + "gui.Chat.WarningFingerprint", event.expectedFingerprint, event.fingerprints.toArray.mkString(", "))))
case Some(event) => player.addChatMessage(Localization.Chat.WarningFingerprint(event))
case _ =>
}
ServerPacketSender.sendPetVisibility(None, Some(player))
// Do update check in local games and for OPs.
if (!MinecraftServer.getServer.isDedicatedServer || MinecraftServer.getServer.getConfigurationManager.isPlayerOpped(player.getCommandSenderName)) {
UpdateCheck.checkForPlayer(player)
@ -93,6 +94,15 @@ object EventHandler {
}
}
@SubscribeEvent
def clientLoggedIn(e: ClientConnectedToServerEvent) {
PetRenderer.hidden.clear()
if (Settings.get.hideOwnPet) {
PetRenderer.hidden += Minecraft.getMinecraft.thePlayer.getCommandSenderName
}
ClientPacketSender.sendPetVisibility()
}
lazy val navigationUpgrade = api.Items.get("navigationUpgrade")
@SubscribeEvent

View File

@ -15,6 +15,7 @@ object PacketType extends Enumeration {
HologramPowerChange,
HologramScale,
HologramSet,
PetVisibility, // Goes both ways.
PowerState,
RedstoneState,
RobotAnimateSwing,

View File

@ -140,8 +140,9 @@ class Proxy {
// Don't allow driver registration after this point, to avoid issues.
driver.Registry.locked = true
FMLCommonHandler.instance().bus().register(EventHandler)
FMLCommonHandler.instance().bus().register(SimpleComponentTickHandler.Instance)
FMLCommonHandler.instance.bus.register(EventHandler)
FMLCommonHandler.instance.bus.register(SimpleComponentTickHandler.Instance)
MinecraftForge.EVENT_BUS.register(EventHandler)
MinecraftForge.EVENT_BUS.register(WirelessNetwork)
MinecraftForge.EVENT_BUS.register(SaveHandler)
}

View File

@ -18,7 +18,13 @@ object ChunkloaderUpgradeHandler extends LoadingCallback {
override def ticketsLoaded(tickets: util.List[Ticket], world: World) {
for (ticket <- tickets) {
restoredTickets += ticket.getModData.getString("address") -> ticket
val data = ticket.getModData
restoredTickets += data.getString("address") -> ticket
if (data.hasKey("x") && data.hasKey("z")) {
val x = data.getInteger("x")
val z = data.getInteger("z")
ForgeChunkManager.forceChunk(ticket, new ChunkCoordIntPair(x, z))
}
}
}
@ -35,9 +41,12 @@ object ChunkloaderUpgradeHandler extends LoadingCallback {
restoredTickets.clear()
}
// TODO it might be necessary to use pre move to force load the target chunk
// Note: it might be necessary to use pre move to force load the target chunk
// in case the robot moves across a chunk border into an otherwise unloaded
// chunk (I think it would just fail to move otherwise)
// chunk (I think it would just fail to move otherwise).
// Update 2014-06-21: did some testing, seems not to be necessary. My guess
// is that the access to the block in the direction the robot moves causes
// the chunk it might move into to get loaded.
@SubscribeEvent
def onMove(e: RobotMoveEvent.Post) {
@ -57,6 +66,8 @@ object ChunkloaderUpgradeHandler extends LoadingCallback {
}
ForgeChunkManager.forceChunk(ticket, robotChunk)
ticket.getModData.setString("address", loader.node.address)
ticket.getModData.setInteger("x", robotChunk.chunkXPos)
ticket.getModData.setInteger("z", robotChunk.chunkZPos)
})
}
}

View File

@ -1,8 +1,8 @@
package li.cil.oc.common.tileentity.traits
import li.cil.oc.Settings
import li.cil.oc.api.{driver, network}
import li.cil.oc.api.network.{Connector, SidedEnvironment}
import li.cil.oc.api.{driver, network}
import li.cil.oc.common.EventHandler
import li.cil.oc.util.ExtendedNBT._
import net.minecraft.nbt.NBTTagCompound

View File

@ -8,6 +8,7 @@ import li.cil.oc.common.tileentity._
import li.cil.oc.common.tileentity.traits.{Computer, TileEntity}
import li.cil.oc.common.{PacketType, PacketHandler => CommonPacketHandler}
import li.cil.oc.{Localization, Settings, api}
import net.minecraft.client.Minecraft
import net.minecraft.entity.player.{EntityPlayer, EntityPlayerMP}
import net.minecraft.network.NetHandlerPlayServer
import net.minecraftforge.common.DimensionManager
@ -31,6 +32,7 @@ object PacketHandler extends CommonPacketHandler {
case PacketType.MouseScroll => onMouseScroll(p)
case PacketType.MouseUp => onMouseUp(p)
case PacketType.MultiPartPlace => onMultiPartPlace(p)
case PacketType.PetVisibility => onPetVisibility(p)
case PacketType.RobotAssemblerStart => onRobotAssemblerStart(p)
case PacketType.RobotStateRequest => onRobotStateRequest(p)
case PacketType.ServerRange => onServerRange(p)
@ -125,6 +127,22 @@ object PacketHandler extends CommonPacketHandler {
}
}
def onPetVisibility(p: PacketParser) {
p.player match {
case player: EntityPlayerMP if player != Minecraft.getMinecraft.thePlayer =>
if (if (p.readBoolean()) {
PetVisibility.hidden.remove(player.getCommandSenderName)
}
else {
PetVisibility.hidden.add(player.getCommandSenderName)
}) {
// Something changed.
PacketSender.sendPetVisibility(Some(player.getCommandSenderName))
}
case _ => // Invalid packet.
}
}
def onRobotAssemblerStart(p: PacketParser) =
p.readTileEntity[RobotAssembler]() match {
case Some(assembler) => assembler.start()

View File

@ -129,6 +129,28 @@ object PacketSender {
pb.sendToNearbyPlayers(t)
}
def sendPetVisibility(name: Option[String] = None, player: Option[EntityPlayerMP] = None) {
val pb = new PacketBuilder(PacketType.PetVisibility)
name match {
case Some(n) =>
pb.writeInt(1)
pb.writeUTF(n)
pb.writeBoolean(!PetVisibility.hidden.contains(n))
case _ =>
pb.writeInt(PetVisibility.hidden.size)
for (n <- PetVisibility.hidden) {
pb.writeUTF(n)
pb.writeBoolean(false)
}
}
player match {
case Some(p) => pb.sendToPlayer(p)
case _ => pb.sendToAllPlayers()
}
}
def sendPowerState(t: PowerInformation) {
val pb = new PacketBuilder(PacketType.PowerState)

View File

@ -0,0 +1,7 @@
package li.cil.oc.server
import scala.collection.mutable
object PetVisibility {
val hidden = mutable.Set.empty[String]
}

View File

@ -282,12 +282,17 @@ abstract class GraphicsCard extends component.ManagedComponent {
else s.setBackgroundColor(0x000000)
s.fill(0, 0, w, h, ' ')
try {
val message = "Unrecoverable error:\n" + Localization.localizeImmediately(machine.lastError) + "\n"
val wrapRegEx = s"(.{1,${math.max(1, w - 2)}})\\s".r
val lines = wrapRegEx.replaceAllIn(message, m => m.group(1) + "\n").lines.toArray
val lines = wrapRegEx.replaceAllIn(Localization.localizeImmediately(machine.lastError).replace("\t", " ") + "\n", m => m.group(1) + "\n").lines.toArray
val firstRow = ((h - lines.length) / 2) max 2
val message = "Unrecoverable Error"
s.set((w - message.length) / 2, firstRow - 2, message, false)
val maxLineLength = lines.map(_.length).max
val col = ((w - maxLineLength) / 2) max 0
for ((line, idx) <- lines.zipWithIndex) {
val col = (w - line.length) / 2
val row = (h - lines.length) / 2 + idx
val row = firstRow + idx
s.set(col, row, line, false)
}
}

View File

@ -64,6 +64,8 @@ class Player(val robot: tileentity.Robot) extends FakePlayer(robot.world.asInsta
override def getDefaultEyeHeight = 0f
override def getDisplayName = robot.name
// ----------------------------------------------------------------------- //
def updatePositionAndRotation(facing: ForgeDirection, side: ForgeDirection) {