Merge branch 'master-MC1.7.10' of github.com:MightyPirates/OpenComputers into master-MC1.8

Conflicts:
	src/main/scala/li/cil/oc/common/nanomachines/provider/ParticleProvider.scala
	src/main/scala/li/cil/oc/common/tileentity/Charger.scala
This commit is contained in:
Florian Nücke 2015-09-21 21:13:07 +02:00
commit f190fa2aaf
11 changed files with 99 additions and 8 deletions

View File

@ -995,7 +995,7 @@ opencomputers {
# if there are a total of 10 behaviors available, 0.5 means there will
# be 5 trigger inputs, triggers being the inputs that can be activated
# via nanomachines.
triggerQuota: 0.5
triggerQuota: 0.4
# The relative number of connectors based on the number of available
# behaviors (see triggerQuota).

View File

@ -20,7 +20,7 @@
### Карты
* [Карта абстрактной шины](abstractBusCard.md)
* [Карта данных](dataCard.md)
* [Карта данных](dataCard1.md)
* [Отладочная карта](debugCard.md)
* [Видеокарта](graphicsCard1.md)
* [Интернет карта](internetCard.md)

View File

@ -63,5 +63,5 @@ trait InventoryProxy extends IInventory {
override def getField(id: Int) = inventory.getField(id)
private def isValidSlot(slot: Int) = slot >= 0 && slot < getSizeInventory
private def isValidSlot(slot: Int) = slot >= offset && slot < getSizeInventory + offset
}

View File

@ -291,6 +291,13 @@ class ControllerImpl(val player: EntityPlayer) extends Controller with WirelessE
}
}
def debug(): Unit = {
if (isServer) {
configuration.debug()
activeBehaviorsDirty = true
}
}
// ----------------------------------------------------------------------- //
def save(nbt: NBTTagCompound): Unit = configuration.synchronized {

View File

@ -1,5 +1,6 @@
package li.cil.oc.common.nanomachines
import li.cil.oc.OpenComputers
import li.cil.oc.Settings
import li.cil.oc.api
import li.cil.oc.api.Persistable
@ -83,6 +84,29 @@ class NeuralNetwork(controller: ControllerImpl) extends Persistable {
behaviorMap ++= behaviors.map(n => n.behavior -> n)
}
// Enter debug configuration, one input -> one behavior, and list mapping in console.
def debug(): Unit = {
OpenComputers.log.info(s"Creating debug configuration for nanomachines in player ${controller.player.getDisplayName}.")
behaviors.clear()
behaviors ++= api.Nanomachines.getProviders.
map(p => (p, Option(p.createBehaviors(controller.player)).map(_.filter(_ != null)).orNull)). // Remove null behaviors.
filter(_._2 != null). // Remove null lists..
flatMap(pb => pb._2.map(b => new BehaviorNeuron(pb._1, b)))
connectors.clear()
triggers.clear()
for (i <- behaviors.indices) {
val behavior = behaviors(i)
val trigger = new TriggerNeuron()
triggers += trigger
behavior.inputs += trigger
OpenComputers.log.info(s"$i -> ${behavior.behavior.getNameHint} (${behavior.behavior.getClass.toString})")
}
}
override def save(nbt: NBTTagCompound): Unit = {
nbt.setNewTagList("triggers", triggers.map(t => {
val nbt = new NBTTagCompound()
@ -149,7 +173,7 @@ class NeuralNetwork(controller: ControllerImpl) extends Persistable {
class ConnectorNeuron extends Neuron {
val inputs = mutable.ArrayBuffer.empty[Neuron]
override def isActive = inputs.exists(_.isActive)
override def isActive = inputs.forall(_.isActive)
}
class BehaviorNeuron(val provider: BehaviorProvider, val behavior: Behavior) extends ConnectorNeuron

View File

@ -41,7 +41,7 @@ object ParticleProvider extends ScalaProvider("b48c4bbd-51bb-4915-9367-16cff3220
}
class ParticleBehavior(var effectType: EnumParticleTypes, player: EntityPlayer) extends AbstractBehavior(player) {
override def getNameHint = "particles"
override def getNameHint = "particles." + effectType.getParticleName
override def update(): Unit = {
val world = player.getEntityWorld

View File

@ -226,14 +226,29 @@ class Charger extends traits.Environment with traits.PowerAcceptor with traits.R
abstract class ConnectorChargeable(val connector: Connector) extends Chargeable {
override def changeBuffer(delta: Double): Double = connector.changeBuffer(delta)
override def equals(obj: scala.Any): Boolean = obj match {
case chargeable: ConnectorChargeable => chargeable.connector == chargeable
case _ => false
}
}
class RobotChargeable(val robot: Robot) extends ConnectorChargeable(robot.node.asInstanceOf[Connector]) {
override def pos: Vec3 = BlockPosition(robot).toVec3
override def equals(obj: scala.Any): Boolean = obj match {
case chargeable: RobotChargeable => chargeable.robot == robot
case _ => false
}
}
class DroneChargeable(val drone: Drone) extends ConnectorChargeable(drone.components.node.asInstanceOf[Connector]) {
override def pos: Vec3 = new Vec3(drone.posX, drone.posY, drone.posZ)
override def equals(obj: scala.Any): Boolean = obj match {
case chargeable: DroneChargeable => chargeable.drone == drone
case _ => false
}
}
class PlayerChargeable(val player: EntityPlayer) extends Chargeable {
@ -245,6 +260,11 @@ class Charger extends traits.Environment with traits.PowerAcceptor with traits.R
case _ => delta // Cannot charge.
}
}
override def equals(obj: scala.Any): Boolean = obj match {
case chargeable: PlayerChargeable => chargeable.player == player
case _ => false
}
}
}

View File

@ -83,11 +83,12 @@ class Disassembler extends traits.Environment with traits.PowerAcceptor with tra
while (buffer >= Settings.get.disassemblerItemCost && queue.nonEmpty) {
buffer -= Settings.get.disassemblerItemCost
val stack = queue.remove(0)
if (world.rand.nextDouble >= Settings.get.disassemblerBreakChance) {
if (disassembleNextInstantly || world.rand.nextDouble >= Settings.get.disassemblerBreakChance) {
drop(stack)
}
}
}
disassembleNextInstantly = queue.nonEmpty // If we have nothing left to do, stop being creative.
}
}
@ -105,9 +106,11 @@ class Disassembler extends traits.Environment with traits.PowerAcceptor with tra
totalRequiredEnergy = queue.size * Settings.get.disassemblerItemCost
if (instant) {
buffer = totalRequiredEnergy
disassembleNextInstantly = false // Just to be sure...
}
}
else {
drop(stack)
}
}
private def drop(stack: ItemStack) {

View File

@ -39,7 +39,7 @@ object Mods {
val CraftingCosts = new SimpleMod(IDs.CraftingCosts)
val DeepStorageUnit = new ClassBasedMod(IDs.DeepStorageUnit, "powercrystals.minefactoryreloaded.api.IDeepStorageUnit")()
val ElectricalAge = new SimpleMod(IDs.ElectricalAge, providesPower = true)
val EnderIO = new SimpleMod(IDs.EnderIO)
val EnderIO = new SimpleMod(IDs.EnderIO, version = "@[2.2,2.3)")
val EnderStorage = new SimpleMod(IDs.EnderStorage)
val ExtraCells = new SimpleMod(IDs.ExtraCells, version = "@[2.2.73,)")
val Factorization = new SimpleMod(IDs.Factorization, providesPower = true)

View File

@ -4,6 +4,7 @@ import net.minecraftforge.fml.common.event.FMLServerStartingEvent
object CommandHandler {
def register(e: FMLServerStartingEvent) {
e.registerServerCommand(DebugNanomachinesCommand)
e.registerServerCommand(NonDisassemblyAgreementCommand)
e.registerServerCommand(WirelessRenderingCommand)
e.registerServerCommand(SpawnComputerCommand)

View File

@ -0,0 +1,36 @@
package li.cil.oc.server.command
import li.cil.oc.api
import li.cil.oc.common.command.SimpleCommand
import li.cil.oc.common.nanomachines.ControllerImpl
import net.minecraft.command.ICommandSender
import net.minecraft.command.WrongUsageException
import net.minecraft.entity.player.EntityPlayer
import net.minecraft.util.ChatComponentText
object DebugNanomachinesCommand extends SimpleCommand("oc_debugNanomachines") {
aliases += "oc_dn"
override def getCommandUsage(source: ICommandSender): String = name
override def execute(source: ICommandSender, args: Array[String]): Unit = {
source match {
case player: EntityPlayer =>
api.Nanomachines.installController(player) match {
case controller: ControllerImpl =>
controller.debug()
player.addChatMessage(new ChatComponentText("Debug configuration created, see log for mappings."))
case _ => // Someone did something.
}
case _ => throw new WrongUsageException("Can only be used by players.")
}
}
// OP levels for reference:
// 1 - Ops can bypass spawn protection.
// 2 - Ops can use /clear, /difficulty, /effect, /gamemode, /gamerule, /give, /summon, /setblock and /tp, and can edit command blocks.
// 3 - Ops can use /ban, /deop, /kick, and /op.
// 4 - Ops can use /stop.
override def getRequiredPermissionLevel = 2
}