Merge branch 'master' into master
1
.gitignore
vendored
@ -5,6 +5,7 @@ deploy
|
|||||||
*.ipr
|
*.ipr
|
||||||
*.iws
|
*.iws
|
||||||
*.iml
|
*.iml
|
||||||
|
.idea
|
||||||
.gradle
|
.gradle
|
||||||
luaj-2.0.3/lib
|
luaj-2.0.3/lib
|
||||||
luaj-2.0.3/*.jar
|
luaj-2.0.3/*.jar
|
||||||
|
90
gradlew.bat
vendored
Normal file
@ -0,0 +1,90 @@
|
|||||||
|
@if "%DEBUG%" == "" @echo off
|
||||||
|
@rem ##########################################################################
|
||||||
|
@rem
|
||||||
|
@rem Gradle startup script for Windows
|
||||||
|
@rem
|
||||||
|
@rem ##########################################################################
|
||||||
|
|
||||||
|
@rem Set local scope for the variables with windows NT shell
|
||||||
|
if "%OS%"=="Windows_NT" setlocal
|
||||||
|
|
||||||
|
@rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
|
||||||
|
set DEFAULT_JVM_OPTS="-d64 -Xmx2048m"
|
||||||
|
|
||||||
|
set DIRNAME=%~dp0
|
||||||
|
if "%DIRNAME%" == "" set DIRNAME=.
|
||||||
|
set APP_BASE_NAME=%~n0
|
||||||
|
set APP_HOME=%DIRNAME%
|
||||||
|
|
||||||
|
@rem Find java.exe
|
||||||
|
if defined JAVA_HOME goto findJavaFromJavaHome
|
||||||
|
|
||||||
|
set JAVA_EXE=java.exe
|
||||||
|
%JAVA_EXE% -version >NUL 2>&1
|
||||||
|
if "%ERRORLEVEL%" == "0" goto init
|
||||||
|
|
||||||
|
echo.
|
||||||
|
echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
|
||||||
|
echo.
|
||||||
|
echo Please set the JAVA_HOME variable in your environment to match the
|
||||||
|
echo location of your Java installation.
|
||||||
|
|
||||||
|
goto fail
|
||||||
|
|
||||||
|
:findJavaFromJavaHome
|
||||||
|
set JAVA_HOME=%JAVA_HOME:"=%
|
||||||
|
set JAVA_EXE=%JAVA_HOME%/bin/java.exe
|
||||||
|
|
||||||
|
if exist "%JAVA_EXE%" goto init
|
||||||
|
|
||||||
|
echo.
|
||||||
|
echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME%
|
||||||
|
echo.
|
||||||
|
echo Please set the JAVA_HOME variable in your environment to match the
|
||||||
|
echo location of your Java installation.
|
||||||
|
|
||||||
|
goto fail
|
||||||
|
|
||||||
|
:init
|
||||||
|
@rem Get command-line arguments, handling Windowz variants
|
||||||
|
|
||||||
|
if not "%OS%" == "Windows_NT" goto win9xME_args
|
||||||
|
if "%@eval[2+2]" == "4" goto 4NT_args
|
||||||
|
|
||||||
|
:win9xME_args
|
||||||
|
@rem Slurp the command line arguments.
|
||||||
|
set CMD_LINE_ARGS=
|
||||||
|
set _SKIP=2
|
||||||
|
|
||||||
|
:win9xME_args_slurp
|
||||||
|
if "x%~1" == "x" goto execute
|
||||||
|
|
||||||
|
set CMD_LINE_ARGS=%*
|
||||||
|
goto execute
|
||||||
|
|
||||||
|
:4NT_args
|
||||||
|
@rem Get arguments from the 4NT Shell from JP Software
|
||||||
|
set CMD_LINE_ARGS=%$
|
||||||
|
|
||||||
|
:execute
|
||||||
|
@rem Setup the command line
|
||||||
|
|
||||||
|
set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar
|
||||||
|
|
||||||
|
@rem Execute Gradle
|
||||||
|
"%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %CMD_LINE_ARGS%
|
||||||
|
|
||||||
|
:end
|
||||||
|
@rem End local scope for the variables with windows NT shell
|
||||||
|
if "%ERRORLEVEL%"=="0" goto mainEnd
|
||||||
|
|
||||||
|
:fail
|
||||||
|
rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of
|
||||||
|
rem the _cmd.exe /c_ return code!
|
||||||
|
if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1
|
||||||
|
exit /b 1
|
||||||
|
|
||||||
|
:mainEnd
|
||||||
|
if "%OS%"=="Windows_NT" endlocal
|
||||||
|
|
||||||
|
:omega
|
7
setup.bat
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
echo "Setting up IntelliJ development environment with gradle..."
|
||||||
|
rmdir /s /q .\build
|
||||||
|
call gradlew.bat --stacktrace setupDecompWorkspace --refresh-dependencies
|
||||||
|
call gradlew.bat --stacktrace cleanIdea idea
|
||||||
|
|
||||||
|
echo "Done."
|
||||||
|
pause
|
@ -127,6 +127,7 @@ public class ComputerCraft
|
|||||||
|
|
||||||
public static int computerSpaceLimit = 1000 * 1000;
|
public static int computerSpaceLimit = 1000 * 1000;
|
||||||
public static int floppySpaceLimit = 125 * 1000;
|
public static int floppySpaceLimit = 125 * 1000;
|
||||||
|
public static int maximumFilesOpen = 128;
|
||||||
|
|
||||||
// Blocks and Items
|
// Blocks and Items
|
||||||
public static class Blocks
|
public static class Blocks
|
||||||
@ -184,6 +185,7 @@ public class ComputerCraft
|
|||||||
|
|
||||||
public static Property computerSpaceLimit;
|
public static Property computerSpaceLimit;
|
||||||
public static Property floppySpaceLimit;
|
public static Property floppySpaceLimit;
|
||||||
|
public static Property maximumFilesOpen;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -260,6 +262,9 @@ public class ComputerCraft
|
|||||||
Config.turtlesNeedFuel = Config.config.get( Configuration.CATEGORY_GENERAL, "turtlesNeedFuel", turtlesNeedFuel );
|
Config.turtlesNeedFuel = Config.config.get( Configuration.CATEGORY_GENERAL, "turtlesNeedFuel", turtlesNeedFuel );
|
||||||
Config.turtlesNeedFuel.setComment( "Set whether Turtles require fuel to move" );
|
Config.turtlesNeedFuel.setComment( "Set whether Turtles require fuel to move" );
|
||||||
|
|
||||||
|
Config.maximumFilesOpen = Config.config.get(Configuration.CATEGORY_GENERAL, "maximumFilesOpen", maximumFilesOpen);
|
||||||
|
Config.maximumFilesOpen.setComment( "Set how many files a computer can have open at the same time. Set to 0 for unlimited." );
|
||||||
|
|
||||||
Config.turtleFuelLimit = Config.config.get( Configuration.CATEGORY_GENERAL, "turtleFuelLimit", turtleFuelLimit );
|
Config.turtleFuelLimit = Config.config.get( Configuration.CATEGORY_GENERAL, "turtleFuelLimit", turtleFuelLimit );
|
||||||
Config.turtleFuelLimit.setComment( "The fuel limit for Turtles" );
|
Config.turtleFuelLimit.setComment( "The fuel limit for Turtles" );
|
||||||
|
|
||||||
@ -303,6 +308,7 @@ public class ComputerCraft
|
|||||||
|
|
||||||
computerSpaceLimit = Config.computerSpaceLimit.getInt();
|
computerSpaceLimit = Config.computerSpaceLimit.getInt();
|
||||||
floppySpaceLimit = Config.floppySpaceLimit.getInt();
|
floppySpaceLimit = Config.floppySpaceLimit.getInt();
|
||||||
|
maximumFilesOpen = Math.max( 0, Config.maximumFilesOpen.getInt() );
|
||||||
|
|
||||||
turtlesNeedFuel = Config.turtlesNeedFuel.getBoolean();
|
turtlesNeedFuel = Config.turtlesNeedFuel.getBoolean();
|
||||||
turtleFuelLimit = Config.turtleFuelLimit.getInt();
|
turtleFuelLimit = Config.turtleFuelLimit.getInt();
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/**
|
/*
|
||||||
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
||||||
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
||||||
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
||||||
@ -8,13 +8,16 @@ package dan200.computercraft.api;
|
|||||||
|
|
||||||
import dan200.computercraft.api.filesystem.IMount;
|
import dan200.computercraft.api.filesystem.IMount;
|
||||||
import dan200.computercraft.api.filesystem.IWritableMount;
|
import dan200.computercraft.api.filesystem.IWritableMount;
|
||||||
|
import dan200.computercraft.api.media.IMedia;
|
||||||
import dan200.computercraft.api.media.IMediaProvider;
|
import dan200.computercraft.api.media.IMediaProvider;
|
||||||
|
import dan200.computercraft.api.peripheral.IComputerAccess;
|
||||||
|
import dan200.computercraft.api.peripheral.IPeripheral;
|
||||||
import dan200.computercraft.api.peripheral.IPeripheralProvider;
|
import dan200.computercraft.api.peripheral.IPeripheralProvider;
|
||||||
import dan200.computercraft.api.permissions.ITurtlePermissionProvider;
|
import dan200.computercraft.api.permissions.ITurtlePermissionProvider;
|
||||||
import dan200.computercraft.api.redstone.IBundledRedstoneProvider;
|
import dan200.computercraft.api.redstone.IBundledRedstoneProvider;
|
||||||
import dan200.computercraft.api.turtle.ITurtleUpgrade;
|
import dan200.computercraft.api.turtle.ITurtleUpgrade;
|
||||||
import net.minecraft.util.math.BlockPos;
|
|
||||||
import net.minecraft.util.EnumFacing;
|
import net.minecraft.util.EnumFacing;
|
||||||
|
import net.minecraft.util.math.BlockPos;
|
||||||
import net.minecraft.world.World;
|
import net.minecraft.world.World;
|
||||||
|
|
||||||
import java.lang.reflect.Method;
|
import java.lang.reflect.Method;
|
||||||
@ -52,12 +55,16 @@ public final class ComputerCraftAPI
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a numbered directory in a subfolder of the save directory for a given world, and returns that number.<br>
|
* Creates a numbered directory in a subfolder of the save directory for a given world, and returns that number.
|
||||||
* Use in conjuction with createSaveDirMount() to create a unique place for your peripherals or media items to store files.<br>
|
*
|
||||||
* @param world The world for which the save dir should be created. This should be the serverside world object.
|
* Use in conjunction with createSaveDirMount() to create a unique place for your peripherals or media items to store files.
|
||||||
|
*
|
||||||
|
* @param world The world for which the save dir should be created. This should be the server side world object.
|
||||||
* @param parentSubPath The folder path within the save directory where the new directory should be created. eg: "computercraft/disk"
|
* @param parentSubPath The folder path within the save directory where the new directory should be created. eg: "computercraft/disk"
|
||||||
* @return The numerical value of the name of the new folder, or -1 if the folder could not be created for some reason.<br>
|
* @return The numerical value of the name of the new folder, or -1 if the folder could not be created for some reason.
|
||||||
* eg: if createUniqueNumberedSaveDir( world, "computer/disk" ) was called returns 42, then "computer/disk/42" is now available for writing.
|
*
|
||||||
|
* eg: if createUniqueNumberedSaveDir( world, "computer/disk" ) was called returns 42, then "computer/disk/42" is now
|
||||||
|
* available for writing.
|
||||||
* @see #createSaveDirMount(World, String, long)
|
* @see #createSaveDirMount(World, String, long)
|
||||||
*/
|
*/
|
||||||
public static int createUniqueNumberedSaveDir( World world, String parentSubPath )
|
public static int createUniqueNumberedSaveDir( World world, String parentSubPath )
|
||||||
@ -73,21 +80,23 @@ public final class ComputerCraftAPI
|
|||||||
}
|
}
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a file system mount that maps to a subfolder of the save directory for a given world, and returns it.<br>
|
* Creates a file system mount that maps to a subfolder of the save directory for a given world, and returns it.
|
||||||
* Use in conjuction with IComputerAccess.mount() or IComputerAccess.mountWritable() to mount a folder from the
|
*
|
||||||
* users save directory onto a computers file system.<br>
|
* Use in conjunction with IComputerAccess.mount() or IComputerAccess.mountWritable() to mount a folder from the
|
||||||
* @param world The world for which the save dir can be found. This should be the serverside world object.
|
* users save directory onto a computers file system.
|
||||||
* @param subPath The folder path within the save directory that the mount should map to. eg: "computer/disk/42".<br>
|
*
|
||||||
* Use createUniqueNumberedSaveDir() to create a new numbered folder to use.
|
* @param world The world for which the save dir can be found. This should be the server side world object.
|
||||||
* @param capacity The ammount of data that can be stored in the directory before it fills up, in bytes.
|
* @param subPath The folder path within the save directory that the mount should map to. eg: "computer/disk/42".
|
||||||
|
* Use createUniqueNumberedSaveDir() to create a new numbered folder to use.
|
||||||
|
* @param capacity The amount of data that can be stored in the directory before it fills up, in bytes.
|
||||||
* @return The mount, or null if it could be created for some reason. Use IComputerAccess.mount() or IComputerAccess.mountWritable()
|
* @return The mount, or null if it could be created for some reason. Use IComputerAccess.mount() or IComputerAccess.mountWritable()
|
||||||
* to mount this on a Computers' file system.
|
* to mount this on a Computers' file system.
|
||||||
* @see #createUniqueNumberedSaveDir(World, String)
|
* @see #createUniqueNumberedSaveDir(World, String)
|
||||||
* @see dan200.computercraft.api.peripheral.IComputerAccess#mount(String, dan200.computercraft.api.filesystem.IMount)
|
* @see IComputerAccess#mount(String, IMount)
|
||||||
* @see dan200.computercraft.api.peripheral.IComputerAccess#mountWritable(String, dan200.computercraft.api.filesystem.IWritableMount)
|
* @see IComputerAccess#mountWritable(String, IWritableMount)
|
||||||
* @see dan200.computercraft.api.filesystem.IMount
|
* @see IMount
|
||||||
* @see IWritableMount
|
* @see IWritableMount
|
||||||
*/
|
*/
|
||||||
public static IWritableMount createSaveDirMount( World world, String subPath, long capacity )
|
public static IWritableMount createSaveDirMount( World world, String subPath, long capacity )
|
||||||
@ -103,19 +112,24 @@ public final class ComputerCraftAPI
|
|||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a file system mount to a resource folder, and returns it.<br>
|
* Creates a file system mount to a resource folder, and returns it.
|
||||||
* Use in conjuction with IComputerAccess.mount() or IComputerAccess.mountWritable() to mount a resource folder onto a computers file system.<br>
|
*
|
||||||
* The files in this mount will be a combination of files in the specified mod jar, and resource packs that contain resources with the same domain and path.<br>
|
* Use in conjunction with IComputerAccess.mount() or IComputerAccess.mountWritable() to mount a resource folder
|
||||||
|
* onto a computer's file system.
|
||||||
|
*
|
||||||
|
* The files in this mount will be a combination of files in the specified mod jar, and resource packs that contain
|
||||||
|
* resources with the same domain and path.
|
||||||
|
*
|
||||||
* @param modClass A class in whose jar to look first for the resources to mount. Using your main mod class is recommended. eg: MyMod.class
|
* @param modClass A class in whose jar to look first for the resources to mount. Using your main mod class is recommended. eg: MyMod.class
|
||||||
* @param domain The domain under which to look for resources. eg: "mymod"
|
* @param domain The domain under which to look for resources. eg: "mymod".
|
||||||
* @param subPath The domain under which to look for resources. eg: "mymod/lua/myfiles"
|
* @param subPath The domain under which to look for resources. eg: "mymod/lua/myfiles".
|
||||||
* @return The mount, or null if it could be created for some reason. Use IComputerAccess.mount() or IComputerAccess.mountWritable()
|
* @return The mount, or {@code null} if it could be created for some reason. Use IComputerAccess.mount() or
|
||||||
* to mount this on a Computers' file system.
|
* IComputerAccess.mountWritable() to mount this on a Computers' file system.
|
||||||
* @see dan200.computercraft.api.peripheral.IComputerAccess#mount(String, dan200.computercraft.api.filesystem.IMount)
|
* @see IComputerAccess#mount(String, IMount)
|
||||||
* @see dan200.computercraft.api.peripheral.IComputerAccess#mountWritable(String, IWritableMount)
|
* @see IComputerAccess#mountWritable(String, IWritableMount)
|
||||||
* @see dan200.computercraft.api.filesystem.IMount
|
* @see IMount
|
||||||
*/
|
*/
|
||||||
public static IMount createResourceMount( Class modClass, String domain, String subPath )
|
public static IMount createResourceMount( Class modClass, String domain, String subPath )
|
||||||
{
|
{
|
||||||
@ -130,9 +144,11 @@ public final class ComputerCraftAPI
|
|||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Registers a peripheral handler to convert blocks into IPeripheral implementations.
|
* Registers a peripheral handler to convert blocks into {@link IPeripheral} implementations.
|
||||||
|
*
|
||||||
|
* @param handler The peripheral provider to register.
|
||||||
* @see dan200.computercraft.api.peripheral.IPeripheral
|
* @see dan200.computercraft.api.peripheral.IPeripheral
|
||||||
* @see dan200.computercraft.api.peripheral.IPeripheralProvider
|
* @see dan200.computercraft.api.peripheral.IPeripheralProvider
|
||||||
*/
|
*/
|
||||||
@ -153,6 +169,8 @@ public final class ComputerCraftAPI
|
|||||||
* Registers a new turtle turtle for use in ComputerCraft. After calling this,
|
* Registers a new turtle turtle for use in ComputerCraft. After calling this,
|
||||||
* users should be able to craft Turtles with your new turtle. It is recommended to call
|
* users should be able to craft Turtles with your new turtle. It is recommended to call
|
||||||
* this during the load() method of your mod.
|
* this during the load() method of your mod.
|
||||||
|
*
|
||||||
|
* @param upgrade The turtle upgrade to register.
|
||||||
* @see dan200.computercraft.api.turtle.ITurtleUpgrade
|
* @see dan200.computercraft.api.turtle.ITurtleUpgrade
|
||||||
*/
|
*/
|
||||||
public static void registerTurtleUpgrade( ITurtleUpgrade upgrade )
|
public static void registerTurtleUpgrade( ITurtleUpgrade upgrade )
|
||||||
@ -172,7 +190,9 @@ public final class ComputerCraftAPI
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Registers a bundled redstone handler to provide bundled redstone output for blocks
|
* Registers a bundled redstone handler to provide bundled redstone output for blocks.
|
||||||
|
*
|
||||||
|
* @param handler The bundled redstone provider to register.
|
||||||
* @see dan200.computercraft.api.redstone.IBundledRedstoneProvider
|
* @see dan200.computercraft.api.redstone.IBundledRedstoneProvider
|
||||||
*/
|
*/
|
||||||
public static void registerBundledRedstoneProvider( IBundledRedstoneProvider handler )
|
public static void registerBundledRedstoneProvider( IBundledRedstoneProvider handler )
|
||||||
@ -190,9 +210,13 @@ public final class ComputerCraftAPI
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* If there is a Computer or Turtle at a certain position in the world, get it's bundled redstone output.
|
* If there is a Computer or Turtle at a certain position in the world, get it's bundled redstone output.
|
||||||
* @see dan200.computercraft.api.redstone.IBundledRedstoneProvider
|
*
|
||||||
|
* @param world The world this block is in.
|
||||||
|
* @param pos The position this block is at.
|
||||||
|
* @param side The side to extract the bundled redstone output from.
|
||||||
* @return If there is a block capable of emitting bundled redstone at the location, it's signal (0-65535) will be returned.
|
* @return If there is a block capable of emitting bundled redstone at the location, it's signal (0-65535) will be returned.
|
||||||
* If there is no block capable of emitting bundled redstone at the location, -1 will be returned.
|
* If there is no block capable of emitting bundled redstone at the location, -1 will be returned.
|
||||||
|
* @see dan200.computercraft.api.redstone.IBundledRedstoneProvider
|
||||||
*/
|
*/
|
||||||
public static int getBundledRedstoneOutput( World world, BlockPos pos, EnumFacing side )
|
public static int getBundledRedstoneOutput( World world, BlockPos pos, EnumFacing side )
|
||||||
{
|
{
|
||||||
@ -209,7 +233,9 @@ public final class ComputerCraftAPI
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Registers a media handler to provide IMedia implementations for Items
|
* Registers a media handler to provide {@link IMedia} implementations for Items
|
||||||
|
*
|
||||||
|
* @param handler The media provider to register.
|
||||||
* @see dan200.computercraft.api.media.IMediaProvider
|
* @see dan200.computercraft.api.media.IMediaProvider
|
||||||
*/
|
*/
|
||||||
public static void registerMediaProvider( IMediaProvider handler )
|
public static void registerMediaProvider( IMediaProvider handler )
|
||||||
@ -226,7 +252,9 @@ public final class ComputerCraftAPI
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Registers a permission handler to restrict where turtles can move or build
|
* Registers a permission handler to restrict where turtles can move or build.
|
||||||
|
*
|
||||||
|
* @param handler The turtle permission provider to register.
|
||||||
* @see dan200.computercraft.api.permissions.ITurtlePermissionProvider
|
* @see dan200.computercraft.api.permissions.ITurtlePermissionProvider
|
||||||
*/
|
*/
|
||||||
public static void registerPermissionProvider( ITurtlePermissionProvider handler )
|
public static void registerPermissionProvider( ITurtlePermissionProvider handler )
|
||||||
@ -245,7 +273,7 @@ public final class ComputerCraftAPI
|
|||||||
// The functions below here are private, and are used to interface with the non-API ComputerCraft classes.
|
// The functions below here are private, and are used to interface with the non-API ComputerCraft classes.
|
||||||
// Reflection is used here so you can develop your mod without decompiling ComputerCraft and including
|
// Reflection is used here so you can develop your mod without decompiling ComputerCraft and including
|
||||||
// it in your solution, and so your mod won't crash if ComputerCraft is installed.
|
// it in your solution, and so your mod won't crash if ComputerCraft is installed.
|
||||||
|
|
||||||
private static void findCC()
|
private static void findCC()
|
||||||
{
|
{
|
||||||
if( !ccSearched ) {
|
if( !ccSearched ) {
|
||||||
@ -300,9 +328,9 @@ public final class ComputerCraftAPI
|
|||||||
System.out.println( "ComputerCraftAPI: ComputerCraft method " + name + " not found." );
|
System.out.println( "ComputerCraftAPI: ComputerCraft method " + name + " not found." );
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private static boolean ccSearched = false;
|
private static boolean ccSearched = false;
|
||||||
private static Class computerCraft = null;
|
private static Class computerCraft = null;
|
||||||
private static Method computerCraft_getVersion = null;
|
private static Method computerCraft_getVersion = null;
|
||||||
private static Method computerCraft_createUniqueNumberedSaveDir = null;
|
private static Method computerCraft_createUniqueNumberedSaveDir = null;
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/**
|
/*
|
||||||
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
||||||
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
||||||
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
||||||
@ -6,52 +6,71 @@
|
|||||||
|
|
||||||
package dan200.computercraft.api.filesystem;
|
package dan200.computercraft.api.filesystem;
|
||||||
|
|
||||||
|
import dan200.computercraft.api.ComputerCraftAPI;
|
||||||
|
import dan200.computercraft.api.peripheral.IComputerAccess;
|
||||||
|
import net.minecraft.world.World;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Represents a read only part of a virtual filesystem that can be mounted onto a computercraft using IComputerAccess.mount().
|
* Represents a read only part of a virtual filesystem that can be mounted onto a computer using
|
||||||
* Ready made implementations of this interface can be created using ComputerCraftAPI.createSaveDirMount() or ComputerCraftAPI.createResourceMount(), or you're free to implement it yourselves!
|
* {@link IComputerAccess#mount(String, IMount)}
|
||||||
* @see dan200.computercraft.api.ComputerCraftAPI#createSaveDirMount(World, String)
|
*
|
||||||
* @see dan200.computercraft.api.ComputerCraftAPI#createResourceMount(Class, String, String)
|
* Ready made implementations of this interface can be created using
|
||||||
* @see dan200.computercraft.api.peripheral.IComputerAccess#mount(String, IMount)
|
* {@link ComputerCraftAPI#createSaveDirMount(World, String, long)} or
|
||||||
|
* {@link ComputerCraftAPI#createResourceMount(Class, String, String)}, or you're free to implement it yourselves!
|
||||||
|
*
|
||||||
|
* @see ComputerCraftAPI#createSaveDirMount(World, String, long)
|
||||||
|
* @see ComputerCraftAPI#createResourceMount(Class, String, String)
|
||||||
|
* @see IComputerAccess#mount(String, IMount)
|
||||||
* @see IWritableMount
|
* @see IWritableMount
|
||||||
*/
|
*/
|
||||||
public interface IMount
|
public interface IMount
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* Returns whether a file with a given path exists or not.
|
* Returns whether a file with a given path exists or not.
|
||||||
|
*
|
||||||
* @param path A file path in normalised format, relative to the mount location. ie: "programs/myprogram"
|
* @param path A file path in normalised format, relative to the mount location. ie: "programs/myprogram"
|
||||||
* @return true if the file exists, false otherwise
|
* @return If the file exists.
|
||||||
|
* @throws IOException If an error occurs when checking the existence of the file.
|
||||||
*/
|
*/
|
||||||
public boolean exists( String path ) throws IOException;
|
public boolean exists( String path ) throws IOException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns whether a file with a given path is a directory or not.
|
* Returns whether a file with a given path is a directory or not.
|
||||||
* @param path A file path in normalised format, relative to the mount location. ie: "programs/myprograms"
|
*
|
||||||
* @return true if the file exists and is a directory, false otherwise
|
* @param path A file path in normalised format, relative to the mount location. ie: "programs/myprograms".
|
||||||
|
* @return If the file exists and is a directory
|
||||||
|
* @throws IOException If an error occurs when checking whether the file is a directory.
|
||||||
*/
|
*/
|
||||||
public boolean isDirectory( String path ) throws IOException;
|
public boolean isDirectory( String path ) throws IOException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the file names of all the files in a directory.
|
* Returns the file names of all the files in a directory.
|
||||||
* @param path A file path in normalised format, relative to the mount location. ie: "programs/myprograms"
|
*
|
||||||
* @param contents A list of strings. Add all the file names to this list
|
* @param path A file path in normalised format, relative to the mount location. ie: "programs/myprograms".
|
||||||
|
* @param contents A list of strings. Add all the file names to this list.
|
||||||
|
* @throws IOException If the file was not a directory, or could not be listed.
|
||||||
*/
|
*/
|
||||||
public void list( String path, List<String> contents ) throws IOException;
|
public void list( String path, List<String> contents ) throws IOException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the size of a file with a given path, in bytes
|
* Returns the size of a file with a given path, in bytes
|
||||||
* @param path A file path in normalised format, relative to the mount location. ie: "programs/myprogram"
|
*
|
||||||
* @return the size of the file, in bytes
|
* @param path A file path in normalised format, relative to the mount location. ie: "programs/myprogram".
|
||||||
|
* @return The size of the file, in bytes.
|
||||||
|
* @throws IOException If the file does not exist, or its size could not be determined.
|
||||||
*/
|
*/
|
||||||
public long getSize( String path ) throws IOException;
|
public long getSize( String path ) throws IOException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Opens a file with a given path, and returns an inputstream representing it's contents.
|
* Opens a file with a given path, and returns an {@link InputStream} representing its contents.
|
||||||
* @param path A file path in normalised format, relative to the mount location. ie: "programs/myprogram"
|
*
|
||||||
* @return a stream representing the contents of the file
|
* @param path A file path in normalised format, relative to the mount location. ie: "programs/myprogram".
|
||||||
|
* @return A stream representing the contents of the file.
|
||||||
|
* @throws IOException If the file does not exist, or could not be opened.
|
||||||
*/
|
*/
|
||||||
public InputStream openForRead( String path ) throws IOException;
|
public InputStream openForRead( String path ) throws IOException;
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/**
|
/*
|
||||||
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
||||||
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
||||||
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
||||||
@ -6,47 +6,67 @@
|
|||||||
|
|
||||||
package dan200.computercraft.api.filesystem;
|
package dan200.computercraft.api.filesystem;
|
||||||
|
|
||||||
|
import dan200.computercraft.api.ComputerCraftAPI;
|
||||||
|
import dan200.computercraft.api.peripheral.IComputerAccess;
|
||||||
|
import net.minecraft.world.World;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.OutputStream;
|
import java.io.OutputStream;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Represents a part of a virtual filesystem that can be mounted onto a computercraft using IComputerAccess.mount() or IComputerAccess.mountWritable(), that can also be written to.
|
* Represents a part of a virtual filesystem that can be mounted onto a computer using {@link IComputerAccess#mount(String, IMount)}
|
||||||
* Ready made implementations of this interface can be created using ComputerCraftAPI.createSaveDirMount(), or you're free to implement it yourselves!
|
* or {@link IComputerAccess#mountWritable(String, IWritableMount)}, that can also be written to.
|
||||||
* @see dan200.computercraft.api.ComputerCraftAPI#createSaveDirMount(World, String)
|
*
|
||||||
* @see dan200.computercraft.api.peripheral.IComputerAccess#mountWritable(String, dan200.computercraft.api.filesystem.IMount)
|
* Ready made implementations of this interface can be created using
|
||||||
* @see dan200.computercraft.api.filesystem.IMount
|
* {@link ComputerCraftAPI#createSaveDirMount(World, String, long)}, or you're free to implement it yourselves!
|
||||||
|
*
|
||||||
|
* @see ComputerCraftAPI#createSaveDirMount(World, String, long)
|
||||||
|
* @see IComputerAccess#mount(String, IMount)
|
||||||
|
* @see IComputerAccess#mountWritable(String, IWritableMount)
|
||||||
|
* @see IMount
|
||||||
*/
|
*/
|
||||||
public interface IWritableMount extends IMount
|
public interface IWritableMount extends IMount
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* Creates a directory at a given path inside the virtual file system.
|
* Creates a directory at a given path inside the virtual file system.
|
||||||
* @param path A file path in normalised format, relative to the mount location. ie: "programs/mynewprograms"
|
*
|
||||||
|
* @param path A file path in normalised format, relative to the mount location. ie: "programs/mynewprograms".
|
||||||
|
* @throws IOException If the directory already exists or could not be created.
|
||||||
*/
|
*/
|
||||||
public void makeDirectory( String path ) throws IOException;
|
public void makeDirectory( String path ) throws IOException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Deletes a directory at a given path inside the virtual file system.
|
* Deletes a directory at a given path inside the virtual file system.
|
||||||
* @param path A file path in normalised format, relative to the mount location. ie: "programs/myoldprograms"
|
*
|
||||||
|
* @param path A file path in normalised format, relative to the mount location. ie: "programs/myoldprograms".
|
||||||
|
* @throws IOException If the file does not exist or could not be deleted.
|
||||||
*/
|
*/
|
||||||
public void delete( String path ) throws IOException;
|
public void delete( String path ) throws IOException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Opens a file with a given path, and returns an outputstream for writing to it.
|
* Opens a file with a given path, and returns an {@link OutputStream} for writing to it.
|
||||||
* @param path A file path in normalised format, relative to the mount location. ie: "programs/myprogram"
|
*
|
||||||
* @return a stream for writing to
|
* @param path A file path in normalised format, relative to the mount location. ie: "programs/myprogram".
|
||||||
|
* @return A stream for writing to
|
||||||
|
* @throws IOException If the file could not be opened for writing.
|
||||||
*/
|
*/
|
||||||
public OutputStream openForWrite( String path ) throws IOException;
|
public OutputStream openForWrite( String path ) throws IOException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Opens a file with a given path, and returns an outputstream for appending to it.
|
* Opens a file with a given path, and returns an {@link OutputStream} for appending to it.
|
||||||
* @param path A file path in normalised format, relative to the mount location. ie: "programs/myprogram"
|
*
|
||||||
* @return a stream for writing to
|
* @param path A file path in normalised format, relative to the mount location. ie: "programs/myprogram".
|
||||||
|
* @return A stream for writing to.
|
||||||
|
* @throws IOException If the file could not be opened for writing.
|
||||||
*/
|
*/
|
||||||
public OutputStream openForAppend( String path ) throws IOException;
|
public OutputStream openForAppend( String path ) throws IOException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the ammount of free space on the mount, in bytes. You should decrease this value as the user writes to the mount, and write operations should fail once it reaches zero.
|
* Get the amount of free space on the mount, in bytes. You should decrease this value as the user writes to the
|
||||||
* @return The ammount of free space, in bytes.
|
* mount, and write operations should fail once it reaches zero.
|
||||||
|
*
|
||||||
|
* @return The amount of free space, in bytes.
|
||||||
|
* @throws IOException If the remaining space could not be computed.
|
||||||
*/
|
*/
|
||||||
public long getRemainingSpace() throws IOException;
|
public long getRemainingSpace() throws IOException;
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/**
|
/*
|
||||||
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
||||||
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
||||||
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/**
|
/*
|
||||||
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
||||||
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
||||||
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
||||||
@ -7,52 +7,84 @@
|
|||||||
package dan200.computercraft.api.lua;
|
package dan200.computercraft.api.lua;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* An interface passed to peripherals and ILuaObjects' by computers or turtles, providing methods
|
* An interface passed to peripherals and {@link ILuaObject}s by computers or turtles, providing methods
|
||||||
* that allow the peripheral call to wait for events before returning, just like in lua.
|
* that allow the peripheral call to wait for events before returning, just like in lua. This is very useful if you need
|
||||||
* This is very useful if you need to signal work to be performed on the main thread, and don't want to return
|
* to signal work to be performed on the main thread, and don't want to return until the work has been completed.
|
||||||
* until the work has been completed.
|
|
||||||
*/
|
*/
|
||||||
public interface ILuaContext
|
public interface ILuaContext
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* Wait for an event to occur on the computercraft, suspending the thread until it arises. This method is exactly equivalent to os.pullEvent() in lua.
|
* Wait for an event to occur on the computer, suspending the thread until it arises. This method is exactly
|
||||||
* @param filter A specific event to wait for, or null to wait for any event
|
* equivalent to {@code os.pullEvent()} in lua.
|
||||||
* @return An object array containing the name of the event that occurred, and any event parameters
|
*
|
||||||
* @throws Exception If the user presses CTRL+T to terminate the current program while pullEvent() is waiting for an event, a "Terminated" exception will be thrown here.
|
* @param filter A specific event to wait for, or null to wait for any event.
|
||||||
* Do not attempt to common this exception, unless you wish to prevent termination, which is not recommended.
|
* @return An object array containing the name of the event that occurred, and any event parameters.
|
||||||
* @throws InterruptedException If the user shuts down or reboots the computercraft while pullEvent() is waiting for an event, InterruptedException will be thrown. This exception must not be caught or intercepted, or the computercraft will leak memory and end up in a broken state.
|
* @throws LuaException If the user presses CTRL+T to terminate the current program while pullEvent() is
|
||||||
|
* waiting for an event, a "Terminated" exception will be thrown here.
|
||||||
|
*
|
||||||
|
* Do not attempt to catch this exception. You should use {@link #pullEventRaw(String)}
|
||||||
|
* should you wish to disable termination.
|
||||||
|
* @throws InterruptedException If the user shuts down or reboots the computer while pullEvent() is waiting for an
|
||||||
|
* event, InterruptedException will be thrown. This exception must not be caught or
|
||||||
|
* intercepted, or the computer will leak memory and end up in a broken state.
|
||||||
*/
|
*/
|
||||||
public Object[] pullEvent( String filter ) throws LuaException, InterruptedException;
|
public Object[] pullEvent( String filter ) throws LuaException, InterruptedException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The same as pullEvent(), except "terminated" events are ignored. Only use this if you want to prevent program termination, which is not recommended. This method is exactly equivalent to os.pullEventRaw() in lua.
|
* The same as {@link #pullEvent(String)}, except "terminated" events are ignored. Only use this if you want to
|
||||||
* @param filter A specific event to wait for, or null to wait for any event
|
* prevent program termination, which is not recommended. This method is exactly equivalent to
|
||||||
* @return An object array containing the name of the event that occurred, and any event parameters
|
* {@code os.pullEventRaw()} in lua.
|
||||||
* @throws InterruptedException If the user shuts down or reboots the computercraft while pullEventRaw() is waiting for an event, InterruptedException will be thrown. This exception must not be caught or intercepted, or the computercraft will leak memory and end up in a broken state.
|
*
|
||||||
|
* @param filter A specific event to wait for, or null to wait for any event.
|
||||||
|
* @return An object array containing the name of the event that occurred, and any event parameters.
|
||||||
|
* @throws InterruptedException If the user shuts down or reboots the computer while pullEventRaw() is waiting for
|
||||||
|
* an event, InterruptedException will be thrown. This exception must not be caught or
|
||||||
|
* intercepted, or the computer will leak memory and end up in a broken state.
|
||||||
* @see #pullEvent(String)
|
* @see #pullEvent(String)
|
||||||
*/
|
*/
|
||||||
public Object[] pullEventRaw( String filter ) throws InterruptedException;
|
public Object[] pullEventRaw( String filter ) throws InterruptedException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Yield the current coroutine with some arguments until it is resumed. This method is exactly equivalent to coroutine.yield() in lua. Use pullEvent() if you wish to wait for events.
|
* Yield the current coroutine with some arguments until it is resumed. This method is exactly equivalent to
|
||||||
|
* {@code coroutine.yield()} in lua. Use {@code pullEvent()} if you wish to wait for events.
|
||||||
|
*
|
||||||
* @param arguments An object array containing the arguments to pass to coroutine.yield()
|
* @param arguments An object array containing the arguments to pass to coroutine.yield()
|
||||||
* @return An object array containing the return values from coroutine.yield()
|
* @return An object array containing the return values from coroutine.yield()
|
||||||
* @throws InterruptedException If the user shuts down or reboots the computercraft the coroutine is suspended, InterruptedException will be thrown. This exception must not be caught or intercepted, or the computercraft will leak memory and end up in a broken state.
|
* @throws InterruptedException If the user shuts down or reboots the computer the coroutine is suspended,
|
||||||
|
* InterruptedException will be thrown. This exception must not be caught or
|
||||||
|
* intercepted, or the computer will leak memory and end up in a broken state.
|
||||||
* @see #pullEvent(String)
|
* @see #pullEvent(String)
|
||||||
*/
|
*/
|
||||||
public Object[] yield( Object[] arguments ) throws InterruptedException;
|
public Object[] yield( Object[] arguments ) throws InterruptedException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* TODO: Document me
|
* Queue a task to be executed on the main server thread at the beginning of next tick, waiting for it to complete.
|
||||||
* @param task
|
* This should be used when you need to interact with the world in a thread-safe manner.
|
||||||
* @return
|
*
|
||||||
|
* Note that the return values of your task are handled as events, meaning more complex objects such as maps or
|
||||||
|
* {@link ILuaObject} will not preserve their identities.
|
||||||
|
*
|
||||||
|
* @param task The task to execute on the main thread.
|
||||||
|
* @return The objects returned by {@code task}.
|
||||||
|
* @throws LuaException If the task could not be queued, or if the task threw an exception.
|
||||||
|
* @throws InterruptedException If the user shuts down or reboots the computer the coroutine is suspended,
|
||||||
|
* InterruptedException will be thrown. This exception must not be caught or
|
||||||
|
* intercepted, or the computer will leak memory and end up in a broken state.
|
||||||
*/
|
*/
|
||||||
public Object[] executeMainThreadTask( ILuaTask task ) throws LuaException, InterruptedException;
|
public Object[] executeMainThreadTask( ILuaTask task ) throws LuaException, InterruptedException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* TODO: Document me
|
* Queue a task to be executed on the main server thread at the beginning of next tick, but do not wait for it to
|
||||||
* @param task
|
* complete. This should be used when you need to interact with the world in a thread-safe manner but do not care
|
||||||
* @return
|
* about the result or you wish to run asynchronously.
|
||||||
|
*
|
||||||
|
* When the task has finished, it will enqueue a {@code task_completed} event, which takes the task id, a success
|
||||||
|
* value and the return values, or an error message if it failed. If you need to wait on this event, it may be
|
||||||
|
* better to use {@link #executeMainThreadTask(ILuaTask)}.
|
||||||
|
*
|
||||||
|
* @param task The task to execute on the main thread.
|
||||||
|
* @return The "id" of the task. This will be the first argument to the {@code task_completed} event.
|
||||||
|
* @throws LuaException If the task could not be queued.
|
||||||
*/
|
*/
|
||||||
public long issueMainThreadTask( ILuaTask task ) throws LuaException;
|
public long issueMainThreadTask( ILuaTask task ) throws LuaException;
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/**
|
/*
|
||||||
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
||||||
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
||||||
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
||||||
@ -6,21 +6,46 @@
|
|||||||
|
|
||||||
package dan200.computercraft.api.lua;
|
package dan200.computercraft.api.lua;
|
||||||
|
|
||||||
|
import dan200.computercraft.api.peripheral.IComputerAccess;
|
||||||
|
import dan200.computercraft.api.peripheral.IPeripheral;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* An interface for representing custom objects returned by IPeripheral.callMethod() calls.
|
* An interface for representing custom objects returned by {@link IPeripheral#callMethod(IComputerAccess, ILuaContext, int, Object[])}
|
||||||
|
* calls.
|
||||||
|
*
|
||||||
* Return objects implementing this interface to expose objects with methods to lua.
|
* Return objects implementing this interface to expose objects with methods to lua.
|
||||||
*/
|
*/
|
||||||
public interface ILuaObject
|
public interface ILuaObject
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* Get the names of the methods that this object implements. This works the same as IPeripheral.getMethodNames(). See that method for detailed documentation.
|
* Get the names of the methods that this object implements. This works the same as {@link IPeripheral#getMethodNames()}.
|
||||||
* @see dan200.computercraft.api.peripheral.IPeripheral#getMethodNames()
|
* See that method for detailed documentation.
|
||||||
|
*
|
||||||
|
* @return The method names this object provides.
|
||||||
|
* @see IPeripheral#getMethodNames()
|
||||||
*/
|
*/
|
||||||
public String[] getMethodNames();
|
public String[] getMethodNames();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Called when a user calls one of the methods that this object implements. This works the same as IPeripheral.callMethod(). See that method for detailed documentation.
|
* Called when a user calls one of the methods that this object implements. This works the same as
|
||||||
* @see dan200.computercraft.api.peripheral.IPeripheral#callMethod(dan200.computercraft.api.peripheral.IComputerAccess, ILuaContext, int, Object[])
|
* {@link IPeripheral#callMethod(IComputerAccess, ILuaContext, int, Object[])}}. See that method for detailed
|
||||||
|
* documentation.
|
||||||
|
*
|
||||||
|
* @param context The context of the currently running lua thread. This can be used to wait for events
|
||||||
|
* or otherwise yield.
|
||||||
|
* @param method An integer identifying which of the methods from getMethodNames() the computercraft
|
||||||
|
* wishes to call. The integer indicates the index into the getMethodNames() table
|
||||||
|
* that corresponds to the string passed into peripheral.call()
|
||||||
|
* @param arguments The arguments for this method. See {@link IPeripheral#callMethod(IComputerAccess, ILuaContext, int, Object[])}
|
||||||
|
* the possible values and conversion rules.
|
||||||
|
* @return An array of objects, representing the values you wish to return to the Lua program.
|
||||||
|
* See {@link IPeripheral#callMethod(IComputerAccess, ILuaContext, int, Object[])} for the valid values and
|
||||||
|
* conversion rules.
|
||||||
|
* @throws LuaException If the task could not be queued, or if the task threw an exception.
|
||||||
|
* @throws InterruptedException If the user shuts down or reboots the computer the coroutine is suspended,
|
||||||
|
* InterruptedException will be thrown. This exception must not be caught or
|
||||||
|
* intercepted, or the computer will leak memory and end up in a broken state.w
|
||||||
|
* @see IPeripheral#callMethod(IComputerAccess, ILuaContext, int, Object[])
|
||||||
*/
|
*/
|
||||||
public Object[] callMethod( ILuaContext context, int method, Object[] arguments ) throws LuaException, InterruptedException;
|
public Object[] callMethod( ILuaContext context, int method, Object[] arguments ) throws LuaException, InterruptedException;
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/**
|
/*
|
||||||
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
||||||
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
||||||
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
||||||
@ -6,7 +6,24 @@
|
|||||||
|
|
||||||
package dan200.computercraft.api.lua;
|
package dan200.computercraft.api.lua;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A task which can be executed via {@link ILuaContext#executeMainThreadTask(ILuaTask)} or
|
||||||
|
* {@link ILuaContext#issueMainThreadTask(ILuaTask)}. This will be run on the main thread, at the beginning of the
|
||||||
|
* next tick.
|
||||||
|
*
|
||||||
|
* @see ILuaContext#executeMainThreadTask(ILuaTask)
|
||||||
|
* @see ILuaContext#issueMainThreadTask(ILuaTask)
|
||||||
|
*/
|
||||||
public interface ILuaTask
|
public interface ILuaTask
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
|
* Execute this task.
|
||||||
|
*
|
||||||
|
* @return The arguments to add to the {@code task_completed} event. These will be returned by
|
||||||
|
* {@link ILuaContext#executeMainThreadTask(ILuaTask)}.
|
||||||
|
* @throws LuaException If you throw any exception from this function, a lua error will be raised with the
|
||||||
|
* same message as your exception. Use this to throw appropriate errors if the wrong
|
||||||
|
* arguments are supplied to your method.
|
||||||
|
*/
|
||||||
public Object[] execute() throws LuaException;
|
public Object[] execute() throws LuaException;
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/**
|
/*
|
||||||
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
||||||
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
||||||
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
||||||
@ -7,10 +7,11 @@
|
|||||||
package dan200.computercraft.api.lua;
|
package dan200.computercraft.api.lua;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* An exception representing an error in Lua, like that raised by the error() function
|
* An exception representing an error in Lua, like that raised by the {@code error()} function.
|
||||||
*/
|
*/
|
||||||
public class LuaException extends Exception
|
public class LuaException extends Exception
|
||||||
{
|
{
|
||||||
|
private static final long serialVersionUID = -6136063076818512651L;
|
||||||
private final int m_level;
|
private final int m_level;
|
||||||
|
|
||||||
public LuaException()
|
public LuaException()
|
||||||
@ -29,6 +30,12 @@ public class LuaException extends Exception
|
|||||||
m_level = level;
|
m_level = level;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The level this error is raised at. Level 1 is the function's caller, level 2 is that function's caller, and so
|
||||||
|
* on.
|
||||||
|
*
|
||||||
|
* @return The level to raise the error at.
|
||||||
|
*/
|
||||||
public int getLevel()
|
public int getLevel()
|
||||||
{
|
{
|
||||||
return m_level;
|
return m_level;
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/**
|
/*
|
||||||
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
||||||
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
||||||
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/**
|
/*
|
||||||
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
||||||
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
||||||
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
||||||
@ -18,22 +18,26 @@ import net.minecraft.world.World;
|
|||||||
public interface IMedia
|
public interface IMedia
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* Get a string representing the label of this item. Will be called vi disk.getLabel() in lua.
|
* Get a string representing the label of this item. Will be called via {@code disk.getLabel()} in lua.
|
||||||
* @param stack The itemstack to inspect
|
*
|
||||||
* @return The label. ie: "Dan's Programs"
|
* @param stack The itemstack to inspect.
|
||||||
|
* @return The label. ie: "Dan's Programs".
|
||||||
*/
|
*/
|
||||||
public String getLabel( ItemStack stack );
|
public String getLabel( ItemStack stack );
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Set a string representing the label of this item. Will be called vi disk.setLabel() in lua.
|
* Set a string representing the label of this item. Will be called vi {@code disk.setLabel()} in lua.
|
||||||
|
*
|
||||||
* @param stack The itemstack to modify.
|
* @param stack The itemstack to modify.
|
||||||
* @param label The string to set the label to.
|
* @param label The string to set the label to.
|
||||||
* @return true if the label was updated, false if the label may not be modified.
|
* @return true if the label was updated, false if the label may not be modified.
|
||||||
*/
|
*/
|
||||||
public boolean setLabel( ItemStack stack, String label );
|
public boolean setLabel( ItemStack stack, String label );
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* If this disk represents an item with audio (like a record), get the readable name of the audio track. ie: "Jonathon Coulton - Still Alive"
|
* If this disk represents an item with audio (like a record), get the readable name of the audio track. ie:
|
||||||
|
* "Jonathon Coulton - Still Alive"
|
||||||
|
*
|
||||||
* @param stack The itemstack to inspect.
|
* @param stack The itemstack to inspect.
|
||||||
* @return The name, or null if this item does not represent an item with audio.
|
* @return The name, or null if this item does not represent an item with audio.
|
||||||
*/
|
*/
|
||||||
@ -41,16 +45,20 @@ public interface IMedia
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* If this disk represents an item with audio (like a record), get the resource name of the audio track to play.
|
* If this disk represents an item with audio (like a record), get the resource name of the audio track to play.
|
||||||
|
*
|
||||||
* @param stack The itemstack to inspect.
|
* @param stack The itemstack to inspect.
|
||||||
* @return The name, or null if this item does not represent an item with audio.
|
* @return The name, or null if this item does not represent an item with audio.
|
||||||
*/
|
*/
|
||||||
public SoundEvent getAudio( ItemStack stack );
|
public SoundEvent getAudio( ItemStack stack );
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* If this disk represents an item with data (like a floppy disk), get a mount representing it's contents. This will be mounted onto the filesystem of the computercraft while the media is in the disk drive.
|
* If this disk represents an item with data (like a floppy disk), get a mount representing it's contents. This will
|
||||||
|
* be mounted onto the filesystem of the computer while the media is in the disk drive.
|
||||||
|
*
|
||||||
* @param stack The itemstack to inspect.
|
* @param stack The itemstack to inspect.
|
||||||
* @param world The world in which the item and disk drive reside.
|
* @param world The world in which the item and disk drive reside.
|
||||||
* @return The mount, or null if this item does not represent an item with data. If the IMount returned also implements IWritableMount, it will mounted using mountWritable()
|
* @return The mount, or null if this item does not represent an item with data. If the mount returned also
|
||||||
|
* implements {@link dan200.computercraft.api.filesystem.IWritableMount}, it will mounted using mountWritable()
|
||||||
* @see dan200.computercraft.api.filesystem.IMount
|
* @see dan200.computercraft.api.filesystem.IMount
|
||||||
* @see dan200.computercraft.api.filesystem.IWritableMount
|
* @see dan200.computercraft.api.filesystem.IWritableMount
|
||||||
* @see dan200.computercraft.api.ComputerCraftAPI#createSaveDirMount(World, String, long)
|
* @see dan200.computercraft.api.ComputerCraftAPI#createSaveDirMount(World, String, long)
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/**
|
/*
|
||||||
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
||||||
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
||||||
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
||||||
@ -9,15 +9,18 @@ package dan200.computercraft.api.media;
|
|||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This interface is used to provide IMedia implementations for ItemStack
|
* This interface is used to provide {@link IMedia} implementations for {@link ItemStack}.
|
||||||
|
*
|
||||||
* @see dan200.computercraft.api.ComputerCraftAPI#registerMediaProvider(IMediaProvider)
|
* @see dan200.computercraft.api.ComputerCraftAPI#registerMediaProvider(IMediaProvider)
|
||||||
*/
|
*/
|
||||||
public interface IMediaProvider
|
public interface IMediaProvider
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* Produce an IMedia implementation from an ItemStack.
|
* Produce an IMedia implementation from an ItemStack.
|
||||||
|
*
|
||||||
|
* @param stack The stack from which to extract the media information.
|
||||||
|
* @return An IMedia implementation, or null if the item is not something you wish to handle
|
||||||
* @see dan200.computercraft.api.ComputerCraftAPI#registerMediaProvider(IMediaProvider)
|
* @see dan200.computercraft.api.ComputerCraftAPI#registerMediaProvider(IMediaProvider)
|
||||||
* @return an IMedia implementation, or null if the item is not something you wish to handle
|
|
||||||
*/
|
*/
|
||||||
public IMedia getMedia( ItemStack stack );
|
public IMedia getMedia( ItemStack stack );
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/**
|
/*
|
||||||
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
||||||
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
||||||
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/**
|
/*
|
||||||
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
||||||
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
||||||
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/**
|
/*
|
||||||
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
||||||
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
||||||
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
||||||
@ -6,8 +6,10 @@
|
|||||||
|
|
||||||
package dan200.computercraft.api.peripheral;
|
package dan200.computercraft.api.peripheral;
|
||||||
|
|
||||||
|
import dan200.computercraft.api.ComputerCraftAPI;
|
||||||
import dan200.computercraft.api.filesystem.IMount;
|
import dan200.computercraft.api.filesystem.IMount;
|
||||||
import dan200.computercraft.api.filesystem.IWritableMount;
|
import dan200.computercraft.api.filesystem.IWritableMount;
|
||||||
|
import net.minecraft.world.World;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The interface passed to peripherals by computers or turtles, providing methods
|
* The interface passed to peripherals by computers or turtles, providing methods
|
||||||
@ -17,30 +19,50 @@ import dan200.computercraft.api.filesystem.IWritableMount;
|
|||||||
public interface IComputerAccess
|
public interface IComputerAccess
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* Mount a mount onto the computers' file system in a read only mode.<br>
|
* Mount a mount onto the computer's file system in a read only mode.
|
||||||
* @param desiredLocation The location on the computercraft's file system where you would like the mount to be mounted.
|
*
|
||||||
* @param mount The mount object to mount on the computercraft. These can be obtained by calling ComputerCraftAPI.createSaveDirMount(), ComputerCraftAPI.createResourceMount() or by creating your own objects that implement the IMount interface.
|
* @param desiredLocation The location on the computer's file system where you would like the mount to be mounted.
|
||||||
* @return The location on the computercraft's file system where you the mount mounted, or null if there was already a file in the desired location. Store this value if you wish to unmount the mount later.
|
* @param mount The mount object to mount on the computer.
|
||||||
* @see dan200.computercraft.api.ComputerCraftAPI#createSaveDirMount(World, String)
|
* @return The location on the computer's file system where you the mount mounted, or {@code null} if there was already a
|
||||||
* @see dan200.computercraft.api.ComputerCraftAPI#createResourceMount(Class, String, String)
|
* file in the desired location. Store this value if you wish to unmount the mount later.
|
||||||
* @see #mountWritable(String, dan200.computercraft.api.filesystem.IWritableMount)
|
* @throws RuntimeException If the peripheral has been detached.
|
||||||
|
* @see ComputerCraftAPI#createSaveDirMount(World, String, long)
|
||||||
|
* @see ComputerCraftAPI#createResourceMount(Class, String, String)
|
||||||
|
* @see #mount(String, IMount, String)
|
||||||
|
* @see #mountWritable(String, IWritableMount)
|
||||||
* @see #unmount(String)
|
* @see #unmount(String)
|
||||||
* @see dan200.computercraft.api.filesystem.IMount
|
* @see IMount
|
||||||
*/
|
*/
|
||||||
public String mount( String desiredLocation, IMount mount );
|
public String mount( String desiredLocation, IMount mount );
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* TODO: Document me
|
* Mount a mount onto the computer's file system in a read only mode.
|
||||||
|
*
|
||||||
|
* @param desiredLocation The location on the computer's file system where you would like the mount to be mounted.
|
||||||
|
* @param mount The mount object to mount on the computer.
|
||||||
|
* @param driveName A custom name to give for this mount location, as returned by {@code fs.getDrive()}.
|
||||||
|
* @return The location on the computer's file system where you the mount mounted, or {@code null} if there was already a
|
||||||
|
* file in the desired location. Store this value if you wish to unmount the mount later.
|
||||||
|
* @throws RuntimeException If the peripheral has been detached.
|
||||||
|
* @see ComputerCraftAPI#createSaveDirMount(World, String, long)
|
||||||
|
* @see ComputerCraftAPI#createResourceMount(Class, String, String)
|
||||||
|
* @see #mount(String, IMount)
|
||||||
|
* @see #mountWritable(String, IWritableMount)
|
||||||
|
* @see #unmount(String)
|
||||||
|
* @see IMount
|
||||||
*/
|
*/
|
||||||
public String mount( String desiredLocation, IMount mount, String driveName );
|
public String mount( String desiredLocation, IMount mount, String driveName );
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Mount a mount onto the computers' file system in a writable mode.<br>
|
* Mount a mount onto the computer's file system in a writable mode.
|
||||||
* @param desiredLocation The location on the computercraft's file system where you would like the mount to be mounted.
|
*
|
||||||
* @param mount The mount object to mount on the computercraft. These can be obtained by calling ComputerCraftAPI.createSaveDirMount() or by creating your own objects that implement the IWritableMount interface.
|
* @param desiredLocation The location on the computer's file system where you would like the mount to be mounted.
|
||||||
* @return The location on the computercraft's file system where you the mount mounted, or null if there was already a file in the desired location. Store this value if you wish to unmount the mount later.
|
* @param mount The mount object to mount on the computer.
|
||||||
* @see dan200.computercraft.api.ComputerCraftAPI#createSaveDirMount(World, String)
|
* @return The location on the computer's file system where you the mount mounted, or null if there was already a
|
||||||
* @see dan200.computercraft.api.ComputerCraftAPI#createResourceMount(Class, String, String)
|
* file in the desired location. Store this value if you wish to unmount the mount later.
|
||||||
|
* @throws RuntimeException If the peripheral has been detached.
|
||||||
|
* @see ComputerCraftAPI#createSaveDirMount(World, String, long)
|
||||||
|
* @see ComputerCraftAPI#createResourceMount(Class, String, String)
|
||||||
* @see #mount(String, IMount)
|
* @see #mount(String, IMount)
|
||||||
* @see #unmount(String)
|
* @see #unmount(String)
|
||||||
* @see IMount
|
* @see IMount
|
||||||
@ -48,55 +70,81 @@ public interface IComputerAccess
|
|||||||
public String mountWritable( String desiredLocation, IWritableMount mount );
|
public String mountWritable( String desiredLocation, IWritableMount mount );
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* TODO: Document me
|
* Mount a mount onto the computer's file system in a writable mode.
|
||||||
|
*
|
||||||
|
* @param desiredLocation The location on the computer's file system where you would like the mount to be mounted.
|
||||||
|
* @param mount The mount object to mount on the computer.
|
||||||
|
* @param driveName A custom name to give for this mount location, as returned by {@code fs.getDrive()}.
|
||||||
|
* @return The location on the computer's file system where you the mount mounted, or null if there was already a
|
||||||
|
* file in the desired location. Store this value if you wish to unmount the mount later.
|
||||||
|
* @throws RuntimeException If the peripheral has been detached.
|
||||||
|
* @see ComputerCraftAPI#createSaveDirMount(World, String, long)
|
||||||
|
* @see ComputerCraftAPI#createResourceMount(Class, String, String)
|
||||||
|
* @see #mount(String, IMount)
|
||||||
|
* @see #unmount(String)
|
||||||
|
* @see IMount
|
||||||
*/
|
*/
|
||||||
public String mountWritable( String desiredLocation, IWritableMount mount, String driveName );
|
public String mountWritable( String desiredLocation, IWritableMount mount, String driveName );
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Unmounts a directory previously mounted onto the computers file system by mount() or mountWritable().<br>
|
* Unmounts a directory previously mounted onto the computers file system by {@link #mount(String, IMount)}
|
||||||
* When a directory is unmounted, it will disappear from the computers file system, and the user will no longer be able to
|
* or {@link #mountWritable(String, IWritableMount)}.
|
||||||
* access it. All directories mounted by a mount or mountWritable are automatically unmounted when the peripheral
|
*
|
||||||
* is attached if they have not been explicitly unmounted.
|
* When a directory is unmounted, it will disappear from the computers file system, and the user will no longer be
|
||||||
* @param location The desired location in the computers file system of the directory to unmount.
|
* able to access it. All directories mounted by a mount or mountWritable are automatically unmounted when the
|
||||||
* This must be the location of a directory previously mounted by mount() or mountWritable(), as
|
* peripheral is attached if they have not been explicitly unmounted.
|
||||||
* indicated by their return value.
|
*
|
||||||
* @see #mount(String, IMount)
|
* Note that you cannot unmount another peripheral's mounts.
|
||||||
* @see #mountWritable(String, IWritableMount)
|
*
|
||||||
|
* @param location The desired location in the computers file system of the directory to unmount.
|
||||||
|
* This must be the location of a directory previously mounted by {@link #mount(String, IMount)} or
|
||||||
|
* {@link #mountWritable(String, IWritableMount)}, as indicated by their return value.
|
||||||
|
* @throws RuntimeException If the peripheral has been detached.
|
||||||
|
* @throws RuntimeException If the mount does not exist, or was mounted by another peripheral.
|
||||||
|
* @see #mount(String, IMount)
|
||||||
|
* @see #mountWritable(String, IWritableMount)
|
||||||
*/
|
*/
|
||||||
public void unmount( String location );
|
public void unmount( String location );
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns the numerical ID of this computercraft.<br>
|
|
||||||
* This is the same number obtained by calling os.getComputerID() or running the "id" program from lua,
|
|
||||||
* and is guarunteed unique. This number will be positive.
|
|
||||||
* @return The identifier.
|
|
||||||
*/
|
|
||||||
public int getID();
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Causes an event to be raised on this computercraft, which the computercraft can respond to by calling
|
* Returns the numerical ID of this computer.
|
||||||
* os.pullEvent(). This can be used to notify the computercraft when things happen in the world or to
|
*
|
||||||
|
* This is the same number obtained by calling {@code os.getComputerID()} or running the "id" program from lua,
|
||||||
|
* and is guaranteed unique. This number will be positive.
|
||||||
|
*
|
||||||
|
* @return The identifier.
|
||||||
|
*/
|
||||||
|
public int getID();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Causes an event to be raised on this computer, which the computer can respond to by calling
|
||||||
|
* {@code os.pullEvent()}. This can be used to notify the computer when things happen in the world or to
|
||||||
* this peripheral.
|
* this peripheral.
|
||||||
* @param event A string identifying the type of event that has occurred, this will be
|
*
|
||||||
* returned as the first value from os.pullEvent(). It is recommended that you
|
* @param event A string identifying the type of event that has occurred, this will be
|
||||||
* you choose a name that is unique, and recognisable as originating from your
|
* returned as the first value from {@code os.pullEvent()}. It is recommended that you
|
||||||
* peripheral. eg: If your peripheral type is "button", a suitable event would be
|
* you choose a name that is unique, and recognisable as originating from your
|
||||||
* "button_pressed".
|
* peripheral. eg: If your peripheral type is "button", a suitable event would be
|
||||||
* @param arguments In addition to a name, you may pass an array of extra arguments to the event, that will
|
* "button_pressed".
|
||||||
* be supplied as extra return values to os.pullEvent(). Objects in the array will be converted
|
* @param arguments In addition to a name, you may pass an array of extra arguments to the event, that will
|
||||||
* to lua data types in the same fashion as the return values of IPeripheral.callMethod().<br>
|
* be supplied as extra return values to os.pullEvent(). Objects in the array will be converted
|
||||||
* You may supply null to indicate that no arguments are to be supplied.
|
* to lua data types in the same fashion as the return values of IPeripheral.callMethod().
|
||||||
|
*
|
||||||
|
* You may supply {@code null} to indicate that no arguments are to be supplied.
|
||||||
|
* @throws RuntimeException If the peripheral has been detached.
|
||||||
* @see dan200.computercraft.api.peripheral.IPeripheral#callMethod
|
* @see dan200.computercraft.api.peripheral.IPeripheral#callMethod
|
||||||
*/
|
*/
|
||||||
public void queueEvent( String event, Object[] arguments );
|
public void queueEvent( String event, Object[] arguments );
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get a string, unique to the computercraft, by which the computercraft refers to this peripheral.
|
* Get a string, unique to the computer, by which the computer refers to this peripheral.
|
||||||
* For directly attached peripherals this will be "left","right","front","back",etc, but
|
* For directly attached peripherals this will be "left","right","front","back",etc, but
|
||||||
* for peripherals attached remotely it will be different. It is good practice to supply
|
* for peripherals attached remotely it will be different. It is good practice to supply
|
||||||
* this string when raising events to the computercraft, so that the computercraft knows from
|
* this string when raising events to the computer, so that the computer knows from
|
||||||
* which peripheral the event came.
|
* which peripheral the event came.
|
||||||
* @return A string unique to the computercraft, but not globally.
|
*
|
||||||
|
* @return A string unique to the computer, but not globally.
|
||||||
|
* @throws RuntimeException If the peripheral has been detached.
|
||||||
*/
|
*/
|
||||||
public String getAttachmentName();
|
public String getAttachmentName();
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/**
|
/*
|
||||||
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
||||||
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
||||||
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
||||||
@ -10,89 +10,108 @@ import dan200.computercraft.api.lua.ILuaContext;
|
|||||||
import dan200.computercraft.api.lua.LuaException;
|
import dan200.computercraft.api.lua.LuaException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The interface that defines a peripheral. See IPeripheralProvider for how to associate blocks with peripherals.
|
* The interface that defines a peripheral. See {@link IPeripheralProvider} for how to associate blocks with peripherals.
|
||||||
*/
|
*/
|
||||||
public interface IPeripheral
|
public interface IPeripheral
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* Should return a string that uniquely identifies this type of peripheral.
|
* Should return a string that uniquely identifies this type of peripheral.
|
||||||
* This can be queried from lua by calling peripheral.getType()
|
* This can be queried from lua by calling {@code peripheral.getType()}
|
||||||
* @return A string identifying the type of peripheral.
|
*
|
||||||
|
* @return A string identifying the type of peripheral.
|
||||||
*/
|
*/
|
||||||
public String getType();
|
public String getType();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Should return an array of strings that identify the methods that this
|
* Should return an array of strings that identify the methods that this
|
||||||
* peripheral exposes to Lua. This will be called once before each attachment,
|
* peripheral exposes to Lua. This will be called once before each attachment,
|
||||||
* and should not change when called multiple times.
|
* and should not change when called multiple times.
|
||||||
* @return An array of strings representing method names.
|
*
|
||||||
* @see #callMethod
|
* @return An array of strings representing method names.
|
||||||
|
* @see #callMethod
|
||||||
*/
|
*/
|
||||||
public String[] getMethodNames();
|
public String[] getMethodNames();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This is called when a lua program on an attached computercraft calls peripheral.call() with
|
* This is called when a lua program on an attached computer calls {@code peripheral.call()} with
|
||||||
* one of the methods exposed by getMethodNames().<br>
|
* one of the methods exposed by {@link #getMethodNames()}.
|
||||||
* <br>
|
*
|
||||||
* Be aware that this will be called from the ComputerCraft Lua thread, and must be thread-safe
|
* Be aware that this will be called from the ComputerCraft Lua thread, and must be thread-safe
|
||||||
* when interacting with minecraft objects.
|
* when interacting with Minecraft objects.
|
||||||
* @param computer The interface to the computercraft that is making the call. Remember that multiple
|
*
|
||||||
* computers can be attached to a peripheral at once.
|
* @param computer The interface to the computer that is making the call. Remember that multiple
|
||||||
* @param context The context of the currently running lua thread. This can be used to wait for events
|
* computers can be attached to a peripheral at once.
|
||||||
* or otherwise yield.
|
* @param context The context of the currently running lua thread. This can be used to wait for events
|
||||||
* @param method An integer identifying which of the methods from getMethodNames() the computercraft
|
* or otherwise yield.
|
||||||
* wishes to call. The integer indicates the index into the getMethodNames() table
|
* @param method An integer identifying which of the methods from getMethodNames() the computercraft
|
||||||
* that corresponds to the string passed into peripheral.call()
|
* wishes to call. The integer indicates the index into the getMethodNames() table
|
||||||
* @param arguments An array of objects, representing the arguments passed into peripheral.call().<br>
|
* that corresponds to the string passed into peripheral.call()
|
||||||
* Lua values of type "string" will be represented by Object type String.<br>
|
* @param arguments An array of objects, representing the arguments passed into {@code peripheral.call()}.<br>
|
||||||
* Lua values of type "number" will be represented by Object type Double.<br>
|
* Lua values of type "string" will be represented by Object type String.<br>
|
||||||
* Lua values of type "boolean" will be represented by Object type Boolean.<br>
|
* Lua values of type "number" will be represented by Object type Double.<br>
|
||||||
* Lua values of any other type will be represented by a null object.<br>
|
* Lua values of type "boolean" will be represented by Object type Boolean.<br>
|
||||||
* This array will be empty if no arguments are passed.
|
* Lua values of type "table" will be represented by Object type Map.<br>
|
||||||
* @return An array of objects, representing values you wish to return to the lua program.<br>
|
* Lua values of any other type will be represented by a null object.<br>
|
||||||
* Integers, Doubles, Floats, Strings, Booleans and null be converted to their corresponding lua type.<br>
|
* This array will be empty if no arguments are passed.
|
||||||
* All other types will be converted to nil.<br>
|
* @return An array of objects, representing values you wish to return to the lua program. Integers, Doubles, Floats,
|
||||||
* You may return null to indicate no values should be returned.
|
* Strings, Booleans, Maps and ILuaObject and null be converted to their corresponding lua type. All other types
|
||||||
* @throws Exception If you throw any exception from this function, a lua error will be raised with the
|
* will be converted to nil.
|
||||||
* same message as your exception. Use this to throw appropriate errors if the wrong
|
*
|
||||||
* arguments are supplied to your method.
|
* You may return null to indicate no values should be returned.
|
||||||
* @see #getMethodNames
|
* @throws LuaException If you throw any exception from this function, a lua error will be raised with the
|
||||||
|
* same message as your exception. Use this to throw appropriate errors if the wrong
|
||||||
|
* arguments are supplied to your method.
|
||||||
|
* @throws InterruptedException If the user shuts down or reboots the computer the coroutine is suspended,
|
||||||
|
* InterruptedException will be thrown. This exception must not be caught or
|
||||||
|
* intercepted, or the computer will leak memory and end up in a broken state.
|
||||||
|
* @see #getMethodNames
|
||||||
*/
|
*/
|
||||||
public Object[] callMethod( IComputerAccess computer, ILuaContext context, int method, Object[] arguments ) throws LuaException, InterruptedException;
|
public Object[] callMethod( IComputerAccess computer, ILuaContext context, int method, Object[] arguments ) throws LuaException, InterruptedException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Is called when canAttachToSide has returned true, and a computercraft is attaching to the peripheral.
|
* Is called when canAttachToSide has returned true, and a computer is attaching to the peripheral.
|
||||||
* This will occur when a peripheral is placed next to an active computercraft, when a computercraft is turned on next to a peripheral,
|
*
|
||||||
* or when a turtle travels into a square next to a peripheral.
|
* This will occur when a peripheral is placed next to an active computer, when a computer is turned on next to a
|
||||||
* Between calls to attach() and detach(), the attached computercraft can make method calls on the peripheral using peripheral.call().
|
* peripheral, or when a turtle travels into a square next to a peripheral.
|
||||||
* This method can be used to keep track of which computers are attached to the peripheral, or to take action when attachment
|
*
|
||||||
* occurs.<br>
|
* Between calls to attach() and detach(), the attached computer can make method calls on the peripheral using
|
||||||
* <br>
|
* {@code peripheral.call()}. This method can be used to keep track of which computers are attached to the
|
||||||
|
* peripheral, or to take action when attachment occurs.
|
||||||
|
*
|
||||||
* Be aware that this will be called from the ComputerCraft Lua thread, and must be thread-safe
|
* Be aware that this will be called from the ComputerCraft Lua thread, and must be thread-safe
|
||||||
* when interacting with minecraft objects.
|
* when interacting with Minecraft objects.
|
||||||
* @param computer The interface to the computercraft that is being attached. Remember that multiple
|
*
|
||||||
* computers can be attached to a peripheral at once.
|
* @param computer The interface to the computer that is being attached. Remember that multiple
|
||||||
* @see #detach
|
* computers can be attached to a peripheral at once.
|
||||||
|
* @see #detach
|
||||||
*/
|
*/
|
||||||
public void attach( IComputerAccess computer );
|
public void attach( IComputerAccess computer );
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Is called when a computercraft is detaching from the peripheral.
|
* Is called when a computer is detaching from the peripheral.
|
||||||
* This will occur when a computercraft shuts down, when the peripheral is removed while attached to computers,
|
*
|
||||||
* or when a turtle moves away from a square attached to a peripheral.
|
* This will occur when a computer shuts down, when the peripheral is removed while attached to computers,
|
||||||
* This method can be used to keep track of which computers are attached to the peripheral, or to take action when detachment
|
* or when a turtle moves away from a square attached to a peripheral. This method can be used to keep track of
|
||||||
* occurs.<br>
|
* which computers are attached to the peripheral, or to take action when detachment
|
||||||
* <br>
|
* occurs.
|
||||||
|
*
|
||||||
* Be aware that this will be called from the ComputerCraft Lua thread, and must be thread-safe
|
* Be aware that this will be called from the ComputerCraft Lua thread, and must be thread-safe
|
||||||
* when interacting with minecraft objects.
|
* when interacting with Minecraft objects.
|
||||||
* @param computer The interface to the computercraft that is being detached. Remember that multiple
|
*
|
||||||
* computers can be attached to a peripheral at once.
|
* @param computer The interface to the computer that is being detached. Remember that multiple
|
||||||
* @see #detach
|
* computers can be attached to a peripheral at once.
|
||||||
|
* @see #detach
|
||||||
*/
|
*/
|
||||||
public void detach( IComputerAccess computer );
|
public void detach( IComputerAccess computer );
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* TODO: Document me
|
* Determine whether this peripheral is equivalent to another one.
|
||||||
|
*
|
||||||
|
* The minimal example should at least check whether they are the same object. However, you may wish to check if
|
||||||
|
* they point to the same block or tile entity.
|
||||||
|
*
|
||||||
|
* @param other The peripheral to compare against. This may be {@code null}.
|
||||||
|
* @return Whether these peripherals are equivalent.
|
||||||
*/
|
*/
|
||||||
public boolean equals( IPeripheral other );
|
public boolean equals( IPeripheral other );
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/**
|
/*
|
||||||
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
||||||
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
||||||
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
||||||
@ -6,20 +6,25 @@
|
|||||||
|
|
||||||
package dan200.computercraft.api.peripheral;
|
package dan200.computercraft.api.peripheral;
|
||||||
|
|
||||||
import net.minecraft.util.math.BlockPos;
|
|
||||||
import net.minecraft.util.EnumFacing;
|
import net.minecraft.util.EnumFacing;
|
||||||
|
import net.minecraft.util.math.BlockPos;
|
||||||
import net.minecraft.world.World;
|
import net.minecraft.world.World;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This interface is used to create peripheral implementations for blocks
|
* This interface is used to create peripheral implementations for blocks.
|
||||||
|
*
|
||||||
* @see dan200.computercraft.api.ComputerCraftAPI#registerPeripheralProvider(IPeripheralProvider)
|
* @see dan200.computercraft.api.ComputerCraftAPI#registerPeripheralProvider(IPeripheralProvider)
|
||||||
*/
|
*/
|
||||||
public interface IPeripheralProvider
|
public interface IPeripheralProvider
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* Produce an peripheral implementation from a block location.
|
* Produce an peripheral implementation from a block location.
|
||||||
|
*
|
||||||
|
* @param world The world the block is in.
|
||||||
|
* @param pos The position the block is at.
|
||||||
|
* @param side The side to get the peripheral from.
|
||||||
|
* @return A peripheral, or {@code null} if there is not a peripheral here you'd like to handle.
|
||||||
* @see dan200.computercraft.api.ComputerCraftAPI#registerPeripheralProvider(IPeripheralProvider)
|
* @see dan200.computercraft.api.ComputerCraftAPI#registerPeripheralProvider(IPeripheralProvider)
|
||||||
* @return a peripheral, or null if there is not a peripheral here you'd like to handle.
|
|
||||||
*/
|
*/
|
||||||
public IPeripheral getPeripheral( World world, BlockPos pos, EnumFacing side );
|
public IPeripheral getPeripheral( World world, BlockPos pos, EnumFacing side );
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/**
|
/*
|
||||||
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
||||||
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
||||||
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/**
|
/*
|
||||||
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
||||||
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
||||||
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
||||||
@ -10,11 +10,31 @@ import net.minecraft.util.math.BlockPos;
|
|||||||
import net.minecraft.world.World;
|
import net.minecraft.world.World;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This interface is used to restrict where turtles can move or build
|
* This interface is used to restrict where turtles can move or build.
|
||||||
|
*
|
||||||
|
* Turtles will call these methods before attempting to perform an action, allowing them to be cancelled.
|
||||||
|
*
|
||||||
* @see dan200.computercraft.api.ComputerCraftAPI#registerPermissionProvider(ITurtlePermissionProvider)
|
* @see dan200.computercraft.api.ComputerCraftAPI#registerPermissionProvider(ITurtlePermissionProvider)
|
||||||
*/
|
*/
|
||||||
public interface ITurtlePermissionProvider
|
public interface ITurtlePermissionProvider
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
|
* Determine whether a block can be entered by a turtle.
|
||||||
|
*
|
||||||
|
* @param world The world the block exists in
|
||||||
|
* @param pos The location of the block.
|
||||||
|
* @return Whether the turtle can move into this block.
|
||||||
|
*/
|
||||||
public boolean isBlockEnterable( World world, BlockPos pos );
|
public boolean isBlockEnterable( World world, BlockPos pos );
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Determine whether a block can be modified by a turtle.
|
||||||
|
*
|
||||||
|
* This includes breaking and placing blocks.
|
||||||
|
*
|
||||||
|
* @param world The world the block exists in
|
||||||
|
* @param pos The location of the block.
|
||||||
|
* @return Whether the turtle can modify this block.
|
||||||
|
*/
|
||||||
public boolean isBlockEditable( World world, BlockPos pos );
|
public boolean isBlockEditable( World world, BlockPos pos );
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/**
|
/*
|
||||||
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
||||||
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
||||||
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/**
|
/*
|
||||||
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
||||||
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
||||||
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
||||||
@ -6,20 +6,26 @@
|
|||||||
|
|
||||||
package dan200.computercraft.api.redstone;
|
package dan200.computercraft.api.redstone;
|
||||||
|
|
||||||
import net.minecraft.util.math.BlockPos;
|
|
||||||
import net.minecraft.util.EnumFacing;
|
import net.minecraft.util.EnumFacing;
|
||||||
|
import net.minecraft.util.math.BlockPos;
|
||||||
import net.minecraft.world.World;
|
import net.minecraft.world.World;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This interface is used to provide bundled redstone output for blocks
|
* This interface is used to provide bundled redstone output for blocks.
|
||||||
|
*
|
||||||
* @see dan200.computercraft.api.ComputerCraftAPI#registerBundledRedstoneProvider(IBundledRedstoneProvider)
|
* @see dan200.computercraft.api.ComputerCraftAPI#registerBundledRedstoneProvider(IBundledRedstoneProvider)
|
||||||
*/
|
*/
|
||||||
public interface IBundledRedstoneProvider
|
public interface IBundledRedstoneProvider
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* Produce an bundled redstone output from a block location.
|
* Produce an bundled redstone output from a block location.
|
||||||
|
*
|
||||||
|
* @param world The world this block is in.
|
||||||
|
* @param pos The position this block is at.
|
||||||
|
* @param side The side to extract the bundled redstone output from.
|
||||||
|
* @return A number in the range 0-65535 to indicate this block is providing output, or -1 if you do not wish to
|
||||||
|
* handle this block.
|
||||||
* @see dan200.computercraft.api.ComputerCraftAPI#registerBundledRedstoneProvider(IBundledRedstoneProvider)
|
* @see dan200.computercraft.api.ComputerCraftAPI#registerBundledRedstoneProvider(IBundledRedstoneProvider)
|
||||||
* @return a number in the range 0-65535 to indicate this block is providing output, or -1 if you do not wish to handle this block
|
|
||||||
*/
|
*/
|
||||||
public int getBundledRedstoneOutput( World world, BlockPos pos, EnumFacing side );
|
public int getBundledRedstoneOutput( World world, BlockPos pos, EnumFacing side );
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/**
|
/*
|
||||||
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
||||||
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
||||||
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/**
|
/*
|
||||||
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
||||||
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
||||||
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
||||||
@ -11,114 +11,181 @@ import dan200.computercraft.api.lua.LuaException;
|
|||||||
import dan200.computercraft.api.peripheral.IPeripheral;
|
import dan200.computercraft.api.peripheral.IPeripheral;
|
||||||
import net.minecraft.inventory.IInventory;
|
import net.minecraft.inventory.IInventory;
|
||||||
import net.minecraft.nbt.NBTTagCompound;
|
import net.minecraft.nbt.NBTTagCompound;
|
||||||
import net.minecraft.util.math.BlockPos;
|
|
||||||
import net.minecraft.util.EnumFacing;
|
import net.minecraft.util.EnumFacing;
|
||||||
|
import net.minecraft.util.math.BlockPos;
|
||||||
import net.minecraft.util.math.Vec3d;
|
import net.minecraft.util.math.Vec3d;
|
||||||
import net.minecraft.world.World;
|
import net.minecraft.world.World;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The interface passed to turtle by turtles, providing methods that they can call.
|
* The interface passed to turtle by turtles, providing methods that they can call.
|
||||||
* This should not be implemented by your classes. Do not interact with turtles except via this interface and ITurtleUpgrade.
|
*
|
||||||
|
* This should not be implemented by your classes. Do not interact with turtles except via this interface and
|
||||||
|
* {@link ITurtleUpgrade}.
|
||||||
*/
|
*/
|
||||||
public interface ITurtleAccess
|
public interface ITurtleAccess
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* Returns the world in which the turtle resides.
|
* Returns the world in which the turtle resides.
|
||||||
|
*
|
||||||
* @return the world in which the turtle resides.
|
* @return the world in which the turtle resides.
|
||||||
*/
|
*/
|
||||||
public World getWorld();
|
public World getWorld();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns a vector containing the integer co-ordinates at which the turtle resides.
|
* Returns a vector containing the integer co-ordinates at which the turtle resides.
|
||||||
|
*
|
||||||
* @return a vector containing the integer co-ordinates at which the turtle resides.
|
* @return a vector containing the integer co-ordinates at which the turtle resides.
|
||||||
*/
|
*/
|
||||||
public BlockPos getPosition();
|
public BlockPos getPosition();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* TODO: Document me
|
* Attempt to move this turtle to a new position.
|
||||||
|
*
|
||||||
|
* This will preserve the turtle's internal state, such as it's inventory, computer and upgrades. It should
|
||||||
|
* be used before playing a movement animation using {@link #playAnimation(TurtleAnimation)}.
|
||||||
|
*
|
||||||
|
* @param world The new world to move it to
|
||||||
|
* @param pos The new position to move it to.
|
||||||
|
* @return Whether the movement was successful. It may fail if the block was not loaded or the block placement
|
||||||
|
* was cancelled. Note this will not check
|
||||||
|
* {@link dan200.computercraft.api.permissions.ITurtlePermissionProvider#isBlockEnterable(World, BlockPos)}.
|
||||||
|
* @throws UnsupportedOperationException When attempting to teleport on the client side.
|
||||||
*/
|
*/
|
||||||
public boolean teleportTo( World world, BlockPos pos );
|
public boolean teleportTo( World world, BlockPos pos );
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns a vector containing the floating point co-ordinates at which the turtle is rendered.
|
* Returns a vector containing the floating point co-ordinates at which the turtle is rendered.
|
||||||
* This will shift when the turtle is moving.
|
* This will shift when the turtle is moving.
|
||||||
* @param f The subframe fraction
|
*
|
||||||
* @return a vector containing the floating point co-ordinates at which the turtle resides.
|
* @param f The subframe fraction.
|
||||||
|
* @return A vector containing the floating point co-ordinates at which the turtle resides.
|
||||||
|
* @see #getVisualYaw(float)
|
||||||
*/
|
*/
|
||||||
public Vec3d getVisualPosition( float f );
|
public Vec3d getVisualPosition( float f );
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* TODO: Document me
|
* Returns the yaw the turtle is facing when it is rendered.
|
||||||
|
*
|
||||||
|
* @param f The subframe fraction.
|
||||||
|
* @return The yaw the turtle is facing.
|
||||||
|
* @see #getVisualPosition(float)
|
||||||
*/
|
*/
|
||||||
public float getVisualYaw( float f );
|
public float getVisualYaw( float f );
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the world direction the turtle is currently facing.
|
* Returns the world direction the turtle is currently facing.
|
||||||
* @return the world direction the turtle is currently facing.
|
*
|
||||||
|
* @return The world direction the turtle is currently facing.
|
||||||
|
* @see #setDirection(EnumFacing)
|
||||||
*/
|
*/
|
||||||
public EnumFacing getDirection();
|
public EnumFacing getDirection();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* TODO: Document me
|
* Set the direction the turtle is facing. Note that this will not play a rotation animation, you will also need to
|
||||||
|
* call {@link #playAnimation(TurtleAnimation)} to do so.
|
||||||
|
*
|
||||||
|
* @param dir The new direction to set. This should be on either the x or z axis (so north, south, east or west).
|
||||||
|
* @see #getDirection()
|
||||||
*/
|
*/
|
||||||
public void setDirection( EnumFacing dir );
|
public void setDirection( EnumFacing dir );
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* TODO: Document me
|
* Get the currently selected slot in the turtle's inventory.
|
||||||
|
*
|
||||||
|
* @return An integer representing the current slot.
|
||||||
|
* @see #getInventory()
|
||||||
|
* @see #setSelectedSlot(int)
|
||||||
*/
|
*/
|
||||||
public int getSelectedSlot();
|
public int getSelectedSlot();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* TODO: Document me
|
* Set the currently selected slot in the turtle's inventory.
|
||||||
|
*
|
||||||
|
* @param slot The slot to set. This must be greater or equal to 0 and less than the inventory size. Otherwise no
|
||||||
|
* action will be taken.
|
||||||
|
* @throws UnsupportedOperationException When attempting to change the slot on the client side.
|
||||||
|
* @see #getInventory()
|
||||||
|
* @see #getSelectedSlot()
|
||||||
*/
|
*/
|
||||||
public void setSelectedSlot( int slot );
|
public void setSelectedSlot( int slot );
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets the colour of the turtle, as if the player had dyed it with a dye item.
|
* Sets the colour of the turtle, as if the player had dyed it with a dye item.
|
||||||
* @param dyeColour 0-15 to dye the turtle one of the 16 standard minecraft colours, or -1 to remove the dye from the turtle.
|
*
|
||||||
|
* @param dyeColour 0-15 to dye the turtle one of the 16 standard Minecraft <em>dye</em> colours, or -1 to remove
|
||||||
|
* the dye from the turtle.
|
||||||
|
* @see #getDyeColour()
|
||||||
*/
|
*/
|
||||||
public void setDyeColour( int dyeColour );
|
public void setDyeColour( int dyeColour );
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the colour the turtle has been dyed.
|
* Gets the colour the turtle has been dyed.
|
||||||
* @return 0-15 if the turtle has been dyed one of the 16 standard minecraft colours, -1 if the turtle is clean.
|
*
|
||||||
|
* @return 0-15 if the turtle has been dyed one of the 16 standard Minecraft <em>dye</em> colours, -1 if the turtle
|
||||||
|
* is clean.
|
||||||
|
* @see #getDyeColour()
|
||||||
*/
|
*/
|
||||||
public int getDyeColour();
|
public int getDyeColour();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* TODO: Document me
|
* Get the inventory of this turtle
|
||||||
|
*
|
||||||
|
* @return This turtle's inventory
|
||||||
*/
|
*/
|
||||||
public IInventory getInventory();
|
public IInventory getInventory();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* TODO: Document me
|
* Determine whether this turtle will require fuel when performing actions.
|
||||||
|
*
|
||||||
|
* @return Whether this turtle needs fuel.
|
||||||
|
* @see #getFuelLevel()
|
||||||
|
* @see #setFuelLevel(int)
|
||||||
*/
|
*/
|
||||||
public boolean isFuelNeeded();
|
public boolean isFuelNeeded();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* TODO: Document me
|
* Get the current fuel level of this turtle.
|
||||||
|
*
|
||||||
|
* @return The turtle's current fuel level.
|
||||||
|
* @see #isFuelNeeded()
|
||||||
|
* @see #setFuelLevel(int)
|
||||||
*/
|
*/
|
||||||
public int getFuelLevel();
|
public int getFuelLevel();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* TODO: Document me
|
* Set the fuel level to a new value. It is generally preferred to use {@link #consumeFuel(int)}} or {@link #addFuel(int)}
|
||||||
|
* instead.
|
||||||
|
*
|
||||||
|
* @param fuel The new amount of fuel. This must be between 0 and the fuel limit.
|
||||||
|
* @see #getFuelLevel()
|
||||||
|
* @see #getFuelLimit()
|
||||||
|
* @see #addFuel(int)
|
||||||
|
* @see #consumeFuel(int)
|
||||||
*/
|
*/
|
||||||
public void setFuelLevel( int fuel );
|
public void setFuelLevel( int fuel );
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* TODO: Document me
|
* Get the maximum amount of fuel a turtle can hold.
|
||||||
|
*
|
||||||
|
* @return The turtle's fuel limit.
|
||||||
*/
|
*/
|
||||||
public int getFuelLimit();
|
public int getFuelLimit();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Removes some fuel from the turtles fuel supply. Negative numbers can be passed in to INCREASE the fuel level of the turtle.
|
* Removes some fuel from the turtles fuel supply. Negative numbers can be passed in to INCREASE the fuel level of the turtle.
|
||||||
* @return Whether the turtle was able to consume the ammount of fuel specified. Will return false if you supply a number
|
*
|
||||||
* greater than the current fuel level of the turtle.
|
* @param fuel The amount of fuel to consume.
|
||||||
|
* @return Whether the turtle was able to consume the amount of fuel specified. Will return false if you supply a number
|
||||||
|
* greater than the current fuel level of the turtle. No fuel will be consumed if {@code false} is returned.
|
||||||
|
* @throws UnsupportedOperationException When attempting to consume fuel on the client side.
|
||||||
*/
|
*/
|
||||||
public boolean consumeFuel( int fuel );
|
public boolean consumeFuel( int fuel );
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* TODO: Document me
|
* Increase the turtle's fuel level by the given amount.
|
||||||
|
*
|
||||||
|
* @param fuel The amount to refuel with.
|
||||||
|
* @throws UnsupportedOperationException When attempting to refuel on the client side.
|
||||||
*/
|
*/
|
||||||
public void addFuel( int fuel );
|
public void addFuel( int fuel );
|
||||||
|
|
||||||
@ -128,42 +195,76 @@ public interface ITurtleAccess
|
|||||||
* with the turtles standard movement and tool commands. An issued command will return an unique integer, which will
|
* with the turtles standard movement and tool commands. An issued command will return an unique integer, which will
|
||||||
* be supplied as a parameter to a "turtle_response" event issued to the turtle after the command has completed. Look at the
|
* be supplied as a parameter to a "turtle_response" event issued to the turtle after the command has completed. Look at the
|
||||||
* lua source code for "rom/apis/turtle" for how to build a lua wrapper around this functionality.
|
* lua source code for "rom/apis/turtle" for how to build a lua wrapper around this functionality.
|
||||||
* @param command an object which will execute the custom command when its point in the queue is reached
|
*
|
||||||
* @return the objects the command returned when executed. you should probably return these to the player
|
* @param context The Lua context to pull events from.
|
||||||
|
* @param command An object which will execute the custom command when its point in the queue is reached
|
||||||
|
* @return The objects the command returned when executed. you should probably return these to the player
|
||||||
* unchanged if called from a peripheral method.
|
* unchanged if called from a peripheral method.
|
||||||
|
* @throws UnsupportedOperationException When attempting to execute a command on the client side.
|
||||||
|
* @throws LuaException If the user presses CTRL+T to terminate the current program while {@code executeCommand()} is
|
||||||
|
* waiting for an event, a "Terminated" exception will be thrown here.
|
||||||
|
* @throws InterruptedException If the user shuts down or reboots the computer while pullEvent() is waiting for an
|
||||||
|
* event, InterruptedException will be thrown. This exception must not be caught or
|
||||||
|
* intercepted, or the computer will leak memory and end up in a broken state.
|
||||||
* @see ITurtleCommand
|
* @see ITurtleCommand
|
||||||
|
* @see ILuaContext#pullEvent(String)
|
||||||
*/
|
*/
|
||||||
public Object[] executeCommand( ILuaContext context, ITurtleCommand command ) throws LuaException, InterruptedException;
|
public Object[] executeCommand( ILuaContext context, ITurtleCommand command ) throws LuaException, InterruptedException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* TODO: Document me
|
* Start playing a specific animation. This will prevent other turtle commands from executing until
|
||||||
|
* it is finished.
|
||||||
|
*
|
||||||
|
* @param animation The animation to play.
|
||||||
|
* @throws UnsupportedOperationException When attempting to execute play an animation on the client side.
|
||||||
|
* @see TurtleAnimation
|
||||||
*/
|
*/
|
||||||
public void playAnimation( TurtleAnimation animation );
|
public void playAnimation( TurtleAnimation animation );
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the turtle on the specified side of the turtle, if there is one.
|
* Returns the turtle on the specified side of the turtle, if there is one.
|
||||||
* @return the turtle on the specified side of the turtle, if there is one.
|
*
|
||||||
|
* @param side The side to get the upgrade from.
|
||||||
|
* @return The upgrade on the specified side of the turtle, if there is one.
|
||||||
|
* @see #setUpgrade(TurtleSide, ITurtleUpgrade)
|
||||||
*/
|
*/
|
||||||
public ITurtleUpgrade getUpgrade( TurtleSide side );
|
public ITurtleUpgrade getUpgrade( TurtleSide side );
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* TODO: Document me
|
* Set the upgrade for a given side, resetting peripherals and clearing upgrade specific data.
|
||||||
|
*
|
||||||
|
* @param side The side to set the upgrade on.
|
||||||
|
* @param upgrade The upgrade to set, may be {@code null} to clear.
|
||||||
|
* @see #getUpgrade(TurtleSide)
|
||||||
*/
|
*/
|
||||||
public void setUpgrade( TurtleSide side, ITurtleUpgrade upgrade );
|
public void setUpgrade( TurtleSide side, ITurtleUpgrade upgrade );
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the peripheral created by the upgrade on the specified side of the turtle, if there is one.
|
* Returns the peripheral created by the upgrade on the specified side of the turtle, if there is one.
|
||||||
* @return the peripheral created by the upgrade on the specified side of the turtle, if there is one.
|
*
|
||||||
|
* @param side The side to get the peripheral from.
|
||||||
|
* @return The peripheral created by the upgrade on the specified side of the turtle, {@code null} if none exists.
|
||||||
*/
|
*/
|
||||||
public IPeripheral getPeripheral( TurtleSide side );
|
public IPeripheral getPeripheral( TurtleSide side );
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* TODO: Document me
|
* Get an upgrade-specific NBT compound, which can be used to store arbitrary data.
|
||||||
|
*
|
||||||
|
* This will be persisted across turtle restarts and chunk loads, as well as being synced to the client. You must
|
||||||
|
* call {@link #updateUpgradeNBTData(TurtleSide)} after modifying it.
|
||||||
|
*
|
||||||
|
* @param side The side to get the upgrade data for.
|
||||||
|
* @return The upgrade-specific data.
|
||||||
|
* @see #updateUpgradeNBTData(TurtleSide)
|
||||||
*/
|
*/
|
||||||
public NBTTagCompound getUpgradeNBTData( TurtleSide side );
|
public NBTTagCompound getUpgradeNBTData( TurtleSide side );
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* TODO: Document me
|
* Mark the upgrade-specific data as dirty on a specific side. This is required for the data to be synced to the
|
||||||
|
* client and persisted.
|
||||||
|
*
|
||||||
|
* @param side The side to mark dirty.
|
||||||
|
* @see #updateUpgradeNBTData(TurtleSide)
|
||||||
*/
|
*/
|
||||||
public void updateUpgradeNBTData( TurtleSide side );
|
public void updateUpgradeNBTData( TurtleSide side );
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/**
|
/*
|
||||||
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
||||||
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
||||||
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
||||||
@ -6,20 +6,27 @@
|
|||||||
|
|
||||||
package dan200.computercraft.api.turtle;
|
package dan200.computercraft.api.turtle;
|
||||||
|
|
||||||
|
import dan200.computercraft.api.lua.ILuaContext;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* An interface for objects executing custom turtle commands, used with ITurtleAccess.issueCommand
|
* An interface for objects executing custom turtle commands, used with {@link ITurtleAccess#executeCommand(ILuaContext, ITurtleCommand)}.
|
||||||
* @see ITurtleAccess#executeCommand(dan200.computercraft.api.lua.ILuaContext,ITurtleCommand)
|
*
|
||||||
|
* @see ITurtleAccess#executeCommand(ILuaContext, ITurtleCommand)
|
||||||
*/
|
*/
|
||||||
public interface ITurtleCommand
|
public interface ITurtleCommand
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* Will be called by the turtle on the main thread when it is time to execute the custom command.
|
* Will be called by the turtle on the main thread when it is time to execute the custom command.
|
||||||
|
*
|
||||||
* The handler should either perform the work of the command, and return success, or return
|
* The handler should either perform the work of the command, and return success, or return
|
||||||
* failure with an error message to indicate the command cannot be executed at this time.
|
* failure with an error message to indicate the command cannot be executed at this time.
|
||||||
* @param turtle access to the turtle for whom the command was issued
|
*
|
||||||
* @return TurtleCommandResult.success() or TurtleCommandResult.failure( errorMessage )
|
* @param turtle Access to the turtle for whom the command was issued.
|
||||||
* @see ITurtleAccess#executeCommand(dan200.computercraft.api.lua.ILuaContext,ITurtleCommand)
|
* @return A result, indicating whether this action succeeded or not.
|
||||||
* @see dan200.computercraft.api.turtle.TurtleCommandResult
|
* @see ITurtleAccess#executeCommand(ILuaContext, ITurtleCommand)
|
||||||
|
* @see TurtleCommandResult#success()
|
||||||
|
* @see TurtleCommandResult#failure(String)
|
||||||
|
* @see TurtleCommandResult
|
||||||
*/
|
*/
|
||||||
public TurtleCommandResult execute( ITurtleAccess turtle );
|
public TurtleCommandResult execute( ITurtleAccess turtle );
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/**
|
/*
|
||||||
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
||||||
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
||||||
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
||||||
@ -6,8 +6,10 @@
|
|||||||
|
|
||||||
package dan200.computercraft.api.turtle;
|
package dan200.computercraft.api.turtle;
|
||||||
|
|
||||||
|
import dan200.computercraft.api.ComputerCraftAPI;
|
||||||
import dan200.computercraft.api.peripheral.IPeripheral;
|
import dan200.computercraft.api.peripheral.IPeripheral;
|
||||||
import net.minecraft.client.renderer.block.model.IBakedModel;
|
import net.minecraft.client.renderer.block.model.IBakedModel;
|
||||||
|
import net.minecraft.client.renderer.block.model.ModelResourceLocation;
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
import net.minecraft.util.EnumFacing;
|
import net.minecraft.util.EnumFacing;
|
||||||
import net.minecraft.util.ResourceLocation;
|
import net.minecraft.util.ResourceLocation;
|
||||||
@ -21,7 +23,8 @@ import javax.vecmath.Matrix4f;
|
|||||||
/**
|
/**
|
||||||
* The primary interface for defining an update for Turtles. A turtle update
|
* The primary interface for defining an update for Turtles. A turtle update
|
||||||
* can either be a new tool, or a new peripheral.
|
* can either be a new tool, or a new peripheral.
|
||||||
* @see dan200.computercraft.api.ComputerCraftAPI#registerTurtleUpgrade( dan200.computercraft.api.turtle.ITurtleUpgrade )
|
*
|
||||||
|
* @see ComputerCraftAPI#registerTurtleUpgrade(ITurtleUpgrade)
|
||||||
*/
|
*/
|
||||||
public interface ITurtleUpgrade
|
public interface ITurtleUpgrade
|
||||||
{
|
{
|
||||||
@ -29,7 +32,9 @@ public interface ITurtleUpgrade
|
|||||||
* Gets a unique identifier representing this type of turtle upgrade. eg: "computercraft:wireless_modem" or "my_mod:my_upgrade".
|
* Gets a unique identifier representing this type of turtle upgrade. eg: "computercraft:wireless_modem" or "my_mod:my_upgrade".
|
||||||
* You should use a unique resource domain to ensure this upgrade is uniquely identified.
|
* You should use a unique resource domain to ensure this upgrade is uniquely identified.
|
||||||
* The turtle will fail registration if an already used ID is specified.
|
* The turtle will fail registration if an already used ID is specified.
|
||||||
* @see dan200.computercraft.api.ComputerCraftAPI#registerTurtleUpgrade( dan200.computercraft.api.turtle.ITurtleUpgrade )
|
*
|
||||||
|
* @return The unique ID for this upgrade.
|
||||||
|
* @see ComputerCraftAPI#registerTurtleUpgrade(ITurtleUpgrade)
|
||||||
*/
|
*/
|
||||||
public ResourceLocation getUpgradeID();
|
public ResourceLocation getUpgradeID();
|
||||||
|
|
||||||
@ -38,71 +43,89 @@ public interface ITurtleUpgrade
|
|||||||
* for backwards compatibility with pre-1.76 worlds. If your upgrade was
|
* for backwards compatibility with pre-1.76 worlds. If your upgrade was
|
||||||
* not released for older ComputerCraft versions, you can return -1 here.
|
* not released for older ComputerCraft versions, you can return -1 here.
|
||||||
* The turtle will fail registration if an already used positive ID is specified.
|
* The turtle will fail registration if an already used positive ID is specified.
|
||||||
* @see dan200.computercraft.api.ComputerCraftAPI#registerTurtleUpgrade( dan200.computercraft.api.turtle.ITurtleUpgrade )
|
*
|
||||||
|
* @return The legacy ID, or -1 if is needed.
|
||||||
|
* @see ComputerCraftAPI#registerTurtleUpgrade(ITurtleUpgrade)
|
||||||
*/
|
*/
|
||||||
public int getLegacyUpgradeID();
|
public int getLegacyUpgradeID();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Return a String to describe this type of turtle in turtle item names.
|
* Return an unlocalised string to describe this type of turtle in turtle item names.
|
||||||
|
*
|
||||||
* Examples of built-in adjectives are "Wireless", "Mining" and "Crafty".
|
* Examples of built-in adjectives are "Wireless", "Mining" and "Crafty".
|
||||||
*/
|
*
|
||||||
|
* @return The localisation key for this upgrade's adjective.
|
||||||
|
*/
|
||||||
public String getUnlocalisedAdjective();
|
public String getUnlocalisedAdjective();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Return whether this turtle adds a tool or a peripheral to the turtle.
|
* Return whether this turtle adds a tool or a peripheral to the turtle.
|
||||||
* @see TurtleUpgradeType for the differences between the two.
|
*
|
||||||
*/
|
* @return The type of upgrade this is.
|
||||||
|
* @see TurtleUpgradeType for the differences between them.
|
||||||
|
*/
|
||||||
public TurtleUpgradeType getType();
|
public TurtleUpgradeType getType();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Return an item stack representing the type of item that a turtle must be crafted
|
* Return an item stack representing the type of item that a turtle must be crafted
|
||||||
* with to create a turtle which holds this upgrade. This item stack is also used
|
* with to create a turtle which holds this upgrade. This item stack is also used
|
||||||
* to determine the upgrade given by turtle.equip()
|
* to determine the upgrade given by {@code turtle.equip()}
|
||||||
|
*
|
||||||
|
* @return The item stack to craft with, or {@code null} if it cannot be crafted.
|
||||||
*/
|
*/
|
||||||
public ItemStack getCraftingItem();
|
public ItemStack getCraftingItem();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Will only be called for peripheral upgrades. Creates a peripheral for a turtle
|
* Will only be called for peripheral upgrades. Creates a peripheral for a turtle being placed using this upgrade.
|
||||||
* being placed using this upgrade. The peripheral created will be stored
|
*
|
||||||
* for the lifetime of the upgrade, will have update() called once-per-tick, and will be
|
* The peripheral created will be stored for the lifetime of the upgrade and will be passed as an argument to
|
||||||
* attached, detached and have methods called in the same manner as a Computer peripheral.
|
* {@link #update(ITurtleAccess, TurtleSide)}. It will be attached, detached and have methods called in the same
|
||||||
|
* manner as a Computer peripheral.
|
||||||
*
|
*
|
||||||
* @param turtle Access to the turtle that the peripheral is being created for.
|
* @param turtle Access to the turtle that the peripheral is being created for.
|
||||||
* @param side Which side of the turtle (left or right) that the upgrade resides on.
|
* @param side Which side of the turtle (left or right) that the upgrade resides on.
|
||||||
* @return The newly created peripheral. You may return null if this upgrade is a Tool
|
* @return The newly created peripheral. You may return {@code null} if this upgrade is a Tool
|
||||||
* and this method is not expected to be called.
|
* and this method is not expected to be called.
|
||||||
*/
|
*/
|
||||||
public IPeripheral createPeripheral( ITurtleAccess turtle, TurtleSide side );
|
public IPeripheral createPeripheral( ITurtleAccess turtle, TurtleSide side );
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Will only be called for Tool turtle. Called when turtle.dig() or turtle.attack() is called
|
* Will only be called for Tool turtle. Called when turtle.dig() or turtle.attack() is called
|
||||||
* by the turtle, and the tool is required to do some work.
|
* by the turtle, and the tool is required to do some work.
|
||||||
* @param turtle Access to the turtle that the tool resides on.
|
*
|
||||||
* @param side Which side of the turtle (left or right) the tool resides on.
|
* @param turtle Access to the turtle that the tool resides on.
|
||||||
* @param verb Which action (dig or attack) the turtle is being called on to perform.
|
* @param side Which side of the turtle (left or right) the tool resides on.
|
||||||
|
* @param verb Which action (dig or attack) the turtle is being called on to perform.
|
||||||
* @param direction Which world direction the action should be performed in, relative to the turtles
|
* @param direction Which world direction the action should be performed in, relative to the turtles
|
||||||
* position. This will either be up, down, or the direction the turtle is facing, depending on
|
* position. This will either be up, down, or the direction the turtle is facing, depending on
|
||||||
* whether dig, digUp or digDown was called.
|
* whether dig, digUp or digDown was called.
|
||||||
* @return Whether the turtle was able to perform the action, and hence whether the turtle.dig()
|
* @return Whether the turtle was able to perform the action, and hence whether the {@code turtle.dig()}
|
||||||
* or turtle.attack() lua method should return true. If true is returned, the tool will perform
|
* or {@code turtle.attack()} lua method should return true. If true is returned, the tool will perform
|
||||||
* a swinging animation. You may return null if this turtle is a Peripheral
|
* a swinging animation. You may return {@code null} if this turtle is a Peripheral and this method is not expected
|
||||||
* and this method is not expected to be called.
|
* to be called.
|
||||||
*/
|
*/
|
||||||
public TurtleCommandResult useTool( ITurtleAccess turtle, TurtleSide side, TurtleVerb verb, EnumFacing direction );
|
public TurtleCommandResult useTool( ITurtleAccess turtle, TurtleSide side, TurtleVerb verb, EnumFacing direction );
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Called to obtain the model to be used when rendering a turtle peripheral.
|
* Called to obtain the model to be used when rendering a turtle peripheral.
|
||||||
|
*
|
||||||
|
* This can be obtained from {@link net.minecraft.client.renderer.ItemModelMesher#getItemModel(ItemStack)},
|
||||||
|
* {@link net.minecraft.client.renderer.block.model.ModelManager#getModel(ModelResourceLocation)} or any other
|
||||||
|
* source.
|
||||||
|
*
|
||||||
* @param turtle Access to the turtle that the upgrade resides on. This will be null when getting item models!
|
* @param turtle Access to the turtle that the upgrade resides on. This will be null when getting item models!
|
||||||
* @param side Which side of the turtle (left or right) the upgrade resides on.
|
* @param side Which side of the turtle (left or right) the upgrade resides on.
|
||||||
* @return The model that you wish to be used to render your upgrade, and a transformation to apply to it. Returning a transformation of null has the same effect as the identify matrix.
|
* @return The model that you wish to be used to render your upgrade, and a transformation to apply to it. Returning
|
||||||
|
* a transformation of {@code null} has the same effect as the identify matrix.
|
||||||
*/
|
*/
|
||||||
@SideOnly( Side.CLIENT )
|
@SideOnly(Side.CLIENT)
|
||||||
public Pair<IBakedModel, Matrix4f> getModel( ITurtleAccess turtle, TurtleSide side );
|
public Pair<IBakedModel, Matrix4f> getModel( ITurtleAccess turtle, TurtleSide side );
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Called once per tick for each turtle which has the upgrade equipped.
|
* Called once per tick for each turtle which has the upgrade equipped.
|
||||||
|
*
|
||||||
* @param turtle Access to the turtle that the upgrade resides on.
|
* @param turtle Access to the turtle that the upgrade resides on.
|
||||||
* @param side Which side of the turtle (left or right) the upgrade resides on.
|
* @param side Which side of the turtle (left or right) the upgrade resides on.
|
||||||
*/
|
*/
|
||||||
public void update( ITurtleAccess turtle, TurtleSide side );
|
public void update( ITurtleAccess turtle, TurtleSide side );
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/**
|
/*
|
||||||
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
||||||
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
||||||
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
||||||
@ -6,17 +6,82 @@
|
|||||||
|
|
||||||
package dan200.computercraft.api.turtle;
|
package dan200.computercraft.api.turtle;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* An animation a turtle will play between executing commands.
|
||||||
|
*
|
||||||
|
* Each animation takes 8 ticks to complete unless otherwise specified.
|
||||||
|
*
|
||||||
|
* @see ITurtleAccess#playAnimation(TurtleAnimation)
|
||||||
|
*/
|
||||||
public enum TurtleAnimation
|
public enum TurtleAnimation
|
||||||
{
|
{
|
||||||
|
/**
|
||||||
|
* An animation which does nothing. This takes no time to complete.
|
||||||
|
*
|
||||||
|
* @see #Wait
|
||||||
|
* @see #ShortWait
|
||||||
|
*/
|
||||||
None,
|
None,
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Make the turtle move forward. Note that the animation starts from the block <em>behind</em> it, and
|
||||||
|
* moves into this one.
|
||||||
|
*/
|
||||||
MoveForward,
|
MoveForward,
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Make the turtle move backwards. Note that the animation starts from the block <em>in front</em> it, and
|
||||||
|
* moves into this one.
|
||||||
|
*/
|
||||||
MoveBack,
|
MoveBack,
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Make the turtle move backwards. Note that the animation starts from the block <em>above</em> it, and
|
||||||
|
* moves into this one.
|
||||||
|
*/
|
||||||
MoveUp,
|
MoveUp,
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Make the turtle move backwards. Note that the animation starts from the block <em>below</em> it, and
|
||||||
|
* moves into this one.
|
||||||
|
*/
|
||||||
MoveDown,
|
MoveDown,
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Turn the turtle to the left. Note that the animation starts with the turtle facing <em>right</em>, and
|
||||||
|
* the turtle turns to face in the current direction.
|
||||||
|
*/
|
||||||
TurnLeft,
|
TurnLeft,
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Turn the turtle to the left. Note that the animation starts with the turtle facing <em>right</em>, and
|
||||||
|
* the turtle turns to face in the current direction.
|
||||||
|
*/
|
||||||
TurnRight,
|
TurnRight,
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Swing the tool on the left.
|
||||||
|
*/
|
||||||
SwingLeftTool,
|
SwingLeftTool,
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Swing the tool on the right.
|
||||||
|
*/
|
||||||
SwingRightTool,
|
SwingRightTool,
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Wait until the animation has finished, performing no movement.
|
||||||
|
*
|
||||||
|
* @see #ShortWait
|
||||||
|
* @see #None
|
||||||
|
*/
|
||||||
Wait,
|
Wait,
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Wait until the animation has finished, performing no movement. This takes 4 ticks to complete.
|
||||||
|
*
|
||||||
|
* @see #Wait
|
||||||
|
* @see #None
|
||||||
|
*/
|
||||||
ShortWait,
|
ShortWait,
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/**
|
/*
|
||||||
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
||||||
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
||||||
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
||||||
@ -6,16 +6,35 @@
|
|||||||
|
|
||||||
package dan200.computercraft.api.turtle;
|
package dan200.computercraft.api.turtle;
|
||||||
|
|
||||||
|
import net.minecraft.util.EnumFacing;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Used to indicate the result of executing a turtle command.
|
||||||
|
*
|
||||||
|
* @see ITurtleCommand#execute(ITurtleAccess)
|
||||||
|
* @see ITurtleUpgrade#useTool(ITurtleAccess, TurtleSide, TurtleVerb, EnumFacing)
|
||||||
|
*/
|
||||||
public final class TurtleCommandResult
|
public final class TurtleCommandResult
|
||||||
{
|
{
|
||||||
private static final TurtleCommandResult s_success = new TurtleCommandResult( true, null, null );
|
private static final TurtleCommandResult s_success = new TurtleCommandResult( true, null, null );
|
||||||
private static final TurtleCommandResult s_emptyFailure = new TurtleCommandResult( false, null, null );
|
private static final TurtleCommandResult s_emptyFailure = new TurtleCommandResult( false, null, null );
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a successful command result with no result.
|
||||||
|
*
|
||||||
|
* @return A successful command result with no values.
|
||||||
|
*/
|
||||||
public static TurtleCommandResult success()
|
public static TurtleCommandResult success()
|
||||||
{
|
{
|
||||||
return success( null );
|
return success( null );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a successful command result with the given result values.
|
||||||
|
*
|
||||||
|
* @param results The results of executing this command.
|
||||||
|
* @return A successful command result with the given values.
|
||||||
|
*/
|
||||||
public static TurtleCommandResult success( Object[] results )
|
public static TurtleCommandResult success( Object[] results )
|
||||||
{
|
{
|
||||||
if( results == null || results.length == 0 )
|
if( results == null || results.length == 0 )
|
||||||
@ -28,11 +47,22 @@ public final class TurtleCommandResult
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a failed command result with no error message.
|
||||||
|
*
|
||||||
|
* @return A failed command result with no message.
|
||||||
|
*/
|
||||||
public static TurtleCommandResult failure()
|
public static TurtleCommandResult failure()
|
||||||
{
|
{
|
||||||
return failure( null );
|
return failure( null );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a failed command result with an error message.
|
||||||
|
*
|
||||||
|
* @param errorMessage The error message to provide.
|
||||||
|
* @return A failed command result with a message.
|
||||||
|
*/
|
||||||
public static TurtleCommandResult failure( String errorMessage )
|
public static TurtleCommandResult failure( String errorMessage )
|
||||||
{
|
{
|
||||||
if( errorMessage == null )
|
if( errorMessage == null )
|
||||||
@ -56,16 +86,31 @@ public final class TurtleCommandResult
|
|||||||
m_results = results;
|
m_results = results;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Determine whether the command executed successfully.
|
||||||
|
*
|
||||||
|
* @return If the command was successful.
|
||||||
|
*/
|
||||||
public boolean isSuccess()
|
public boolean isSuccess()
|
||||||
{
|
{
|
||||||
return m_success;
|
return m_success;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the error message of this command result.
|
||||||
|
*
|
||||||
|
* @return The command's error message, or {@code null} if it was a success.
|
||||||
|
*/
|
||||||
public String getErrorMessage()
|
public String getErrorMessage()
|
||||||
{
|
{
|
||||||
return m_errorMessage;
|
return m_errorMessage;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the resulting values of this command result.
|
||||||
|
*
|
||||||
|
* @return The command's result, or {@code null} if it was a failure.
|
||||||
|
*/
|
||||||
public Object[] getResults()
|
public Object[] getResults()
|
||||||
{
|
{
|
||||||
return m_results;
|
return m_results;
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/**
|
/*
|
||||||
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
||||||
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
||||||
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
||||||
@ -12,12 +12,12 @@ package dan200.computercraft.api.turtle;
|
|||||||
public enum TurtleSide
|
public enum TurtleSide
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* The turtles left side (where the pickaxe usually is on a Wireless Mining Turtle)
|
* The turtle's left side (where the pickaxe usually is on a Wireless Mining Turtle)
|
||||||
*/
|
*/
|
||||||
Left,
|
Left,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The turtles right side (where the modem usually is on a Wireless Mining Turtle)
|
* The turtle's right side (where the modem usually is on a Wireless Mining Turtle)
|
||||||
*/
|
*/
|
||||||
Right,
|
Right,
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/**
|
/*
|
||||||
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
||||||
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
||||||
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
||||||
@ -7,21 +7,38 @@
|
|||||||
package dan200.computercraft.api.turtle;
|
package dan200.computercraft.api.turtle;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* An enum representing the two different types of turtle that an ITurtleUpgrade
|
* An enum representing the different types of turtle that an {@link ITurtleUpgrade} implementation can add to a turtle.
|
||||||
* implementation can add to a turtle.
|
*
|
||||||
* @see ITurtleUpgrade
|
* @see ITurtleUpgrade#getType()
|
||||||
*/
|
*/
|
||||||
public enum TurtleUpgradeType
|
public enum TurtleUpgradeType
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* A tool is rendered as an item on the side of the turtle, and responds to the turtle.dig()
|
* A tool is rendered as an item on the side of the turtle, and responds to the {@code turtle.dig()}
|
||||||
* and turtle.attack() methods (Such as pickaxe or sword on Mining and Melee turtles).
|
* and {@code turtle.attack()} methods (Such as pickaxe or sword on Mining and Melee turtles).
|
||||||
*/
|
*/
|
||||||
Tool,
|
Tool,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A peripheral adds a special peripheral which is attached to the side of the turtle,
|
* A peripheral adds a special peripheral which is attached to the side of the turtle,
|
||||||
* and can be interacted with the peripheral API (Such as the modem on Wireless Turtles).
|
* and can be interacted with the {@code peripheral} API (Such as the modem on Wireless Turtles).
|
||||||
*/
|
*/
|
||||||
Peripheral,
|
Peripheral,
|
||||||
|
|
||||||
|
/**
|
||||||
|
* An upgrade which provides both a tool and a peripheral. This can be used when you wish
|
||||||
|
* your upgrade to also provide methods. For example, a pickaxe could provide methods
|
||||||
|
* determining whether it can break the given block or not.
|
||||||
|
*/
|
||||||
|
Both,;
|
||||||
|
|
||||||
|
public boolean isTool()
|
||||||
|
{
|
||||||
|
return this == Tool || this == Both;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isPeripheral()
|
||||||
|
{
|
||||||
|
return this == Peripheral || this == Both;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/**
|
/*
|
||||||
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
||||||
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
||||||
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
||||||
@ -6,21 +6,24 @@
|
|||||||
|
|
||||||
package dan200.computercraft.api.turtle;
|
package dan200.computercraft.api.turtle;
|
||||||
|
|
||||||
|
import net.minecraft.util.EnumFacing;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* An enum representing the two different actions that an ITurtleUpgrade of type
|
* An enum representing the different actions that an {@link ITurtleUpgrade} of type Tool may be called on to perform by
|
||||||
* Tool may be called on to perform by a turtle.
|
* a turtle.
|
||||||
* @see ITurtleUpgrade
|
*
|
||||||
* @see ITurtleUpgrade#useTool
|
* @see ITurtleUpgrade#getType()
|
||||||
|
* @see ITurtleUpgrade#useTool(ITurtleAccess, TurtleSide, TurtleVerb, EnumFacing)
|
||||||
*/
|
*/
|
||||||
public enum TurtleVerb
|
public enum TurtleVerb
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* The turtle called turtle.dig(), turtle.digUp() or turtle.digDown()
|
* The turtle called {@code turtle.dig()}, {@code turtle.digUp()} or {@code turtle.digDown()}
|
||||||
*/
|
*/
|
||||||
Dig,
|
Dig,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The turtle called turtle.attack(), turtle.attackUp() or turtle.attackDown()
|
* The turtle called {@code turtle.attack()}, {@code turtle.attackUp()} or {@code turtle.attackDown()}
|
||||||
*/
|
*/
|
||||||
Attack,
|
Attack,
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/**
|
/*
|
||||||
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
* This file is part of the public ComputerCraft API - http://www.computercraft.info
|
||||||
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
* Copyright Daniel Ratcliffe, 2011-2016. This API may be redistributed unmodified and in full only.
|
||||||
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
* For help using the API, and posting your mods, visit the forums at computercraft.info.
|
||||||
|
@ -8,6 +8,7 @@ package dan200.computercraft.client.gui;
|
|||||||
|
|
||||||
import dan200.computercraft.core.terminal.TextBuffer;
|
import dan200.computercraft.core.terminal.TextBuffer;
|
||||||
import dan200.computercraft.shared.util.Colour;
|
import dan200.computercraft.shared.util.Colour;
|
||||||
|
import net.minecraft.client.renderer.GlStateManager;
|
||||||
import net.minecraft.client.renderer.Tessellator;
|
import net.minecraft.client.renderer.Tessellator;
|
||||||
import net.minecraft.client.renderer.VertexBuffer;
|
import net.minecraft.client.renderer.VertexBuffer;
|
||||||
import net.minecraft.client.renderer.texture.TextureManager;
|
import net.minecraft.client.renderer.texture.TextureManager;
|
||||||
@ -35,19 +36,23 @@ public class FixedWidthFontRenderer
|
|||||||
int column = index % 16;
|
int column = index % 16;
|
||||||
int row = index / 16;
|
int row = index / 16;
|
||||||
Colour colour = Colour.values()[ 15 - color ];
|
Colour colour = Colour.values()[ 15 - color ];
|
||||||
|
renderer.pos( x, y, 0.0 ).tex( (double) (column * FONT_WIDTH) / 256.0, (double) (row * FONT_HEIGHT ) / 256.0 ).color( colour.getR(), colour.getG(), colour.getB(), 1.0f ).endVertex();
|
||||||
|
renderer.pos( x, y + FONT_HEIGHT, 0.0 ).tex( (double) (column * FONT_WIDTH) / 256.0, (double) ((row + 1) * FONT_HEIGHT) / 256.0 ).color( colour.getR(), colour.getG(), colour.getB(), 1.0f ).endVertex();
|
||||||
|
renderer.pos( x + FONT_WIDTH, y, 0.0 ).tex( (double) ((column + 1) * FONT_WIDTH) / 256.0, (double) (row * FONT_HEIGHT) / 256.0 ).color( colour.getR(), colour.getG(), colour.getB(), 1.0f ).endVertex();
|
||||||
|
renderer.pos( x + FONT_WIDTH, y, 0.0 ).tex( (double) ((column + 1) * FONT_WIDTH) / 256.0, (double) (row * FONT_HEIGHT) / 256.0 ).color( colour.getR(), colour.getG(), colour.getB(), 1.0f ).endVertex();
|
||||||
renderer.pos( x, y + FONT_HEIGHT, 0.0 ).tex( (double) (column * FONT_WIDTH) / 256.0, (double) ((row + 1) * FONT_HEIGHT) / 256.0 ).color( colour.getR(), colour.getG(), colour.getB(), 1.0f ).endVertex();
|
renderer.pos( x, y + FONT_HEIGHT, 0.0 ).tex( (double) (column * FONT_WIDTH) / 256.0, (double) ((row + 1) * FONT_HEIGHT) / 256.0 ).color( colour.getR(), colour.getG(), colour.getB(), 1.0f ).endVertex();
|
||||||
renderer.pos( x + FONT_WIDTH, y + FONT_HEIGHT, 0.0 ).tex( (double) ((column + 1) * FONT_WIDTH) / 256.0, (double) ((row + 1) * FONT_HEIGHT) / 256.0 ).color( colour.getR(), colour.getG(), colour.getB(), 1.0f ).endVertex();
|
renderer.pos( x + FONT_WIDTH, y + FONT_HEIGHT, 0.0 ).tex( (double) ((column + 1) * FONT_WIDTH) / 256.0, (double) ((row + 1) * FONT_HEIGHT) / 256.0 ).color( colour.getR(), colour.getG(), colour.getB(), 1.0f ).endVertex();
|
||||||
renderer.pos( x + FONT_WIDTH, y, 0.0 ).tex( (double) ((column + 1) * FONT_WIDTH) / 256.0, (double) (row * FONT_HEIGHT) / 256.0 ).color( colour.getR(), colour.getG(), colour.getB(), 1.0f ).endVertex();
|
|
||||||
renderer.pos( x, y, 0.0 ).tex( (double) (column * FONT_WIDTH) / 256.0, (double) (row * FONT_HEIGHT ) / 256.0 ).color( colour.getR(), colour.getG(), colour.getB(), 1.0f ).endVertex();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void drawQuad( VertexBuffer renderer, double x, double y, int color, double width )
|
private void drawQuad( VertexBuffer renderer, double x, double y, int color, double width )
|
||||||
{
|
{
|
||||||
Colour colour = Colour.values()[ 15 - color ];
|
Colour colour = Colour.values()[ 15 - color ];
|
||||||
renderer.pos( x, y + FONT_HEIGHT, 0.0 ).tex( 0.0, 1.0 ).color( colour.getR(), colour.getG(), colour.getB(), 1.0f ).endVertex();
|
renderer.pos( x, y, 0.0 ).color( colour.getR(), colour.getG(), colour.getB(), 1.0f ).endVertex();
|
||||||
renderer.pos( x + width, y + FONT_HEIGHT, 0.0 ).tex( 1.0, 1.0 ).color( colour.getR(), colour.getG(), colour.getB(), 1.0f ).endVertex();
|
renderer.pos( x, y + FONT_HEIGHT, 0.0 ).color( colour.getR(), colour.getG(), colour.getB(), 1.0f ).endVertex();
|
||||||
renderer.pos( x + width, y, 0.0 ).tex( 1.0, 0.0 ).color( colour.getR(), colour.getG(), colour.getB(), 1.0f ).endVertex();
|
renderer.pos( x + width, y, 0.0 ).color( colour.getR(), colour.getG(), colour.getB(), 1.0f ).endVertex();
|
||||||
renderer.pos( x, y, 0.0 ).tex( 0.0, 0.0 ).color( colour.getR(), colour.getG(), colour.getB(), 1.0f ).endVertex();
|
renderer.pos( x + width, y, 0.0 ).color( colour.getR(), colour.getG(), colour.getB(), 1.0f ).endVertex();
|
||||||
|
renderer.pos( x, y + FONT_HEIGHT, 0.0 ).color( colour.getR(), colour.getG(), colour.getB(), 1.0f ).endVertex();
|
||||||
|
renderer.pos( x + width, y + FONT_HEIGHT, 0.0 ).color( colour.getR(), colour.getG(), colour.getB(), 1.0f ).endVertex();
|
||||||
}
|
}
|
||||||
|
|
||||||
private boolean isGreyScale( int colour )
|
private boolean isGreyScale( int colour )
|
||||||
@ -60,7 +65,7 @@ public class FixedWidthFontRenderer
|
|||||||
// Draw the quads
|
// Draw the quads
|
||||||
Tessellator tessellator = Tessellator.getInstance();
|
Tessellator tessellator = Tessellator.getInstance();
|
||||||
VertexBuffer renderer = tessellator.getBuffer();
|
VertexBuffer renderer = tessellator.getBuffer();
|
||||||
renderer.begin( GL11.GL_QUADS, DefaultVertexFormats.POSITION_TEX_COLOR );
|
renderer.begin( GL11.GL_TRIANGLES, DefaultVertexFormats.POSITION_COLOR );
|
||||||
if( leftMarginSize > 0.0 )
|
if( leftMarginSize > 0.0 )
|
||||||
{
|
{
|
||||||
int colour1 = "0123456789abcdef".indexOf( backgroundColour.charAt( 0 ) );
|
int colour1 = "0123456789abcdef".indexOf( backgroundColour.charAt( 0 ) );
|
||||||
@ -88,7 +93,9 @@ public class FixedWidthFontRenderer
|
|||||||
}
|
}
|
||||||
drawQuad( renderer, x + i * FONT_WIDTH, y, colour, FONT_WIDTH );
|
drawQuad( renderer, x + i * FONT_WIDTH, y, colour, FONT_WIDTH );
|
||||||
}
|
}
|
||||||
|
GlStateManager.disableTexture2D();
|
||||||
tessellator.draw();
|
tessellator.draw();
|
||||||
|
GlStateManager.enableTexture2D();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void drawStringTextPart( int x, int y, TextBuffer s, TextBuffer textColour, boolean greyScale )
|
public void drawStringTextPart( int x, int y, TextBuffer s, TextBuffer textColour, boolean greyScale )
|
||||||
@ -96,7 +103,7 @@ public class FixedWidthFontRenderer
|
|||||||
// Draw the quads
|
// Draw the quads
|
||||||
Tessellator tessellator = Tessellator.getInstance();
|
Tessellator tessellator = Tessellator.getInstance();
|
||||||
VertexBuffer renderer = tessellator.getBuffer();
|
VertexBuffer renderer = tessellator.getBuffer();
|
||||||
renderer.begin( GL11.GL_QUADS, DefaultVertexFormats.POSITION_TEX_COLOR );
|
renderer.begin( GL11.GL_TRIANGLES, DefaultVertexFormats.POSITION_TEX_COLOR );
|
||||||
for( int i = 0; i < s.length(); i++ )
|
for( int i = 0; i < s.length(); i++ )
|
||||||
{
|
{
|
||||||
// Switch colour
|
// Switch colour
|
||||||
|
@ -407,23 +407,22 @@ public class WidgetTerminal extends Widget
|
|||||||
TextBuffer colour = terminal.getTextColourLine( line );
|
TextBuffer colour = terminal.getTextColourLine( line );
|
||||||
TextBuffer backgroundColour = terminal.getBackgroundColourLine( line );
|
TextBuffer backgroundColour = terminal.getBackgroundColourLine( line );
|
||||||
fontRenderer.drawString( text, x, y, colour, backgroundColour, m_leftMargin, m_rightMargin, greyscale );
|
fontRenderer.drawString( text, x, y, colour, backgroundColour, m_leftMargin, m_rightMargin, greyscale );
|
||||||
if( tblink && ty == line )
|
y += FixedWidthFontRenderer.FONT_HEIGHT;
|
||||||
{
|
}
|
||||||
if( tx >= 0 && tx < tw )
|
|
||||||
{
|
if( tblink && tx >= 0 && ty >= 0 && tx < tw && ty < th )
|
||||||
TextBuffer cursor = new TextBuffer( '_', 1 );
|
{
|
||||||
TextBuffer cursorColour = new TextBuffer( "0123456789abcdef".charAt( terminal.getTextColour() ), 1 );
|
TextBuffer cursor = new TextBuffer( '_', 1 );
|
||||||
fontRenderer.drawString(
|
TextBuffer cursorColour = new TextBuffer( "0123456789abcdef".charAt( terminal.getTextColour() ), 1 );
|
||||||
cursor,
|
|
||||||
x + FixedWidthFontRenderer.FONT_WIDTH * tx,
|
fontRenderer.drawString(
|
||||||
y,
|
cursor,
|
||||||
cursorColour, null,
|
x + FixedWidthFontRenderer.FONT_WIDTH * tx,
|
||||||
0, 0,
|
startY + m_topMargin + FixedWidthFontRenderer.FONT_HEIGHT * ty,
|
||||||
greyscale
|
cursorColour, null,
|
||||||
);
|
0, 0,
|
||||||
}
|
greyscale
|
||||||
}
|
);
|
||||||
y = y + FixedWidthFontRenderer.FONT_HEIGHT;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -20,12 +20,14 @@ import dan200.computercraft.shared.network.ComputerCraftPacket;
|
|||||||
import dan200.computercraft.shared.peripheral.diskdrive.TileDiskDrive;
|
import dan200.computercraft.shared.peripheral.diskdrive.TileDiskDrive;
|
||||||
import dan200.computercraft.shared.peripheral.monitor.TileMonitor;
|
import dan200.computercraft.shared.peripheral.monitor.TileMonitor;
|
||||||
import dan200.computercraft.shared.peripheral.printer.TilePrinter;
|
import dan200.computercraft.shared.peripheral.printer.TilePrinter;
|
||||||
|
import dan200.computercraft.shared.pocket.inventory.ContainerPocketComputer;
|
||||||
import dan200.computercraft.shared.pocket.items.ItemPocketComputer;
|
import dan200.computercraft.shared.pocket.items.ItemPocketComputer;
|
||||||
import dan200.computercraft.shared.proxy.ComputerCraftProxyCommon;
|
import dan200.computercraft.shared.proxy.ComputerCraftProxyCommon;
|
||||||
import dan200.computercraft.shared.turtle.blocks.TileTurtle;
|
import dan200.computercraft.shared.turtle.blocks.TileTurtle;
|
||||||
import dan200.computercraft.shared.turtle.entity.TurtleVisionCamera;
|
import dan200.computercraft.shared.turtle.entity.TurtleVisionCamera;
|
||||||
import net.minecraft.block.Block;
|
import net.minecraft.block.Block;
|
||||||
import net.minecraft.client.Minecraft;
|
import net.minecraft.client.Minecraft;
|
||||||
|
import net.minecraft.client.renderer.GlStateManager;
|
||||||
import net.minecraft.client.renderer.ItemMeshDefinition;
|
import net.minecraft.client.renderer.ItemMeshDefinition;
|
||||||
import net.minecraft.client.renderer.block.model.ModelBakery;
|
import net.minecraft.client.renderer.block.model.ModelBakery;
|
||||||
import net.minecraft.client.renderer.block.model.ModelResourceLocation;
|
import net.minecraft.client.renderer.block.model.ModelResourceLocation;
|
||||||
@ -255,7 +257,7 @@ public class ComputerCraftProxyClient extends ComputerCraftProxyCommon
|
|||||||
@Override
|
@Override
|
||||||
public void deleteDisplayLists( int list, int range )
|
public void deleteDisplayLists( int list, int range )
|
||||||
{
|
{
|
||||||
GL11.glDeleteLists( list, range );
|
GlStateManager.glDeleteLists( list, range );
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -325,7 +327,7 @@ public class ComputerCraftProxyClient extends ComputerCraftProxyCommon
|
|||||||
@Override
|
@Override
|
||||||
public Object getPocketComputerGUI( EntityPlayer player, EnumHand hand )
|
public Object getPocketComputerGUI( EntityPlayer player, EnumHand hand )
|
||||||
{
|
{
|
||||||
ContainerHeldItem container = new ContainerHeldItem( player, hand );
|
ContainerPocketComputer container = new ContainerPocketComputer( player, hand );
|
||||||
if( container.getStack() != null && container.getStack().getItem() instanceof ItemPocketComputer )
|
if( container.getStack() != null && container.getStack().getItem() instanceof ItemPocketComputer )
|
||||||
{
|
{
|
||||||
return new GuiPocketComputer( container );
|
return new GuiPocketComputer( container );
|
||||||
@ -410,7 +412,6 @@ public class ComputerCraftProxyClient extends ComputerCraftProxyCommon
|
|||||||
private void registerForgeHandlers()
|
private void registerForgeHandlers()
|
||||||
{
|
{
|
||||||
ForgeHandlers handlers = new ForgeHandlers();
|
ForgeHandlers handlers = new ForgeHandlers();
|
||||||
FMLCommonHandler.instance().bus().register( handlers );
|
|
||||||
MinecraftForge.EVENT_BUS.register( handlers );
|
MinecraftForge.EVENT_BUS.register( handlers );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -11,7 +11,6 @@ import dan200.computercraft.client.gui.FixedWidthFontRenderer;
|
|||||||
import dan200.computercraft.core.terminal.Terminal;
|
import dan200.computercraft.core.terminal.Terminal;
|
||||||
import dan200.computercraft.core.terminal.TextBuffer;
|
import dan200.computercraft.core.terminal.TextBuffer;
|
||||||
import dan200.computercraft.shared.common.ClientTerminal;
|
import dan200.computercraft.shared.common.ClientTerminal;
|
||||||
import dan200.computercraft.shared.common.ITerminal;
|
|
||||||
import dan200.computercraft.shared.peripheral.monitor.TileMonitor;
|
import dan200.computercraft.shared.peripheral.monitor.TileMonitor;
|
||||||
import dan200.computercraft.shared.util.Colour;
|
import dan200.computercraft.shared.util.Colour;
|
||||||
import dan200.computercraft.shared.util.DirectionUtil;
|
import dan200.computercraft.shared.util.DirectionUtil;
|
||||||
@ -21,11 +20,8 @@ import net.minecraft.client.renderer.Tessellator;
|
|||||||
import net.minecraft.client.renderer.VertexBuffer;
|
import net.minecraft.client.renderer.VertexBuffer;
|
||||||
import net.minecraft.client.renderer.tileentity.TileEntitySpecialRenderer;
|
import net.minecraft.client.renderer.tileentity.TileEntitySpecialRenderer;
|
||||||
import net.minecraft.client.renderer.vertex.DefaultVertexFormats;
|
import net.minecraft.client.renderer.vertex.DefaultVertexFormats;
|
||||||
import net.minecraft.tileentity.TileEntity;
|
|
||||||
import net.minecraft.util.math.BlockPos;
|
|
||||||
import net.minecraft.util.EnumFacing;
|
import net.minecraft.util.EnumFacing;
|
||||||
import net.minecraft.util.ResourceLocation;
|
import net.minecraft.util.math.BlockPos;
|
||||||
import net.minecraftforge.client.MinecraftForgeClient;
|
|
||||||
import org.lwjgl.opengl.GL11;
|
import org.lwjgl.opengl.GL11;
|
||||||
|
|
||||||
public class TileEntityMonitorRenderer extends TileEntitySpecialRenderer<TileMonitor>
|
public class TileEntityMonitorRenderer extends TileEntitySpecialRenderer<TileMonitor>
|
||||||
@ -104,6 +100,7 @@ public class TileEntityMonitorRenderer extends TileEntitySpecialRenderer<TileMon
|
|||||||
// Draw the contents
|
// Draw the contents
|
||||||
GlStateManager.depthMask( false );
|
GlStateManager.depthMask( false );
|
||||||
GlStateManager.disableLighting();
|
GlStateManager.disableLighting();
|
||||||
|
mc.entityRenderer.disableLightmap();
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
if( terminal != null )
|
if( terminal != null )
|
||||||
@ -111,7 +108,7 @@ public class TileEntityMonitorRenderer extends TileEntitySpecialRenderer<TileMon
|
|||||||
// Allocate display lists
|
// Allocate display lists
|
||||||
if( origin.m_renderDisplayList < 0 )
|
if( origin.m_renderDisplayList < 0 )
|
||||||
{
|
{
|
||||||
origin.m_renderDisplayList = GL11.glGenLists( 3 );
|
origin.m_renderDisplayList = GlStateManager.glGenLists( 3 );
|
||||||
redraw = true;
|
redraw = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -135,7 +132,7 @@ public class TileEntityMonitorRenderer extends TileEntitySpecialRenderer<TileMon
|
|||||||
if( redraw )
|
if( redraw )
|
||||||
{
|
{
|
||||||
// Build background display list
|
// Build background display list
|
||||||
GL11.glNewList( origin.m_renderDisplayList, GL11.GL_COMPILE );
|
GlStateManager.glNewList( origin.m_renderDisplayList, GL11.GL_COMPILE );
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
double marginXSize = TileMonitor.RENDER_MARGIN / xScale;
|
double marginXSize = TileMonitor.RENDER_MARGIN / xScale;
|
||||||
@ -143,18 +140,18 @@ public class TileEntityMonitorRenderer extends TileEntitySpecialRenderer<TileMon
|
|||||||
double marginSquash = marginYSize / (double) FixedWidthFontRenderer.FONT_HEIGHT;
|
double marginSquash = marginYSize / (double) FixedWidthFontRenderer.FONT_HEIGHT;
|
||||||
|
|
||||||
// Top and bottom margins
|
// Top and bottom margins
|
||||||
GL11.glPushMatrix();
|
GlStateManager.pushMatrix();
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
GL11.glScaled( 1.0, marginSquash, 1.0 );
|
GlStateManager.scale( 1.0, marginSquash, 1.0 );
|
||||||
GL11.glTranslated( 0.0, -marginYSize / marginSquash, 0.0 );
|
GlStateManager.translate( 0.0, -marginYSize / marginSquash, 0.0 );
|
||||||
fontRenderer.drawStringBackgroundPart( 0, 0, terminal.getBackgroundColourLine( 0 ), marginXSize, marginXSize, greyscale );
|
fontRenderer.drawStringBackgroundPart( 0, 0, terminal.getBackgroundColourLine( 0 ), marginXSize, marginXSize, greyscale );
|
||||||
GL11.glTranslated( 0.0, ( marginYSize + height * FixedWidthFontRenderer.FONT_HEIGHT ) / marginSquash, 0.0 );
|
GlStateManager.translate( 0.0, ( marginYSize + height * FixedWidthFontRenderer.FONT_HEIGHT ) / marginSquash, 0.0 );
|
||||||
fontRenderer.drawStringBackgroundPart( 0, 0, terminal.getBackgroundColourLine( height - 1 ), marginXSize, marginXSize, greyscale );
|
fontRenderer.drawStringBackgroundPart( 0, 0, terminal.getBackgroundColourLine( height - 1 ), marginXSize, marginXSize, greyscale );
|
||||||
}
|
}
|
||||||
finally
|
finally
|
||||||
{
|
{
|
||||||
GL11.glPopMatrix();
|
GlStateManager.popMatrix();
|
||||||
}
|
}
|
||||||
|
|
||||||
// Backgrounds
|
// Backgrounds
|
||||||
@ -170,7 +167,7 @@ public class TileEntityMonitorRenderer extends TileEntitySpecialRenderer<TileMon
|
|||||||
}
|
}
|
||||||
finally
|
finally
|
||||||
{
|
{
|
||||||
GL11.glEndList();
|
GlStateManager.glEndList();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
GlStateManager.callList( origin.m_renderDisplayList );
|
GlStateManager.callList( origin.m_renderDisplayList );
|
||||||
@ -180,7 +177,7 @@ public class TileEntityMonitorRenderer extends TileEntitySpecialRenderer<TileMon
|
|||||||
if( redraw )
|
if( redraw )
|
||||||
{
|
{
|
||||||
// Build text display list
|
// Build text display list
|
||||||
GL11.glNewList( origin.m_renderDisplayList + 1, GL11.GL_COMPILE );
|
GlStateManager.glNewList( origin.m_renderDisplayList + 1, GL11.GL_COMPILE );
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
// Lines
|
// Lines
|
||||||
@ -196,7 +193,7 @@ public class TileEntityMonitorRenderer extends TileEntitySpecialRenderer<TileMon
|
|||||||
}
|
}
|
||||||
finally
|
finally
|
||||||
{
|
{
|
||||||
GL11.glEndList();
|
GlStateManager.glEndList();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
GlStateManager.callList( origin.m_renderDisplayList + 1 );
|
GlStateManager.callList( origin.m_renderDisplayList + 1 );
|
||||||
@ -206,7 +203,7 @@ public class TileEntityMonitorRenderer extends TileEntitySpecialRenderer<TileMon
|
|||||||
if( redraw )
|
if( redraw )
|
||||||
{
|
{
|
||||||
// Build cursor display list
|
// Build cursor display list
|
||||||
GL11.glNewList( origin.m_renderDisplayList + 2, GL11.GL_COMPILE );
|
GlStateManager.glNewList( origin.m_renderDisplayList + 2, GL11.GL_COMPILE );
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
// Cursor
|
// Cursor
|
||||||
@ -226,7 +223,7 @@ public class TileEntityMonitorRenderer extends TileEntitySpecialRenderer<TileMon
|
|||||||
}
|
}
|
||||||
finally
|
finally
|
||||||
{
|
{
|
||||||
GL11.glEndList();
|
GlStateManager.glEndList();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if( ComputerCraft.getGlobalCursorBlink() )
|
if( ComputerCraft.getGlobalCursorBlink() )
|
||||||
@ -243,19 +240,24 @@ public class TileEntityMonitorRenderer extends TileEntitySpecialRenderer<TileMon
|
|||||||
{
|
{
|
||||||
// Draw a big black quad
|
// Draw a big black quad
|
||||||
mc.getTextureManager().bindTexture( FixedWidthFontRenderer.background );
|
mc.getTextureManager().bindTexture( FixedWidthFontRenderer.background );
|
||||||
renderer.begin( GL11.GL_QUADS, DefaultVertexFormats.POSITION_TEX_COLOR );
|
final Colour colour = Colour.Black;
|
||||||
Colour colour = Colour.Black;
|
|
||||||
renderer.pos( -TileMonitor.RENDER_MARGIN, -ySize - TileMonitor.RENDER_MARGIN, 0.0 ).tex( 0.0, 1.0 ).color( colour.getR(), colour.getG(), colour.getB(), 1.0f ).endVertex();
|
final float r = colour.getR();
|
||||||
renderer.pos( xSize + TileMonitor.RENDER_MARGIN, -ySize - TileMonitor.RENDER_MARGIN, 0.0 ).tex( 1.0, 1.0 ).color( colour.getR(), colour.getG(), colour.getB(), 1.0f ).endVertex();
|
final float g = colour.getG();
|
||||||
renderer.pos( xSize + TileMonitor.RENDER_MARGIN, TileMonitor.RENDER_MARGIN, 0.0D ).tex( 1.0, 0.0 ).color( colour.getR(), colour.getG(), colour.getB(), 1.0f ).endVertex();
|
final float b = colour.getB();
|
||||||
renderer.pos( -TileMonitor.RENDER_MARGIN, TileMonitor.RENDER_MARGIN, 0.0D ).tex( 0.0, 0.0 ).color( colour.getR(), colour.getG(), colour.getB(), 1.0f ).endVertex();
|
|
||||||
renderer.pos( -TileMonitor.RENDER_MARGIN, -ySize - TileMonitor.RENDER_MARGIN, 0.0 ).tex( 0.0, 1.0 ).color( colour.getR(), colour.getG(), colour.getB(), 1.0f ).endVertex();
|
renderer.begin( GL11.GL_TRIANGLE_STRIP, DefaultVertexFormats.POSITION_TEX_COLOR );
|
||||||
|
renderer.pos( -TileMonitor.RENDER_MARGIN, TileMonitor.RENDER_MARGIN, 0.0D ).tex( 0.0, 0.0 ).color( r, g, b, 1.0f ).endVertex();
|
||||||
|
renderer.pos( -TileMonitor.RENDER_MARGIN, -ySize - TileMonitor.RENDER_MARGIN, 0.0 ).tex( 0.0, 1.0 ).color( r, g, b, 1.0f ).endVertex();
|
||||||
|
renderer.pos( xSize + TileMonitor.RENDER_MARGIN, TileMonitor.RENDER_MARGIN, 0.0D ).tex( 1.0, 0.0 ).color( r, g, b, 1.0f ).endVertex();
|
||||||
|
renderer.pos( xSize + TileMonitor.RENDER_MARGIN, -ySize - TileMonitor.RENDER_MARGIN, 0.0 ).tex( 1.0, 1.0 ).color( r, g, b, 1.0f ).endVertex();
|
||||||
tessellator.draw();
|
tessellator.draw();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
finally
|
finally
|
||||||
{
|
{
|
||||||
GlStateManager.depthMask( true );
|
GlStateManager.depthMask( true );
|
||||||
|
mc.entityRenderer.enableLightmap();
|
||||||
GlStateManager.enableLighting();
|
GlStateManager.enableLighting();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -264,13 +266,11 @@ public class TileEntityMonitorRenderer extends TileEntitySpecialRenderer<TileMon
|
|||||||
try
|
try
|
||||||
{
|
{
|
||||||
mc.getTextureManager().bindTexture( FixedWidthFontRenderer.background );
|
mc.getTextureManager().bindTexture( FixedWidthFontRenderer.background );
|
||||||
renderer.begin( GL11.GL_QUADS, DefaultVertexFormats.POSITION_TEX_COLOR );
|
renderer.begin( GL11.GL_TRIANGLE_STRIP, DefaultVertexFormats.POSITION );
|
||||||
Colour colour = Colour.Black;
|
renderer.pos( -TileMonitor.RENDER_MARGIN, TileMonitor.RENDER_MARGIN, 0.0 ).endVertex();
|
||||||
renderer.pos( -TileMonitor.RENDER_MARGIN, -ySize - TileMonitor.RENDER_MARGIN, 0.0 ).tex( 0.0, 1.0 ).color( colour.getR(), colour.getG(), colour.getB(), 1.0f ).endVertex();
|
renderer.pos( -TileMonitor.RENDER_MARGIN, -ySize - TileMonitor.RENDER_MARGIN, 0.0 ).endVertex();
|
||||||
renderer.pos( xSize + TileMonitor.RENDER_MARGIN, -ySize - TileMonitor.RENDER_MARGIN, 0.0 ).tex( 1.0, 1.0 ).color( colour.getR(), colour.getG(), colour.getB(), 1.0f ).endVertex();
|
renderer.pos( xSize + TileMonitor.RENDER_MARGIN, TileMonitor.RENDER_MARGIN, 0.0 ).endVertex();
|
||||||
renderer.pos( xSize + TileMonitor.RENDER_MARGIN, TileMonitor.RENDER_MARGIN, 0.0D ).tex( 1.0, 0.0 ).color( colour.getR(), colour.getG(), colour.getB(), 1.0f ).endVertex();
|
renderer.pos( xSize + TileMonitor.RENDER_MARGIN, -ySize - TileMonitor.RENDER_MARGIN, 0.0 ).endVertex();
|
||||||
renderer.pos( -TileMonitor.RENDER_MARGIN, TileMonitor.RENDER_MARGIN, 0.0D ).tex( 0.0, 0.0 ).color( colour.getR(), colour.getG(), colour.getB(), 1.0f ).endVertex();
|
|
||||||
renderer.pos( -TileMonitor.RENDER_MARGIN, -ySize - TileMonitor.RENDER_MARGIN, 0.0 ).tex( 0.0, 1.0 ).color( colour.getR(), colour.getG(), colour.getB(), 1.0f ).endVertex();
|
|
||||||
tessellator.draw();
|
tessellator.draw();
|
||||||
}
|
}
|
||||||
finally
|
finally
|
||||||
|
@ -285,7 +285,7 @@ public class Computer
|
|||||||
{
|
{
|
||||||
synchronized( this )
|
synchronized( this )
|
||||||
{
|
{
|
||||||
if( m_state == State.Running )
|
if( m_state != State.Off && m_machine != null )
|
||||||
{
|
{
|
||||||
if( hard )
|
if( hard )
|
||||||
{
|
{
|
||||||
|
@ -6,11 +6,11 @@
|
|||||||
|
|
||||||
package dan200.computercraft.core.filesystem;
|
package dan200.computercraft.core.filesystem;
|
||||||
|
|
||||||
|
import dan200.computercraft.ComputerCraft;
|
||||||
import dan200.computercraft.api.filesystem.IMount;
|
import dan200.computercraft.api.filesystem.IMount;
|
||||||
import dan200.computercraft.api.filesystem.IWritableMount;
|
import dan200.computercraft.api.filesystem.IWritableMount;
|
||||||
|
|
||||||
import java.io.*;
|
import java.io.*;
|
||||||
import java.nio.charset.Charset;
|
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
import java.util.regex.Pattern;
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
@ -290,8 +290,8 @@ public class FileSystem
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private Map<String, MountWrapper> m_mounts = new HashMap<String, MountWrapper>();
|
private final Map<String, MountWrapper> m_mounts = new HashMap<String, MountWrapper>();
|
||||||
private Set<IMountedFile> m_openFiles = new HashSet<IMountedFile>();
|
private final Set<IMountedFile> m_openFiles = Collections.newSetFromMap( new WeakHashMap<IMountedFile, Boolean>() );
|
||||||
|
|
||||||
public FileSystem( String rootLabel, IMount rootMount ) throws FileSystemException
|
public FileSystem( String rootLabel, IMount rootMount ) throws FileSystemException
|
||||||
{
|
{
|
||||||
@ -308,18 +308,15 @@ public class FileSystem
|
|||||||
// Close all dangling open files
|
// Close all dangling open files
|
||||||
synchronized( m_openFiles )
|
synchronized( m_openFiles )
|
||||||
{
|
{
|
||||||
while( m_openFiles.size() > 0 )
|
for(IMountedFile file : m_openFiles)
|
||||||
{
|
{
|
||||||
IMountedFile file = m_openFiles.iterator().next();
|
try {
|
||||||
try
|
|
||||||
{
|
|
||||||
file.close();
|
file.close();
|
||||||
}
|
} catch (IOException e) {
|
||||||
catch( IOException e )
|
// Ignore
|
||||||
{
|
|
||||||
m_openFiles.remove( file );
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
m_openFiles.clear();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -441,6 +438,7 @@ public class FileSystem
|
|||||||
// Return list
|
// Return list
|
||||||
String[] array = new String[ list.size() ];
|
String[] array = new String[ list.size() ];
|
||||||
list.toArray(array);
|
list.toArray(array);
|
||||||
|
Arrays.sort( array );
|
||||||
return array;
|
return array;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -649,6 +647,41 @@ public class FileSystem
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private synchronized <T extends IMountedFile> T openFile(T file, Closeable handle) throws FileSystemException
|
||||||
|
{
|
||||||
|
synchronized( m_openFiles )
|
||||||
|
{
|
||||||
|
if( ComputerCraft.maximumFilesOpen > 0 &&
|
||||||
|
m_openFiles.size() >= ComputerCraft.maximumFilesOpen )
|
||||||
|
{
|
||||||
|
if( handle != null )
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
handle.close();
|
||||||
|
} catch ( IOException ignored ) {
|
||||||
|
// shrug
|
||||||
|
}
|
||||||
|
}
|
||||||
|
throw new FileSystemException("Too many files already open");
|
||||||
|
}
|
||||||
|
|
||||||
|
m_openFiles.add( file );
|
||||||
|
return file;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private synchronized void closeFile( IMountedFile file, Closeable handle ) throws IOException
|
||||||
|
{
|
||||||
|
synchronized( m_openFiles )
|
||||||
|
{
|
||||||
|
m_openFiles.remove( file );
|
||||||
|
if( handle != null )
|
||||||
|
{
|
||||||
|
handle.close();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public synchronized IMountedFileNormal openForRead( String path ) throws FileSystemException
|
public synchronized IMountedFileNormal openForRead( String path ) throws FileSystemException
|
||||||
{
|
{
|
||||||
@ -684,11 +717,7 @@ public class FileSystem
|
|||||||
@Override
|
@Override
|
||||||
public void close() throws IOException
|
public void close() throws IOException
|
||||||
{
|
{
|
||||||
synchronized( m_openFiles )
|
closeFile( this, reader );
|
||||||
{
|
|
||||||
m_openFiles.remove( this );
|
|
||||||
reader.close();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -697,11 +726,7 @@ public class FileSystem
|
|||||||
throw new UnsupportedOperationException();
|
throw new UnsupportedOperationException();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
synchronized( m_openFiles )
|
return openFile( file, reader );
|
||||||
{
|
|
||||||
m_openFiles.add( file );
|
|
||||||
}
|
|
||||||
return file;
|
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
@ -744,11 +769,7 @@ public class FileSystem
|
|||||||
@Override
|
@Override
|
||||||
public void close() throws IOException
|
public void close() throws IOException
|
||||||
{
|
{
|
||||||
synchronized( m_openFiles )
|
closeFile( this, writer );
|
||||||
{
|
|
||||||
m_openFiles.remove( this );
|
|
||||||
writer.close();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -757,11 +778,7 @@ public class FileSystem
|
|||||||
writer.flush();
|
writer.flush();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
synchronized( m_openFiles )
|
return openFile( file, writer );
|
||||||
{
|
|
||||||
m_openFiles.add( file );
|
|
||||||
}
|
|
||||||
return file;
|
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
@ -790,11 +807,7 @@ public class FileSystem
|
|||||||
@Override
|
@Override
|
||||||
public void close() throws IOException
|
public void close() throws IOException
|
||||||
{
|
{
|
||||||
synchronized( m_openFiles )
|
closeFile( this, stream );
|
||||||
{
|
|
||||||
m_openFiles.remove( this );
|
|
||||||
stream.close();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -803,11 +816,7 @@ public class FileSystem
|
|||||||
throw new UnsupportedOperationException();
|
throw new UnsupportedOperationException();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
synchronized( m_openFiles )
|
return openFile( file, stream );
|
||||||
{
|
|
||||||
m_openFiles.add( file );
|
|
||||||
}
|
|
||||||
return file;
|
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
@ -836,11 +845,7 @@ public class FileSystem
|
|||||||
@Override
|
@Override
|
||||||
public void close() throws IOException
|
public void close() throws IOException
|
||||||
{
|
{
|
||||||
synchronized( m_openFiles )
|
closeFile( this, stream );
|
||||||
{
|
|
||||||
m_openFiles.remove( this );
|
|
||||||
stream.close();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -849,11 +854,7 @@ public class FileSystem
|
|||||||
stream.flush();
|
stream.flush();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
synchronized( m_openFiles )
|
return openFile( file, stream );
|
||||||
{
|
|
||||||
m_openFiles.add( file );
|
|
||||||
}
|
|
||||||
return file;
|
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
@ -46,7 +46,7 @@ public abstract class BlockGeneric extends Block implements
|
|||||||
public final void dropBlockAsItemWithChance( World world, BlockPos pos, IBlockState state, float chance, int fortune )
|
public final void dropBlockAsItemWithChance( World world, BlockPos pos, IBlockState state, float chance, int fortune )
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public final List<ItemStack> getDrops( IBlockAccess world, BlockPos pos, IBlockState state, int fortune )
|
public final List<ItemStack> getDrops( IBlockAccess world, BlockPos pos, IBlockState state, int fortune )
|
||||||
{
|
{
|
||||||
@ -107,7 +107,7 @@ public abstract class BlockGeneric extends Block implements
|
|||||||
{
|
{
|
||||||
Block.spawnAsEntity( world, pos, stack );
|
Block.spawnAsEntity( world, pos, stack );
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public final void breakBlock( World world, BlockPos pos, IBlockState newState )
|
public final void breakBlock( World world, BlockPos pos, IBlockState newState )
|
||||||
{
|
{
|
||||||
@ -162,6 +162,17 @@ public abstract class BlockGeneric extends Block implements
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public final void onNeighborChange( IBlockAccess world, BlockPos pos, BlockPos neighbour )
|
||||||
|
{
|
||||||
|
TileEntity tile = world.getTileEntity( pos );
|
||||||
|
if( tile instanceof TileGeneric )
|
||||||
|
{
|
||||||
|
TileGeneric generic = (TileGeneric)tile;
|
||||||
|
generic.onNeighbourTileEntityChange( neighbour );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public final boolean isSideSolid( IBlockState state, IBlockAccess world, BlockPos pos, EnumFacing side )
|
public final boolean isSideSolid( IBlockState state, IBlockAccess world, BlockPos pos, EnumFacing side )
|
||||||
{
|
{
|
||||||
|
@ -95,6 +95,10 @@ public abstract class TileGeneric extends TileEntity
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void onNeighbourTileEntityChange( BlockPos neighbour )
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
public boolean isSolidOnSide( int side )
|
public boolean isSolidOnSide( int side )
|
||||||
{
|
{
|
||||||
return true;
|
return true;
|
||||||
|
@ -119,7 +119,7 @@ public class CommandAPI implements ILuaAPI
|
|||||||
table.put( "metadata", metadata );
|
table.put( "metadata", metadata );
|
||||||
|
|
||||||
Map<Object, Object> stateTable = new HashMap<Object, Object>();
|
Map<Object, Object> stateTable = new HashMap<Object, Object>();
|
||||||
for( Object o : block.getActualState( state, world, pos ).getProperties().entrySet() )
|
for( Object o : state.getActualState( world, pos ).getProperties().entrySet() )
|
||||||
{
|
{
|
||||||
ImmutableMap.Entry<IProperty, Object> entry = (ImmutableMap.Entry<IProperty, Object>)o;
|
ImmutableMap.Entry<IProperty, Object> entry = (ImmutableMap.Entry<IProperty, Object>)o;
|
||||||
String propertyName = entry.getKey().getName();
|
String propertyName = entry.getKey().getName();
|
||||||
|
@ -22,10 +22,10 @@ import net.minecraft.entity.player.EntityPlayer;
|
|||||||
import net.minecraft.init.Items;
|
import net.minecraft.init.Items;
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
import net.minecraft.nbt.NBTTagCompound;
|
import net.minecraft.nbt.NBTTagCompound;
|
||||||
|
import net.minecraft.util.EnumFacing;
|
||||||
import net.minecraft.util.EnumHand;
|
import net.minecraft.util.EnumHand;
|
||||||
import net.minecraft.util.ITickable;
|
import net.minecraft.util.ITickable;
|
||||||
import net.minecraft.util.math.BlockPos;
|
import net.minecraft.util.math.BlockPos;
|
||||||
import net.minecraft.util.EnumFacing;
|
|
||||||
|
|
||||||
public abstract class TileComputerBase extends TileGeneric
|
public abstract class TileComputerBase extends TileGeneric
|
||||||
implements IComputerTile, IDirectionalTile, ITickable
|
implements IComputerTile, IDirectionalTile, ITickable
|
||||||
@ -143,7 +143,8 @@ public abstract class TileComputerBase extends TileGeneric
|
|||||||
@Override
|
@Override
|
||||||
public boolean getRedstoneConnectivity( EnumFacing side )
|
public boolean getRedstoneConnectivity( EnumFacing side )
|
||||||
{
|
{
|
||||||
int localDir = remapLocalSide( DirectionUtil.toLocal( this, side ) );
|
if( side == null ) return false;
|
||||||
|
int localDir = remapLocalSide( DirectionUtil.toLocal( this, side.getOpposite() ) );
|
||||||
return !isRedstoneBlockedOnSide( localDir );
|
return !isRedstoneBlockedOnSide( localDir );
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -196,6 +197,12 @@ public abstract class TileComputerBase extends TileGeneric
|
|||||||
updateInput();
|
updateInput();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onNeighbourTileEntityChange( BlockPos neighbour )
|
||||||
|
{
|
||||||
|
updateInput( neighbour );
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void update()
|
public void update()
|
||||||
{
|
{
|
||||||
@ -307,6 +314,21 @@ public abstract class TileComputerBase extends TileGeneric
|
|||||||
return localSide;
|
return localSide;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void updateSideInput( ServerComputer computer, EnumFacing dir, BlockPos offset )
|
||||||
|
{
|
||||||
|
EnumFacing offsetSide = dir.getOpposite();
|
||||||
|
int localDir = remapLocalSide( DirectionUtil.toLocal( this, dir ) );
|
||||||
|
if( !isRedstoneBlockedOnSide( localDir ) )
|
||||||
|
{
|
||||||
|
computer.setRedstoneInput( localDir, RedstoneUtil.getRedstoneOutput( worldObj, offset, offsetSide ) );
|
||||||
|
computer.setBundledRedstoneInput( localDir, RedstoneUtil.getBundledRedstoneOutput( worldObj, offset, offsetSide ) );
|
||||||
|
}
|
||||||
|
if( !isPeripheralBlockedOnSide( localDir ) )
|
||||||
|
{
|
||||||
|
computer.setPeripheral( localDir, PeripheralUtil.getPeripheral( worldObj, offset, offsetSide ) );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public void updateInput()
|
public void updateInput()
|
||||||
{
|
{
|
||||||
if( worldObj == null || worldObj.isRemote )
|
if( worldObj == null || worldObj.isRemote )
|
||||||
@ -315,6 +337,24 @@ public abstract class TileComputerBase extends TileGeneric
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Update redstone and peripherals
|
// Update redstone and peripherals
|
||||||
|
ServerComputer computer = getServerComputer();
|
||||||
|
if( computer != null )
|
||||||
|
{
|
||||||
|
BlockPos pos = computer.getPosition();
|
||||||
|
for( EnumFacing dir : EnumFacing.VALUES )
|
||||||
|
{
|
||||||
|
updateSideInput( computer, dir, pos.offset( dir ) );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void updateInput( BlockPos neighbour )
|
||||||
|
{
|
||||||
|
if( worldObj == null || worldObj.isRemote )
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
ServerComputer computer = getServerComputer();
|
ServerComputer computer = getServerComputer();
|
||||||
if( computer != null )
|
if( computer != null )
|
||||||
{
|
{
|
||||||
@ -322,16 +362,10 @@ public abstract class TileComputerBase extends TileGeneric
|
|||||||
for( EnumFacing dir : EnumFacing.VALUES )
|
for( EnumFacing dir : EnumFacing.VALUES )
|
||||||
{
|
{
|
||||||
BlockPos offset = pos.offset( dir );
|
BlockPos offset = pos.offset( dir );
|
||||||
EnumFacing offsetSide = dir.getOpposite();
|
if ( offset.equals( neighbour ) )
|
||||||
int localDir = remapLocalSide( DirectionUtil.toLocal( this, dir ) );
|
|
||||||
if( !isRedstoneBlockedOnSide( localDir ) )
|
|
||||||
{
|
{
|
||||||
computer.setRedstoneInput( localDir, RedstoneUtil.getRedstoneOutput( worldObj, offset, offsetSide ) );
|
updateSideInput( computer, dir, offset );
|
||||||
computer.setBundledRedstoneInput( localDir, RedstoneUtil.getBundledRedstoneOutput( worldObj, offset, offsetSide ) );
|
break;
|
||||||
}
|
|
||||||
if( !isPeripheralBlockedOnSide( localDir ) )
|
|
||||||
{
|
|
||||||
computer.setPeripheral( localDir, PeripheralUtil.getPeripheral( worldObj, offset, offsetSide ) );
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,20 @@
|
|||||||
|
package dan200.computercraft.shared.computer.core;
|
||||||
|
|
||||||
|
import javax.annotation.Nullable;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* An instance of {@link net.minecraft.inventory.Container} which provides a computer. You should implement this
|
||||||
|
* if you provide custom computers/GUIs to interact with them.
|
||||||
|
*/
|
||||||
|
public interface IContainerComputer
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Get the computer you are interacting with.
|
||||||
|
*
|
||||||
|
* This will only be called on the server.
|
||||||
|
*
|
||||||
|
* @return The computer you are interacting with.
|
||||||
|
*/
|
||||||
|
@Nullable
|
||||||
|
IComputer getComputer();
|
||||||
|
}
|
@ -20,6 +20,7 @@ import dan200.computercraft.shared.network.ComputerCraftPacket;
|
|||||||
import dan200.computercraft.shared.network.INetworkedThing;
|
import dan200.computercraft.shared.network.INetworkedThing;
|
||||||
import dan200.computercraft.shared.util.NBTUtil;
|
import dan200.computercraft.shared.util.NBTUtil;
|
||||||
import net.minecraft.entity.player.EntityPlayer;
|
import net.minecraft.entity.player.EntityPlayer;
|
||||||
|
import net.minecraft.inventory.Container;
|
||||||
import net.minecraft.nbt.NBTTagCompound;
|
import net.minecraft.nbt.NBTTagCompound;
|
||||||
import net.minecraft.util.math.BlockPos;
|
import net.minecraft.util.math.BlockPos;
|
||||||
import net.minecraft.world.World;
|
import net.minecraft.world.World;
|
||||||
@ -351,6 +352,17 @@ public class ServerComputer extends ServerTerminal
|
|||||||
@Override
|
@Override
|
||||||
public void handlePacket( ComputerCraftPacket packet, EntityPlayer sender )
|
public void handlePacket( ComputerCraftPacket packet, EntityPlayer sender )
|
||||||
{
|
{
|
||||||
|
// Allow Computer/Tile updates as they may happen at any time.
|
||||||
|
if (packet.requiresContainer()) {
|
||||||
|
if (sender == null) return;
|
||||||
|
|
||||||
|
Container container = sender.openContainer;
|
||||||
|
if (!(container instanceof IContainerComputer)) return;
|
||||||
|
|
||||||
|
IComputer computer = ((IContainerComputer) container).getComputer();
|
||||||
|
if (computer != this) return;
|
||||||
|
}
|
||||||
|
|
||||||
// Receive packets sent from the client to the server
|
// Receive packets sent from the client to the server
|
||||||
switch( packet.m_packetType )
|
switch( packet.m_packetType )
|
||||||
{
|
{
|
||||||
|
@ -7,10 +7,15 @@
|
|||||||
package dan200.computercraft.shared.computer.inventory;
|
package dan200.computercraft.shared.computer.inventory;
|
||||||
|
|
||||||
import dan200.computercraft.shared.computer.blocks.TileComputer;
|
import dan200.computercraft.shared.computer.blocks.TileComputer;
|
||||||
|
import dan200.computercraft.shared.computer.core.IComputer;
|
||||||
|
import dan200.computercraft.shared.computer.core.IContainerComputer;
|
||||||
import net.minecraft.entity.player.EntityPlayer;
|
import net.minecraft.entity.player.EntityPlayer;
|
||||||
import net.minecraft.inventory.Container;
|
import net.minecraft.inventory.Container;
|
||||||
|
|
||||||
|
import javax.annotation.Nullable;
|
||||||
|
|
||||||
public class ContainerComputer extends Container
|
public class ContainerComputer extends Container
|
||||||
|
implements IContainerComputer
|
||||||
{
|
{
|
||||||
private TileComputer m_computer;
|
private TileComputer m_computer;
|
||||||
|
|
||||||
@ -24,4 +29,11 @@ public class ContainerComputer extends Container
|
|||||||
{
|
{
|
||||||
return m_computer.isUseableByPlayer( player );
|
return m_computer.isUseableByPlayer( player );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Nullable
|
||||||
|
@Override
|
||||||
|
public IComputer getComputer()
|
||||||
|
{
|
||||||
|
return m_computer.getServerComputer();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -224,4 +224,12 @@ public class ComputerCraftPacket
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Determine whether this packet requires the player to be interacting with the
|
||||||
|
* target.
|
||||||
|
*/
|
||||||
|
public boolean requiresContainer() {
|
||||||
|
return m_packetType != RequestComputerUpdate && m_packetType != RequestTileEntityUpdate;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,35 @@
|
|||||||
|
package dan200.computercraft.shared.pocket.inventory;
|
||||||
|
|
||||||
|
import dan200.computercraft.shared.computer.core.IComputer;
|
||||||
|
import dan200.computercraft.shared.computer.core.IContainerComputer;
|
||||||
|
import dan200.computercraft.shared.media.inventory.ContainerHeldItem;
|
||||||
|
import dan200.computercraft.shared.pocket.items.ItemPocketComputer;
|
||||||
|
import net.minecraft.entity.player.EntityPlayer;
|
||||||
|
import net.minecraft.item.ItemStack;
|
||||||
|
import net.minecraft.util.EnumHand;
|
||||||
|
|
||||||
|
import javax.annotation.Nullable;
|
||||||
|
|
||||||
|
public class ContainerPocketComputer extends ContainerHeldItem
|
||||||
|
implements IContainerComputer
|
||||||
|
{
|
||||||
|
public ContainerPocketComputer( EntityPlayer player, EnumHand hand )
|
||||||
|
{
|
||||||
|
super( player, hand );
|
||||||
|
}
|
||||||
|
|
||||||
|
@Nullable
|
||||||
|
@Override
|
||||||
|
public IComputer getComputer()
|
||||||
|
{
|
||||||
|
ItemStack stack = getStack();
|
||||||
|
if( stack != null && stack.getItem() instanceof ItemPocketComputer )
|
||||||
|
{
|
||||||
|
return ((ItemPocketComputer) stack.getItem()).getServerComputer( stack );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -18,6 +18,7 @@ import dan200.computercraft.shared.computer.core.ServerComputer;
|
|||||||
import dan200.computercraft.shared.computer.items.IComputerItem;
|
import dan200.computercraft.shared.computer.items.IComputerItem;
|
||||||
import dan200.computercraft.shared.pocket.apis.PocketAPI;
|
import dan200.computercraft.shared.pocket.apis.PocketAPI;
|
||||||
import dan200.computercraft.shared.pocket.peripherals.PocketModemPeripheral;
|
import dan200.computercraft.shared.pocket.peripherals.PocketModemPeripheral;
|
||||||
|
import dan200.computercraft.shared.util.StringUtil;
|
||||||
import net.minecraft.creativetab.CreativeTabs;
|
import net.minecraft.creativetab.CreativeTabs;
|
||||||
import net.minecraft.entity.Entity;
|
import net.minecraft.entity.Entity;
|
||||||
import net.minecraft.entity.EntityLivingBase;
|
import net.minecraft.entity.EntityLivingBase;
|
||||||
@ -30,7 +31,6 @@ import net.minecraft.util.ActionResult;
|
|||||||
import net.minecraft.util.EnumActionResult;
|
import net.minecraft.util.EnumActionResult;
|
||||||
import net.minecraft.util.EnumHand;
|
import net.minecraft.util.EnumHand;
|
||||||
import net.minecraft.util.SoundEvent;
|
import net.minecraft.util.SoundEvent;
|
||||||
import net.minecraft.util.text.translation.I18n;
|
|
||||||
import net.minecraft.world.World;
|
import net.minecraft.world.World;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
@ -200,14 +200,14 @@ public class ItemPocketComputer extends Item implements IComputerItem, IMedia
|
|||||||
boolean modem = getHasModem( stack );
|
boolean modem = getHasModem( stack );
|
||||||
if( modem )
|
if( modem )
|
||||||
{
|
{
|
||||||
return I18n.translateToLocalFormatted(
|
return StringUtil.translateToLocalFormatted(
|
||||||
baseString + ".upgraded.name",
|
baseString + ".upgraded.name",
|
||||||
I18n.translateToLocal( "upgrade.computercraft:wireless_modem.adjective" )
|
StringUtil.translateToLocal( "upgrade.computercraft:wireless_modem.adjective" )
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
return I18n.translateToLocal( baseString + ".name" );
|
return StringUtil.translateToLocal( baseString + ".name" );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -279,6 +279,16 @@ public class ItemPocketComputer extends Item implements IComputerItem, IMedia
|
|||||||
return computer;
|
return computer;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public ServerComputer getServerComputer( ItemStack stack )
|
||||||
|
{
|
||||||
|
int instanceID = getInstanceID( stack );
|
||||||
|
if( instanceID >= 0 )
|
||||||
|
{
|
||||||
|
return ComputerCraft.serverComputerRegistry.get( instanceID );
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
public ClientComputer createClientComputer( ItemStack stack )
|
public ClientComputer createClientComputer( ItemStack stack )
|
||||||
{
|
{
|
||||||
int instanceID = getInstanceID( stack );
|
int instanceID = getInstanceID( stack );
|
||||||
|
@ -126,7 +126,7 @@ public abstract class CCTurtleProxyCommon implements ICCTurtleProxy
|
|||||||
{
|
{
|
||||||
if( family == ComputerFamily.Beginners )
|
if( family == ComputerFamily.Beginners )
|
||||||
{
|
{
|
||||||
return upgrade.getType() == TurtleUpgradeType.Tool;
|
return upgrade.getType().isTool();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -42,15 +42,13 @@ import dan200.computercraft.shared.peripheral.modem.TileWirelessModem;
|
|||||||
import dan200.computercraft.shared.peripheral.monitor.TileMonitor;
|
import dan200.computercraft.shared.peripheral.monitor.TileMonitor;
|
||||||
import dan200.computercraft.shared.peripheral.printer.ContainerPrinter;
|
import dan200.computercraft.shared.peripheral.printer.ContainerPrinter;
|
||||||
import dan200.computercraft.shared.peripheral.printer.TilePrinter;
|
import dan200.computercraft.shared.peripheral.printer.TilePrinter;
|
||||||
|
import dan200.computercraft.shared.pocket.inventory.ContainerPocketComputer;
|
||||||
import dan200.computercraft.shared.pocket.items.ItemPocketComputer;
|
import dan200.computercraft.shared.pocket.items.ItemPocketComputer;
|
||||||
import dan200.computercraft.shared.pocket.items.PocketComputerItemFactory;
|
import dan200.computercraft.shared.pocket.items.PocketComputerItemFactory;
|
||||||
import dan200.computercraft.shared.pocket.recipes.PocketComputerUpgradeRecipe;
|
import dan200.computercraft.shared.pocket.recipes.PocketComputerUpgradeRecipe;
|
||||||
import dan200.computercraft.shared.turtle.blocks.TileTurtle;
|
import dan200.computercraft.shared.turtle.blocks.TileTurtle;
|
||||||
import dan200.computercraft.shared.turtle.inventory.ContainerTurtle;
|
import dan200.computercraft.shared.turtle.inventory.ContainerTurtle;
|
||||||
import dan200.computercraft.shared.util.Colour;
|
import dan200.computercraft.shared.util.*;
|
||||||
import dan200.computercraft.shared.util.CreativeTabMain;
|
|
||||||
import dan200.computercraft.shared.util.ImpostorRecipe;
|
|
||||||
import dan200.computercraft.shared.util.ImpostorShapelessRecipe;
|
|
||||||
import net.minecraft.creativetab.CreativeTabs;
|
import net.minecraft.creativetab.CreativeTabs;
|
||||||
import net.minecraft.entity.player.EntityPlayer;
|
import net.minecraft.entity.player.EntityPlayer;
|
||||||
import net.minecraft.entity.player.EntityPlayerMP;
|
import net.minecraft.entity.player.EntityPlayerMP;
|
||||||
@ -67,7 +65,6 @@ import net.minecraft.util.EnumHand;
|
|||||||
import net.minecraft.util.IThreadListener;
|
import net.minecraft.util.IThreadListener;
|
||||||
import net.minecraft.util.SoundEvent;
|
import net.minecraft.util.SoundEvent;
|
||||||
import net.minecraft.util.math.BlockPos;
|
import net.minecraft.util.math.BlockPos;
|
||||||
import net.minecraft.util.text.translation.I18n;
|
|
||||||
import net.minecraft.world.World;
|
import net.minecraft.world.World;
|
||||||
import net.minecraftforge.common.MinecraftForge;
|
import net.minecraftforge.common.MinecraftForge;
|
||||||
import net.minecraftforge.event.world.WorldEvent;
|
import net.minecraftforge.event.world.WorldEvent;
|
||||||
@ -129,7 +126,7 @@ public abstract class ComputerCraftProxyCommon implements IComputerCraftProxy
|
|||||||
{
|
{
|
||||||
ItemRecord record = (ItemRecord) item;
|
ItemRecord record = (ItemRecord) item;
|
||||||
String key = ObfuscationReflectionHelper.getPrivateValue( ItemRecord.class, record, "field_185077_c" );
|
String key = ObfuscationReflectionHelper.getPrivateValue( ItemRecord.class, record, "field_185077_c" );
|
||||||
return I18n.translateToLocal( key );
|
return StringUtil.translateToLocal( key );
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
@ -541,7 +538,7 @@ public abstract class ComputerCraftProxyCommon implements IComputerCraftProxy
|
|||||||
if (tile != null && tile instanceof TileTurtle)
|
if (tile != null && tile instanceof TileTurtle)
|
||||||
{
|
{
|
||||||
TileTurtle turtle = (TileTurtle) tile;
|
TileTurtle turtle = (TileTurtle) tile;
|
||||||
return new ContainerTurtle( player.inventory, turtle.getAccess() );
|
return new ContainerTurtle( player.inventory, turtle.getAccess(), turtle.getServerComputer() );
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -551,7 +548,7 @@ public abstract class ComputerCraftProxyCommon implements IComputerCraftProxy
|
|||||||
}
|
}
|
||||||
case ComputerCraft.pocketComputerGUIID:
|
case ComputerCraft.pocketComputerGUIID:
|
||||||
{
|
{
|
||||||
return new ContainerHeldItem( player, x == 0 ? EnumHand.MAIN_HAND : EnumHand.OFF_HAND );
|
return new ContainerPocketComputer( player, x == 0 ? EnumHand.MAIN_HAND : EnumHand.OFF_HAND );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
|
@ -46,12 +46,19 @@ public class TileTurtle extends TileComputerBase
|
|||||||
public static final int INVENTORY_HEIGHT = 4;
|
public static final int INVENTORY_HEIGHT = 4;
|
||||||
|
|
||||||
// Members
|
// Members
|
||||||
|
|
||||||
|
enum MoveState
|
||||||
|
{
|
||||||
|
NOT_MOVED,
|
||||||
|
IN_PROGRESS,
|
||||||
|
MOVED
|
||||||
|
}
|
||||||
|
|
||||||
private ItemStack[] m_inventory;
|
private ItemStack[] m_inventory;
|
||||||
private ItemStack[] m_previousInventory;
|
private ItemStack[] m_previousInventory;
|
||||||
private boolean m_inventoryChanged;
|
private boolean m_inventoryChanged;
|
||||||
private TurtleBrain m_brain;
|
private TurtleBrain m_brain;
|
||||||
private boolean m_moved;
|
private MoveState m_moveState;
|
||||||
|
|
||||||
public TileTurtle()
|
public TileTurtle()
|
||||||
{
|
{
|
||||||
@ -59,12 +66,12 @@ public class TileTurtle extends TileComputerBase
|
|||||||
m_previousInventory = new ItemStack[ getSizeInventory() ];
|
m_previousInventory = new ItemStack[ getSizeInventory() ];
|
||||||
m_inventoryChanged = false;
|
m_inventoryChanged = false;
|
||||||
m_brain = createBrain();
|
m_brain = createBrain();
|
||||||
m_moved = false;
|
m_moveState = MoveState.NOT_MOVED;
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean hasMoved()
|
public boolean hasMoved()
|
||||||
{
|
{
|
||||||
return m_moved;
|
return m_moveState == MoveState.MOVED;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected TurtleBrain createBrain()
|
protected TurtleBrain createBrain()
|
||||||
@ -276,6 +283,41 @@ public class TileTurtle extends TileComputerBase
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onNeighbourChange()
|
||||||
|
{
|
||||||
|
if ( m_moveState == MoveState.NOT_MOVED )
|
||||||
|
{
|
||||||
|
super.onNeighbourChange();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onNeighbourTileEntityChange(BlockPos neighbour)
|
||||||
|
{
|
||||||
|
if ( m_moveState == MoveState.NOT_MOVED )
|
||||||
|
{
|
||||||
|
super.onNeighbourTileEntityChange( neighbour );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void notifyMoveStart()
|
||||||
|
{
|
||||||
|
if (m_moveState == MoveState.NOT_MOVED)
|
||||||
|
{
|
||||||
|
m_moveState = MoveState.IN_PROGRESS;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void notifyMoveEnd()
|
||||||
|
{
|
||||||
|
// MoveState.MOVED is final
|
||||||
|
if (m_moveState == MoveState.IN_PROGRESS)
|
||||||
|
{
|
||||||
|
m_moveState = MoveState.NOT_MOVED;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void readFromNBT( NBTTagCompound nbttagcompound )
|
public void readFromNBT( NBTTagCompound nbttagcompound )
|
||||||
{
|
{
|
||||||
@ -334,7 +376,7 @@ public class TileTurtle extends TileComputerBase
|
|||||||
@Override
|
@Override
|
||||||
protected boolean isRedstoneBlockedOnSide( int localSide )
|
protected boolean isRedstoneBlockedOnSide( int localSide )
|
||||||
{
|
{
|
||||||
return hasPeripheralUpgradeOnSide( localSide );
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
// IDirectionalTile
|
// IDirectionalTile
|
||||||
@ -401,7 +443,7 @@ public class TileTurtle extends TileComputerBase
|
|||||||
}
|
}
|
||||||
|
|
||||||
// IInventory
|
// IInventory
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getSizeInventory()
|
public int getSizeInventory()
|
||||||
{
|
{
|
||||||
@ -431,7 +473,7 @@ public class TileTurtle extends TileComputerBase
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ItemStack decrStackSize( int slot, int count )
|
public ItemStack decrStackSize( int slot, int count )
|
||||||
{
|
{
|
||||||
@ -447,13 +489,13 @@ public class TileTurtle extends TileComputerBase
|
|||||||
{
|
{
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
if( stack.stackSize <= count )
|
if( stack.stackSize <= count )
|
||||||
{
|
{
|
||||||
setInventorySlotContents( slot, null );
|
setInventorySlotContents( slot, null );
|
||||||
return stack;
|
return stack;
|
||||||
}
|
}
|
||||||
|
|
||||||
ItemStack part = stack.splitStack( count );
|
ItemStack part = stack.splitStack( count );
|
||||||
onInventoryDefinitelyChanged();
|
onInventoryDefinitelyChanged();
|
||||||
return part;
|
return part;
|
||||||
@ -496,7 +538,7 @@ public class TileTurtle extends TileComputerBase
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getName()
|
public String getName()
|
||||||
{
|
{
|
||||||
@ -550,7 +592,7 @@ public class TileTurtle extends TileComputerBase
|
|||||||
public void openInventory( EntityPlayer player )
|
public void openInventory( EntityPlayer player )
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void closeInventory( EntityPlayer player )
|
public void closeInventory( EntityPlayer player )
|
||||||
{
|
{
|
||||||
@ -561,7 +603,7 @@ public class TileTurtle extends TileComputerBase
|
|||||||
{
|
{
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void markDirty()
|
public void markDirty()
|
||||||
{
|
{
|
||||||
@ -649,7 +691,7 @@ public class TileTurtle extends TileComputerBase
|
|||||||
case 5: upgrade = getUpgrade( TurtleSide.Left ); break;
|
case 5: upgrade = getUpgrade( TurtleSide.Left ); break;
|
||||||
default: return false;
|
default: return false;
|
||||||
}
|
}
|
||||||
if( upgrade != null && upgrade.getType() == TurtleUpgradeType.Peripheral )
|
if( upgrade != null && upgrade.getType().isPeripheral() )
|
||||||
{
|
{
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -664,6 +706,6 @@ public class TileTurtle extends TileComputerBase
|
|||||||
m_inventoryChanged = copy.m_inventoryChanged;
|
m_inventoryChanged = copy.m_inventoryChanged;
|
||||||
m_brain = copy.m_brain;
|
m_brain = copy.m_brain;
|
||||||
m_brain.setOwner( this );
|
m_brain.setOwner( this );
|
||||||
copy.m_moved = true;
|
copy.m_moveState = MoveState.MOVED;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -495,6 +495,7 @@ public class TurtleBrain implements ITurtleAccess
|
|||||||
|
|
||||||
// Cache info about the old turtle (so we don't access this after we delete ourselves)
|
// Cache info about the old turtle (so we don't access this after we delete ourselves)
|
||||||
World oldWorld = getWorld();
|
World oldWorld = getWorld();
|
||||||
|
TileTurtle oldOwner = m_owner;
|
||||||
BlockPos oldPos = m_owner.getPos();
|
BlockPos oldPos = m_owner.getPos();
|
||||||
Block oldBlock = m_owner.getBlock();
|
Block oldBlock = m_owner.getBlock();
|
||||||
|
|
||||||
@ -504,36 +505,51 @@ public class TurtleBrain implements ITurtleAccess
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Create a new turtle
|
if ( !world.isBlockLoaded( pos ) )
|
||||||
if( world.isBlockLoaded( pos ) && world.setBlockState( pos, oldBlock.getDefaultState(), 0 ) )
|
|
||||||
{
|
{
|
||||||
Block block = world.getBlockState( pos ).getBlock();
|
return false;
|
||||||
if( block == oldBlock )
|
}
|
||||||
|
|
||||||
|
oldOwner.notifyMoveStart();
|
||||||
|
|
||||||
|
try
|
||||||
|
{
|
||||||
|
// Create a new turtle
|
||||||
|
if( world.setBlockState( pos, oldBlock.getDefaultState(), 0 ) )
|
||||||
{
|
{
|
||||||
TileEntity newTile = world.getTileEntity( pos );
|
Block block = world.getBlockState( pos ).getBlock();
|
||||||
if( newTile != null && newTile instanceof TileTurtle )
|
if( block == oldBlock )
|
||||||
{
|
{
|
||||||
// Copy the old turtle state into the new turtle
|
TileEntity newTile = world.getTileEntity( pos );
|
||||||
TileTurtle newTurtle = (TileTurtle)newTile;
|
if( newTile != null && newTile instanceof TileTurtle )
|
||||||
newTurtle.setWorldObj( world );
|
{
|
||||||
newTurtle.setPos( pos );
|
// Copy the old turtle state into the new turtle
|
||||||
newTurtle.transferStateFrom( m_owner );
|
TileTurtle newTurtle = (TileTurtle)newTile;
|
||||||
newTurtle.createServerComputer().setWorld( world );
|
newTurtle.setWorldObj( world );
|
||||||
newTurtle.createServerComputer().setPosition( pos );
|
newTurtle.setPos( pos );
|
||||||
|
newTurtle.transferStateFrom( oldOwner );
|
||||||
|
newTurtle.createServerComputer().setWorld( world );
|
||||||
|
newTurtle.createServerComputer().setPosition( pos );
|
||||||
|
|
||||||
// Remove the old turtle
|
// Remove the old turtle
|
||||||
oldWorld.setBlockToAir( oldPos );
|
oldWorld.setBlockToAir( oldPos );
|
||||||
|
|
||||||
// Make sure everybody knows about it
|
// Make sure everybody knows about it
|
||||||
newTurtle.updateBlock();
|
newTurtle.updateBlock();
|
||||||
newTurtle.updateInput();
|
newTurtle.updateInput();
|
||||||
newTurtle.updateOutput();
|
newTurtle.updateOutput();
|
||||||
return true;
|
return true;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
// Something went wrong, remove the newly created turtle
|
// Something went wrong, remove the newly created turtle
|
||||||
world.setBlockToAir( pos );
|
world.setBlockToAir( pos );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
finally
|
||||||
|
{
|
||||||
|
// whatever happens, unblock old turtle in case it's still in world
|
||||||
|
oldOwner.notifyMoveEnd();
|
||||||
}
|
}
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
@ -950,7 +966,7 @@ public class TurtleBrain implements ITurtleAccess
|
|||||||
{
|
{
|
||||||
ITurtleUpgrade upgrade = getUpgrade( side );
|
ITurtleUpgrade upgrade = getUpgrade( side );
|
||||||
IPeripheral peripheral = null;
|
IPeripheral peripheral = null;
|
||||||
if( upgrade != null && upgrade.getType() == TurtleUpgradeType.Peripheral )
|
if( upgrade != null && upgrade.getType().isPeripheral() )
|
||||||
{
|
{
|
||||||
peripheral = upgrade.createPeripheral( this, side );
|
peripheral = upgrade.createPeripheral( this, side );
|
||||||
}
|
}
|
||||||
@ -961,15 +977,11 @@ public class TurtleBrain implements ITurtleAccess
|
|||||||
if( !m_peripherals.containsKey( side ) )
|
if( !m_peripherals.containsKey( side ) )
|
||||||
{
|
{
|
||||||
serverComputer.setPeripheral( dir, peripheral );
|
serverComputer.setPeripheral( dir, peripheral );
|
||||||
serverComputer.setRedstoneInput( dir, 0 );
|
|
||||||
serverComputer.setBundledRedstoneInput( dir, 0 );
|
|
||||||
m_peripherals.put( side, peripheral );
|
m_peripherals.put( side, peripheral );
|
||||||
}
|
}
|
||||||
else if( !m_peripherals.get( side ).equals( peripheral ) )
|
else if( !m_peripherals.get( side ).equals( peripheral ) )
|
||||||
{
|
{
|
||||||
serverComputer.setPeripheral( dir, peripheral );
|
serverComputer.setPeripheral( dir, peripheral );
|
||||||
serverComputer.setRedstoneInput( dir, 0 );
|
|
||||||
serverComputer.setBundledRedstoneInput( dir, 0 );
|
|
||||||
m_peripherals.remove( side );
|
m_peripherals.remove( side );
|
||||||
m_peripherals.put( side, peripheral );
|
m_peripherals.put( side, peripheral );
|
||||||
}
|
}
|
||||||
|
@ -57,7 +57,7 @@ public class TurtleInspectCommand implements ITurtleCommand
|
|||||||
table.put( "metadata", metadata );
|
table.put( "metadata", metadata );
|
||||||
|
|
||||||
Map<Object, Object> stateTable = new HashMap<Object, Object>();
|
Map<Object, Object> stateTable = new HashMap<Object, Object>();
|
||||||
for( Object o : block.getActualState( state, world, newPosition ).getProperties().entrySet() )
|
for( Object o : state.getActualState( world, newPosition ).getProperties().entrySet() )
|
||||||
{
|
{
|
||||||
ImmutableMap.Entry<IProperty, Object> entry = (ImmutableMap.Entry<IProperty, Object>)o;
|
ImmutableMap.Entry<IProperty, Object> entry = (ImmutableMap.Entry<IProperty, Object>)o;
|
||||||
String propertyName = entry.getKey().getName();
|
String propertyName = entry.getKey().getName();
|
||||||
|
@ -31,7 +31,7 @@ public class TurtleToolCommand implements ITurtleCommand
|
|||||||
if( !m_side.isPresent() || m_side.get() == side )
|
if( !m_side.isPresent() || m_side.get() == side )
|
||||||
{
|
{
|
||||||
ITurtleUpgrade upgrade = turtle.getUpgrade( side );
|
ITurtleUpgrade upgrade = turtle.getUpgrade( side );
|
||||||
if( upgrade != null && upgrade.getType() == TurtleUpgradeType.Tool )
|
if( upgrade != null && upgrade.getType().isTool() )
|
||||||
{
|
{
|
||||||
TurtleCommandResult result = upgrade.useTool( turtle, side, m_verb, m_direction.toWorldDir( turtle ) );
|
TurtleCommandResult result = upgrade.useTool( turtle, side, m_verb, m_direction.toWorldDir( turtle ) );
|
||||||
if( result.isSuccess() )
|
if( result.isSuccess() )
|
||||||
|
@ -7,6 +7,8 @@
|
|||||||
package dan200.computercraft.shared.turtle.inventory;
|
package dan200.computercraft.shared.turtle.inventory;
|
||||||
|
|
||||||
import dan200.computercraft.api.turtle.ITurtleAccess;
|
import dan200.computercraft.api.turtle.ITurtleAccess;
|
||||||
|
import dan200.computercraft.shared.computer.core.IComputer;
|
||||||
|
import dan200.computercraft.shared.computer.core.IContainerComputer;
|
||||||
import dan200.computercraft.shared.turtle.blocks.TileTurtle;
|
import dan200.computercraft.shared.turtle.blocks.TileTurtle;
|
||||||
import dan200.computercraft.shared.turtle.core.TurtleBrain;
|
import dan200.computercraft.shared.turtle.core.TurtleBrain;
|
||||||
import net.minecraft.entity.player.EntityPlayer;
|
import net.minecraft.entity.player.EntityPlayer;
|
||||||
@ -16,7 +18,10 @@ import net.minecraft.inventory.IInventory;
|
|||||||
import net.minecraft.inventory.Slot;
|
import net.minecraft.inventory.Slot;
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
|
|
||||||
|
import javax.annotation.Nullable;
|
||||||
|
|
||||||
public class ContainerTurtle extends Container
|
public class ContainerTurtle extends Container
|
||||||
|
implements IContainerComputer
|
||||||
{
|
{
|
||||||
private static final int PROGRESS_ID_SELECTED_SLOT = 0;
|
private static final int PROGRESS_ID_SELECTED_SLOT = 0;
|
||||||
|
|
||||||
@ -24,6 +29,7 @@ public class ContainerTurtle extends Container
|
|||||||
public final int m_turtleInvStartX;
|
public final int m_turtleInvStartX;
|
||||||
|
|
||||||
protected ITurtleAccess m_turtle;
|
protected ITurtleAccess m_turtle;
|
||||||
|
private IComputer m_computer;
|
||||||
private int m_selectedSlot;
|
private int m_selectedSlot;
|
||||||
|
|
||||||
protected ContainerTurtle( IInventory playerInventory, ITurtleAccess turtle, int playerInvStartY, int turtleInvStartX )
|
protected ContainerTurtle( IInventory playerInventory, ITurtleAccess turtle, int playerInvStartY, int turtleInvStartX )
|
||||||
@ -71,6 +77,12 @@ public class ContainerTurtle extends Container
|
|||||||
this( playerInventory, turtle, 134, 175 );
|
this( playerInventory, turtle, 134, 175 );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public ContainerTurtle( IInventory playerInventory, ITurtleAccess turtle, IComputer computer )
|
||||||
|
{
|
||||||
|
this( playerInventory, turtle );
|
||||||
|
m_computer = computer;
|
||||||
|
}
|
||||||
|
|
||||||
public int getSelectedSlot()
|
public int getSelectedSlot()
|
||||||
{
|
{
|
||||||
return m_selectedSlot;
|
return m_selectedSlot;
|
||||||
@ -178,4 +190,11 @@ public class ContainerTurtle extends Container
|
|||||||
}
|
}
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Nullable
|
||||||
|
@Override
|
||||||
|
public IComputer getComputer()
|
||||||
|
{
|
||||||
|
return m_computer;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -14,6 +14,7 @@ import dan200.computercraft.shared.computer.items.ItemComputerBase;
|
|||||||
import dan200.computercraft.shared.turtle.blocks.ITurtleTile;
|
import dan200.computercraft.shared.turtle.blocks.ITurtleTile;
|
||||||
import dan200.computercraft.shared.turtle.core.TurtleBrain;
|
import dan200.computercraft.shared.turtle.core.TurtleBrain;
|
||||||
import dan200.computercraft.shared.util.Colour;
|
import dan200.computercraft.shared.util.Colour;
|
||||||
|
import dan200.computercraft.shared.util.StringUtil;
|
||||||
import net.minecraft.block.Block;
|
import net.minecraft.block.Block;
|
||||||
import net.minecraft.block.state.IBlockState;
|
import net.minecraft.block.state.IBlockState;
|
||||||
import net.minecraft.creativetab.CreativeTabs;
|
import net.minecraft.creativetab.CreativeTabs;
|
||||||
@ -21,10 +22,9 @@ import net.minecraft.entity.player.EntityPlayer;
|
|||||||
import net.minecraft.item.Item;
|
import net.minecraft.item.Item;
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
import net.minecraft.tileentity.TileEntity;
|
import net.minecraft.tileentity.TileEntity;
|
||||||
import net.minecraft.util.math.BlockPos;
|
|
||||||
import net.minecraft.util.EnumFacing;
|
import net.minecraft.util.EnumFacing;
|
||||||
import net.minecraft.util.ResourceLocation;
|
import net.minecraft.util.ResourceLocation;
|
||||||
import net.minecraft.util.text.translation.I18n;;
|
import net.minecraft.util.math.BlockPos;
|
||||||
import net.minecraft.world.World;
|
import net.minecraft.world.World;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
@ -142,29 +142,29 @@ public abstract class ItemTurtleBase extends ItemComputerBase implements ITurtle
|
|||||||
ITurtleUpgrade right = getUpgrade( stack, TurtleSide.Right );
|
ITurtleUpgrade right = getUpgrade( stack, TurtleSide.Right );
|
||||||
if( left != null && right != null )
|
if( left != null && right != null )
|
||||||
{
|
{
|
||||||
return I18n.translateToLocalFormatted(
|
return StringUtil.translateToLocalFormatted(
|
||||||
baseString + ".upgraded_twice.name",
|
baseString + ".upgraded_twice.name",
|
||||||
I18n.translateToLocal( right.getUnlocalisedAdjective() ),
|
StringUtil.translateToLocal( right.getUnlocalisedAdjective() ),
|
||||||
I18n.translateToLocal( left.getUnlocalisedAdjective() )
|
StringUtil.translateToLocal( left.getUnlocalisedAdjective() )
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
else if( left != null )
|
else if( left != null )
|
||||||
{
|
{
|
||||||
return I18n.translateToLocalFormatted(
|
return StringUtil.translateToLocalFormatted(
|
||||||
baseString + ".upgraded.name",
|
baseString + ".upgraded.name",
|
||||||
I18n.translateToLocal( left.getUnlocalisedAdjective() )
|
StringUtil.translateToLocal( left.getUnlocalisedAdjective() )
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
else if( right != null )
|
else if( right != null )
|
||||||
{
|
{
|
||||||
return I18n.translateToLocalFormatted(
|
return StringUtil.translateToLocalFormatted(
|
||||||
baseString + ".upgraded.name",
|
baseString + ".upgraded.name",
|
||||||
I18n.translateToLocal( right.getUnlocalisedAdjective() )
|
StringUtil.translateToLocal( right.getUnlocalisedAdjective() )
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
return I18n.translateToLocal( baseString + ".name" );
|
return StringUtil.translateToLocal( baseString + ".name" );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -34,8 +34,7 @@ public class TurtleHoe extends TurtleTool
|
|||||||
if( super.canBreakBlock( world, pos ) )
|
if( super.canBreakBlock( world, pos ) )
|
||||||
{
|
{
|
||||||
IBlockState state = world.getBlockState( pos );
|
IBlockState state = world.getBlockState( pos );
|
||||||
Block block = state.getBlock();
|
Material material = state.getMaterial( );
|
||||||
Material material = block.getMaterial( state );
|
|
||||||
return
|
return
|
||||||
material == Material.PLANTS ||
|
material == Material.PLANTS ||
|
||||||
material == Material.CACTUS ||
|
material == Material.CACTUS ||
|
||||||
|
@ -26,8 +26,7 @@ public class TurtleShovel extends TurtleTool
|
|||||||
if( super.canBreakBlock( world, pos ) )
|
if( super.canBreakBlock( world, pos ) )
|
||||||
{
|
{
|
||||||
IBlockState state = world.getBlockState( pos );
|
IBlockState state = world.getBlockState( pos );
|
||||||
Block block = state.getBlock();
|
Material material = state.getMaterial( );
|
||||||
Material material = block.getMaterial( state );
|
|
||||||
return
|
return
|
||||||
material == Material.GROUND ||
|
material == Material.GROUND ||
|
||||||
material == Material.SAND ||
|
material == Material.SAND ||
|
||||||
|
@ -26,8 +26,7 @@ public class TurtleSword extends TurtleTool
|
|||||||
if( super.canBreakBlock( world, pos ) )
|
if( super.canBreakBlock( world, pos ) )
|
||||||
{
|
{
|
||||||
IBlockState state = world.getBlockState( pos );
|
IBlockState state = world.getBlockState( pos );
|
||||||
Block block = state.getBlock();
|
Material material = state.getMaterial( );
|
||||||
Material material = block.getMaterial( state );
|
|
||||||
return
|
return
|
||||||
material == Material.PLANTS ||
|
material == Material.PLANTS ||
|
||||||
material == Material.LEAVES ||
|
material == Material.LEAVES ||
|
||||||
|
@ -136,7 +136,7 @@ public class TurtleTool implements ITurtleUpgrade
|
|||||||
{
|
{
|
||||||
IBlockState state = world.getBlockState( pos );
|
IBlockState state = world.getBlockState( pos );
|
||||||
Block block = state.getBlock();
|
Block block = state.getBlock();
|
||||||
if( block.isAir( state, world, pos ) || block == Blocks.BEDROCK || block.getBlockHardness( state, world, pos ) <= -1.0F )
|
if( block.isAir( state, world, pos ) || block == Blocks.BEDROCK || state.getBlockHardness( world, pos ) <= -1.0F )
|
||||||
{
|
{
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -8,7 +8,7 @@ package dan200.computercraft.shared.util;
|
|||||||
|
|
||||||
public enum Colour
|
public enum Colour
|
||||||
{
|
{
|
||||||
Black( 0x191919 ),
|
Black( 0x111111 ),
|
||||||
Red( 0xcc4c4c ),
|
Red( 0xcc4c4c ),
|
||||||
Green( 0x57A64E ),
|
Green( 0x57A64E ),
|
||||||
Brown( 0x7f664c ),
|
Brown( 0x7f664c ),
|
||||||
|
@ -11,43 +11,33 @@ import net.minecraft.block.Block;
|
|||||||
import net.minecraft.block.BlockRedstoneWire;
|
import net.minecraft.block.BlockRedstoneWire;
|
||||||
import net.minecraft.block.state.IBlockState;
|
import net.minecraft.block.state.IBlockState;
|
||||||
import net.minecraft.init.Blocks;
|
import net.minecraft.init.Blocks;
|
||||||
import net.minecraft.util.math.BlockPos;
|
|
||||||
import net.minecraft.util.EnumFacing;
|
import net.minecraft.util.EnumFacing;
|
||||||
import net.minecraft.world.IBlockAccess;
|
import net.minecraft.util.math.BlockPos;
|
||||||
import net.minecraft.world.World;
|
import net.minecraft.world.World;
|
||||||
|
|
||||||
public class RedstoneUtil
|
public class RedstoneUtil
|
||||||
{
|
{
|
||||||
private static Block getBlock( IBlockAccess world, BlockPos pos )
|
|
||||||
{
|
|
||||||
if( pos.getY() >= 0 )
|
|
||||||
{
|
|
||||||
return world.getBlockState( pos ).getBlock();
|
|
||||||
}
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static int getRedstoneOutput( World world, BlockPos pos, EnumFacing side )
|
public static int getRedstoneOutput( World world, BlockPos pos, EnumFacing side )
|
||||||
{
|
{
|
||||||
int power = 0;
|
int power = 0;
|
||||||
Block block = getBlock( world, pos );
|
IBlockState state = world.getBlockState( pos );
|
||||||
if( block != null && block != Blocks.AIR )
|
Block block = state.getBlock();
|
||||||
|
if( block != Blocks.AIR )
|
||||||
{
|
{
|
||||||
IBlockState state = world.getBlockState( pos );
|
|
||||||
if( block == Blocks.REDSTONE_WIRE )
|
if( block == Blocks.REDSTONE_WIRE )
|
||||||
{
|
{
|
||||||
if( side != EnumFacing.UP )
|
if( side != EnumFacing.UP )
|
||||||
{
|
{
|
||||||
power = ((Integer)state.getValue( BlockRedstoneWire.POWER )).intValue();
|
power = state.getValue( BlockRedstoneWire.POWER );
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
power = 0;
|
power = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if( block.canProvidePower( state ) )
|
else if( state.canProvidePower( ) )
|
||||||
{
|
{
|
||||||
power = block.getWeakPower( state, world, pos, side.getOpposite() );
|
power = state.getWeakPower( world, pos, side.getOpposite() );
|
||||||
}
|
}
|
||||||
if( block.isNormalCube( state, world, pos ) )
|
if( block.isNormalCube( state, world, pos ) )
|
||||||
{
|
{
|
||||||
@ -56,10 +46,10 @@ public class RedstoneUtil
|
|||||||
if( testSide != side )
|
if( testSide != side )
|
||||||
{
|
{
|
||||||
BlockPos testPos = pos.offset( testSide );
|
BlockPos testPos = pos.offset( testSide );
|
||||||
Block neighbour = getBlock( world, testPos );
|
IBlockState neighbour = world.getBlockState( testPos );
|
||||||
if( neighbour != null && neighbour.canProvidePower( state ) )
|
if( neighbour.canProvidePower( ) )
|
||||||
{
|
{
|
||||||
power = Math.max( power, neighbour.getStrongPower( state, world, testPos, testSide.getOpposite() ) );
|
power = Math.max( power, neighbour.getStrongPower( world, testPos, testSide.getOpposite() ) );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -81,15 +71,15 @@ public class RedstoneUtil
|
|||||||
public static void propogateRedstoneOutput( World world, BlockPos pos, EnumFacing side )
|
public static void propogateRedstoneOutput( World world, BlockPos pos, EnumFacing side )
|
||||||
{
|
{
|
||||||
// Propogate ordinary output
|
// Propogate ordinary output
|
||||||
Block block = getBlock( world, pos );
|
IBlockState block = world.getBlockState( pos );
|
||||||
BlockPos neighbourPos = pos.offset( side );
|
BlockPos neighbourPos = pos.offset( side );
|
||||||
Block neighbour = getBlock( world, neighbourPos );
|
IBlockState neighbour = world.getBlockState( neighbourPos );
|
||||||
if( neighbour != null && neighbour != Blocks.AIR )
|
if( neighbour.getBlock() != Blocks.AIR )
|
||||||
{
|
{
|
||||||
world.notifyBlockOfStateChange( neighbourPos, block );
|
world.notifyBlockOfStateChange( neighbourPos, block.getBlock() );
|
||||||
if( neighbour.isNormalCube( world.getBlockState( neighbourPos ), world, neighbourPos ) )
|
if( neighbour.getBlock().isNormalCube( neighbour, world, neighbourPos ) )
|
||||||
{
|
{
|
||||||
world.notifyNeighborsOfStateExcept( neighbourPos, neighbour, side.getOpposite() );
|
world.notifyNeighborsOfStateExcept( neighbourPos, neighbour.getBlock(), side.getOpposite() );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -23,4 +23,22 @@ public class StringUtil
|
|||||||
|
|
||||||
return builder.toString();
|
return builder.toString();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Translates a Stat name
|
||||||
|
*/
|
||||||
|
@SuppressWarnings("deprecation")
|
||||||
|
public static String translateToLocal( String key )
|
||||||
|
{
|
||||||
|
return net.minecraft.util.text.translation.I18n.translateToLocal( key );
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Translates a Stat name with format args
|
||||||
|
*/
|
||||||
|
@SuppressWarnings("deprecation")
|
||||||
|
public static String translateToLocalFormatted( String key, Object... format )
|
||||||
|
{
|
||||||
|
return net.minecraft.util.text.translation.I18n.translateToLocalFormatted( key, format );
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -27,16 +27,7 @@ public class WorldUtil
|
|||||||
|
|
||||||
public static boolean isLiquidBlock( World world, BlockPos pos )
|
public static boolean isLiquidBlock( World world, BlockPos pos )
|
||||||
{
|
{
|
||||||
if( isBlockInWorld( world, pos ) )
|
return isBlockInWorld( world, pos ) && world.getBlockState( pos ).getMaterial().isLiquid();
|
||||||
{
|
|
||||||
IBlockState state = world.getBlockState( pos );
|
|
||||||
Block block = state.getBlock();
|
|
||||||
if( block != null )
|
|
||||||
{
|
|
||||||
return block.getMaterial( state ).isLiquid();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static BlockPos moveCoords( BlockPos pos, EnumFacing dir )
|
public static BlockPos moveCoords( BlockPos pos, EnumFacing dir )
|
||||||
|
@ -56,3 +56,4 @@ gui.computercraft:config.turtle_fuel_limit=Turtle fuel limit
|
|||||||
gui.computercraft:config.advanced_turtle_fuel_limit=Advanced Turtle fuel limit
|
gui.computercraft:config.advanced_turtle_fuel_limit=Advanced Turtle fuel limit
|
||||||
gui.computercraft:config.turtles_obey_block_protection=Turtles obey block protection
|
gui.computercraft:config.turtles_obey_block_protection=Turtles obey block protection
|
||||||
gui.computercraft:config.turtles_can_push=Turtles can push entities
|
gui.computercraft:config.turtles_can_push=Turtles can push entities
|
||||||
|
gui.computercraft:config.maximum_files_open=Maximum files open per computer
|
||||||
|
@ -175,11 +175,11 @@ function os.pullEventRaw( sFilter )
|
|||||||
end
|
end
|
||||||
|
|
||||||
function os.pullEvent( sFilter )
|
function os.pullEvent( sFilter )
|
||||||
local eventData = { os.pullEventRaw( sFilter ) }
|
local eventData = table.pack( os.pullEventRaw( sFilter ) )
|
||||||
if eventData[1] == "terminate" then
|
if eventData[1] == "terminate" then
|
||||||
error( "Terminated", 0 )
|
error( "Terminated", 0 )
|
||||||
end
|
end
|
||||||
return table.unpack( eventData )
|
return table.unpack( eventData, 1, eventData.n )
|
||||||
end
|
end
|
||||||
|
|
||||||
-- Install globals
|
-- Install globals
|
||||||
@ -550,13 +550,13 @@ end
|
|||||||
|
|
||||||
-- Install the rest of the OS api
|
-- Install the rest of the OS api
|
||||||
function os.run( _tEnv, _sPath, ... )
|
function os.run( _tEnv, _sPath, ... )
|
||||||
local tArgs = { ... }
|
local tArgs = table.pack( ... )
|
||||||
local tEnv = _tEnv
|
local tEnv = _tEnv
|
||||||
setmetatable( tEnv, { __index = _G } )
|
setmetatable( tEnv, { __index = _G } )
|
||||||
local fnFile, err = loadfile( _sPath, tEnv )
|
local fnFile, err = loadfile( _sPath, tEnv )
|
||||||
if fnFile then
|
if fnFile then
|
||||||
local ok, err = pcall( function()
|
local ok, err = pcall( function()
|
||||||
fnFile( table.unpack( tArgs ) )
|
fnFile( table.unpack( tArgs, 1, tArgs.n ) )
|
||||||
end )
|
end )
|
||||||
if not ok then
|
if not ok then
|
||||||
if err and err ~= "" then
|
if err and err ~= "" then
|
||||||
|
@ -103,7 +103,7 @@ function locate( _nTimeout, _bDebug )
|
|||||||
local sSide, sChannel, sReplyChannel, tMessage, nDistance = p1, p2, p3, p4, p5
|
local sSide, sChannel, sReplyChannel, tMessage, nDistance = p1, p2, p3, p4, p5
|
||||||
if sSide == sModemSide and sChannel == os.getComputerID() and sReplyChannel == CHANNEL_GPS and nDistance then
|
if sSide == sModemSide and sChannel == os.getComputerID() and sReplyChannel == CHANNEL_GPS and nDistance then
|
||||||
-- Received the correct message from the correct modem: use it to determine position
|
-- Received the correct message from the correct modem: use it to determine position
|
||||||
if type(tMessage) == "table" and #tMessage == 3 then
|
if type(tMessage) == "table" and #tMessage == 3 and tonumber(tMessage[1]) and tonumber(tMessage[2]) and tonumber(tMessage[3]) then
|
||||||
local tFix = { vPosition = vector.new( tMessage[1], tMessage[2], tMessage[3] ), nDistance = nDistance }
|
local tFix = { vPosition = vector.new( tMessage[1], tMessage[2], tMessage[3] ), nDistance = nDistance }
|
||||||
if _bDebug then
|
if _bDebug then
|
||||||
print( tFix.nDistance.." metres from "..tostring( tFix.vPosition ) )
|
print( tFix.nDistance.." metres from "..tostring( tFix.vPosition ) )
|
||||||
|
@ -14,13 +14,13 @@ local function runUntilLimit( _routines, _limit )
|
|||||||
local living = count
|
local living = count
|
||||||
|
|
||||||
local tFilters = {}
|
local tFilters = {}
|
||||||
local eventData = {}
|
local eventData = { n = 0 }
|
||||||
while true do
|
while true do
|
||||||
for n=1,count do
|
for n=1,count do
|
||||||
local r = _routines[n]
|
local r = _routines[n]
|
||||||
if r then
|
if r then
|
||||||
if tFilters[r] == nil or tFilters[r] == eventData[1] or eventData[1] == "terminate" then
|
if tFilters[r] == nil or tFilters[r] == eventData[1] or eventData[1] == "terminate" then
|
||||||
local ok, param = coroutine.resume( r, table.unpack(eventData) )
|
local ok, param = coroutine.resume( r, table.unpack( eventData, 1, eventData.n ) )
|
||||||
if not ok then
|
if not ok then
|
||||||
error( param, 0 )
|
error( param, 0 )
|
||||||
else
|
else
|
||||||
@ -46,7 +46,7 @@ local function runUntilLimit( _routines, _limit )
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
eventData = { os.pullEventRaw() }
|
eventData = table.pack( os.pullEventRaw() )
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -76,9 +76,9 @@ local vmetatable = {
|
|||||||
|
|
||||||
function new( x, y, z )
|
function new( x, y, z )
|
||||||
local v = {
|
local v = {
|
||||||
x = x or 0,
|
x = tonumber(x) or 0,
|
||||||
y = y or 0,
|
y = tonumber(y) or 0,
|
||||||
z = z or 0
|
z = tonumber(z) or 0
|
||||||
}
|
}
|
||||||
setmetatable( v, vmetatable )
|
setmetatable( v, vmetatable )
|
||||||
return v
|
return v
|
||||||
|
@ -5,6 +5,7 @@ New Features in ComputerCraft 1.80:
|
|||||||
* Added a GUI to change ComputerCraft config options
|
* Added a GUI to change ComputerCraft config options
|
||||||
* os.time( ... ) now accept parameters to get real timestamp and real hour of day
|
* os.time( ... ) now accept parameters to get real timestamp and real hour of day
|
||||||
* os.day ( ... ) now accept parameters to get real day since 1970-01-01
|
* os.day ( ... ) now accept parameters to get real day since 1970-01-01
|
||||||
|
* Monitor text now glows in the dark
|
||||||
|
|
||||||
New Features in ComputerCraft 1.79:
|
New Features in ComputerCraft 1.79:
|
||||||
|
|
||||||
|
@ -5,5 +5,6 @@ New Features in ComputerCraft 1.80:
|
|||||||
* Added a GUI to change ComputerCraft config options
|
* Added a GUI to change ComputerCraft config options
|
||||||
* os.time( ... ) now accept parameters to get real timestamp and real hour of day
|
* os.time( ... ) now accept parameters to get real timestamp and real hour of day
|
||||||
* os.day ( ... ) now accept parameters to get real day since 1970-01-01
|
* os.day ( ... ) now accept parameters to get real day since 1970-01-01
|
||||||
|
* Monitor text now glows in the dark
|
||||||
|
|
||||||
Type "help changelog" to see the full version history.
|
Type "help changelog" to see the full version history.
|
||||||
|
@ -47,7 +47,7 @@ local function resumeProcess( nProcess, sEvent, ... )
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function launchProcess( tProgramEnv, sProgramPath, ... )
|
local function launchProcess( tProgramEnv, sProgramPath, ... )
|
||||||
local tProgramArgs = { ... }
|
local tProgramArgs = table.pack( ... )
|
||||||
local nProcess = #tProcesses + 1
|
local nProcess = #tProcesses + 1
|
||||||
local tProcess = {}
|
local tProcess = {}
|
||||||
tProcess.sTitle = fs.getName( sProgramPath )
|
tProcess.sTitle = fs.getName( sProgramPath )
|
||||||
@ -57,7 +57,7 @@ local function launchProcess( tProgramEnv, sProgramPath, ... )
|
|||||||
tProcess.window = window.create( parentTerm, 1, 1, w, h, false )
|
tProcess.window = window.create( parentTerm, 1, 1, w, h, false )
|
||||||
end
|
end
|
||||||
tProcess.co = coroutine.create( function()
|
tProcess.co = coroutine.create( function()
|
||||||
os.run( tProgramEnv, sProgramPath, table.unpack( tProgramArgs ) )
|
os.run( tProgramEnv, sProgramPath, table.unpack( tProgramArgs, 1, tProgramArgs.n ) )
|
||||||
if not tProcess.bInteracted then
|
if not tProcess.bInteracted then
|
||||||
term.setCursorBlink( false )
|
term.setCursorBlink( false )
|
||||||
print( "Press any key to continue" )
|
print( "Press any key to continue" )
|
||||||
@ -222,7 +222,7 @@ redrawMenu()
|
|||||||
-- Run processes
|
-- Run processes
|
||||||
while #tProcesses > 0 do
|
while #tProcesses > 0 do
|
||||||
-- Get the event
|
-- Get the event
|
||||||
local tEventData = { os.pullEventRaw() }
|
local tEventData = table.pack( os.pullEventRaw() )
|
||||||
local sEvent = tEventData[1]
|
local sEvent = tEventData[1]
|
||||||
if sEvent == "term_resize" then
|
if sEvent == "term_resize" then
|
||||||
-- Resize event
|
-- Resize event
|
||||||
@ -233,7 +233,7 @@ while #tProcesses > 0 do
|
|||||||
elseif sEvent == "char" or sEvent == "key" or sEvent == "key_up" or sEvent == "paste" or sEvent == "terminate" then
|
elseif sEvent == "char" or sEvent == "key" or sEvent == "key_up" or sEvent == "paste" or sEvent == "terminate" then
|
||||||
-- Keyboard event
|
-- Keyboard event
|
||||||
-- Passthrough to current process
|
-- Passthrough to current process
|
||||||
resumeProcess( nCurrentProcess, table.unpack( tEventData ) )
|
resumeProcess( nCurrentProcess, table.unpack( tEventData, 1, tEventData.n ) )
|
||||||
if cullProcess( nCurrentProcess ) then
|
if cullProcess( nCurrentProcess ) then
|
||||||
setMenuVisible( #tProcesses >= 2 )
|
setMenuVisible( #tProcesses >= 2 )
|
||||||
redrawMenu()
|
redrawMenu()
|
||||||
@ -280,7 +280,7 @@ while #tProcesses > 0 do
|
|||||||
-- Passthrough to all processes
|
-- Passthrough to all processes
|
||||||
local nLimit = #tProcesses -- Storing this ensures any new things spawned don't get the event
|
local nLimit = #tProcesses -- Storing this ensures any new things spawned don't get the event
|
||||||
for n=1,nLimit do
|
for n=1,nLimit do
|
||||||
resumeProcess( n, table.unpack( tEventData ) )
|
resumeProcess( n, table.unpack( tEventData, 1, tEventData.n ) )
|
||||||
end
|
end
|
||||||
if cullProcesses() then
|
if cullProcesses() then
|
||||||
setMenuVisible( #tProcesses >= 2 )
|
setMenuVisible( #tProcesses >= 2 )
|
||||||
|
@ -43,13 +43,13 @@ end
|
|||||||
local ok, param = pcall( function()
|
local ok, param = pcall( function()
|
||||||
local sFilter = resume()
|
local sFilter = resume()
|
||||||
while coroutine.status( co ) ~= "dead" do
|
while coroutine.status( co ) ~= "dead" do
|
||||||
local tEvent = { os.pullEventRaw() }
|
local tEvent = table.pack( os.pullEventRaw() )
|
||||||
if sFilter == nil or tEvent[1] == sFilter or tEvent[1] == "terminate" then
|
if sFilter == nil or tEvent[1] == sFilter or tEvent[1] == "terminate" then
|
||||||
sFilter = resume( table.unpack( tEvent ) )
|
sFilter = resume( table.unpack( tEvent, 1, tEvent.n ) )
|
||||||
end
|
end
|
||||||
if coroutine.status( co ) ~= "dead" and (sFilter == nil or sFilter == "mouse_click") then
|
if coroutine.status( co ) ~= "dead" and (sFilter == nil or sFilter == "mouse_click") then
|
||||||
if tEvent[1] == "monitor_touch" and tEvent[2] == sName then
|
if tEvent[1] == "monitor_touch" and tEvent[2] == sName then
|
||||||
sFilter = resume( "mouse_click", 1, table.unpack( tEvent, 3 ) )
|
sFilter = resume( "mouse_click", 1, table.unpack( tEvent, 3, tEvent.n ) )
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
if coroutine.status( co ) ~= "dead" and (sFilter == nil or sFilter == "term_resize") then
|
if coroutine.status( co ) ~= "dead" and (sFilter == nil or sFilter == "term_resize") then
|
||||||
|
@ -16,5 +16,37 @@
|
|||||||
"east": { "uv": [ 13, 2, 16, 14 ], "texture": "#front" }
|
"east": { "uv": [ 13, 2, 16, 14 ], "texture": "#front" }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
]
|
],
|
||||||
|
"display": {
|
||||||
|
"gui": {
|
||||||
|
"rotation": [ 30, 45, 0 ],
|
||||||
|
"translation": [ 3.2, -2, 0],
|
||||||
|
"scale":[ 0.75, 0.75, 0.75 ]
|
||||||
|
},
|
||||||
|
"ground": {
|
||||||
|
"rotation": [ 0, 0, 0 ],
|
||||||
|
"translation": [ 0, 3, 0],
|
||||||
|
"scale":[ 0.25, 0.25, 0.25 ]
|
||||||
|
},
|
||||||
|
"fixed": {
|
||||||
|
"rotation": [ 0, 0, 0 ],
|
||||||
|
"translation": [ 0, 0, 0],
|
||||||
|
"scale":[ 0.5, 0.5, 0.5 ]
|
||||||
|
},
|
||||||
|
"thirdperson_righthand": {
|
||||||
|
"rotation": [ 75, 180, 0 ],
|
||||||
|
"translation": [ 0, 2.5, 0],
|
||||||
|
"scale": [ 0.375, 0.375, 0.375 ]
|
||||||
|
},
|
||||||
|
"firstperson_righthand": {
|
||||||
|
"rotation": [ 0, 45, 0 ],
|
||||||
|
"translation": [ 0, 0, 0 ],
|
||||||
|
"scale": [ 0.40, 0.40, 0.40 ]
|
||||||
|
},
|
||||||
|
"firstperson_lefthand": {
|
||||||
|
"rotation": [ 0, 45, 0 ],
|
||||||
|
"translation": [ 0, 0, 0 ],
|
||||||
|
"scale": [ 0.40, 0.40, 0.40 ]
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
{
|
{
|
||||||
"parent": "builtin/generated",
|
"parent": "item/generated",
|
||||||
"textures": {
|
"textures": {
|
||||||
"layer0": "computercraft:items/pocketComputerBlinkAdvanced"
|
"layer0": "computercraft:items/pocketComputerBlinkAdvanced"
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
{
|
{
|
||||||
"parent": "builtin/generated",
|
"parent": "item/generated",
|
||||||
"textures": {
|
"textures": {
|
||||||
"layer0": "computercraft:items/pocketComputerBlinkAdvanced",
|
"layer0": "computercraft:items/pocketComputerBlinkAdvanced",
|
||||||
"layer1": "computercraft:items/pocketComputerModemLight"
|
"layer1": "computercraft:items/pocketComputerModemLight"
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
{
|
{
|
||||||
"parent": "builtin/generated",
|
"parent": "item/generated",
|
||||||
"textures": {
|
"textures": {
|
||||||
"layer0": "computercraft:items/pocketComputerAdvanced"
|
"layer0": "computercraft:items/pocketComputerAdvanced"
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
{
|
{
|
||||||
"parent": "builtin/generated",
|
"parent": "item/generated",
|
||||||
"textures": {
|
"textures": {
|
||||||
"layer0": "computercraft:items/pocketComputerOnAdvanced"
|
"layer0": "computercraft:items/pocketComputerOnAdvanced"
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
{
|
{
|
||||||
"parent": "builtin/generated",
|
"parent": "item/generated",
|
||||||
"textures": {
|
"textures": {
|
||||||
"layer0": "computercraft:items/pocketComputerOnAdvanced",
|
"layer0": "computercraft:items/pocketComputerOnAdvanced",
|
||||||
"layer1": "computercraft:items/pocketComputerModemLight"
|
"layer1": "computercraft:items/pocketComputerModemLight"
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
{
|
{
|
||||||
"parent": "builtin/generated",
|
"parent": "item/generated",
|
||||||
"textures": {
|
"textures": {
|
||||||
"layer0": "computercraft:items/book"
|
"layer0": "computercraft:items/book"
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
{
|
{
|
||||||
"parent": "builtin/generated",
|
"parent": "item/generated",
|
||||||
"textures": {
|
"textures": {
|
||||||
"layer0": "computercraft:items/diskFrame",
|
"layer0": "computercraft:items/diskFrame",
|
||||||
"layer1": "computercraft:items/diskColour"
|
"layer1": "computercraft:items/diskColour"
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
{
|
{
|
||||||
"parent": "builtin/generated",
|
"parent": "item/generated",
|
||||||
"textures": {
|
"textures": {
|
||||||
"layer0": "computercraft:items/diskFrame",
|
"layer0": "computercraft:items/diskFrame",
|
||||||
"layer1": "computercraft:items/diskColour"
|
"layer1": "computercraft:items/diskColour"
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
{
|
{
|
||||||
"parent": "builtin/generated",
|
"parent": "item/generated",
|
||||||
"textures": {
|
"textures": {
|
||||||
"layer0": "computercraft:items/pageBundle"
|
"layer0": "computercraft:items/pageBundle"
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
{
|
{
|
||||||
"parent": "builtin/generated",
|
"parent": "item/generated",
|
||||||
"textures": {
|
"textures": {
|
||||||
"layer0": "computercraft:items/pocketComputer"
|
"layer0": "computercraft:items/pocketComputer"
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
{
|
{
|
||||||
"parent": "builtin/generated",
|
"parent": "item/generated",
|
||||||
"textures": {
|
"textures": {
|
||||||
"layer0": "computercraft:items/pocketComputerBlink"
|
"layer0": "computercraft:items/pocketComputerBlink"
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
{
|
{
|
||||||
"parent": "builtin/generated",
|
"parent": "item/generated",
|
||||||
"textures": {
|
"textures": {
|
||||||
"layer0": "computercraft:items/pocketComputerBlink",
|
"layer0": "computercraft:items/pocketComputerBlink",
|
||||||
"layer1": "computercraft:items/pocketComputerModemLight"
|
"layer1": "computercraft:items/pocketComputerModemLight"
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
{
|
{
|
||||||
"parent": "builtin/generated",
|
"parent": "item/generated",
|
||||||
"textures": {
|
"textures": {
|
||||||
"layer0": "computercraft:items/pocketComputerOn"
|
"layer0": "computercraft:items/pocketComputerOn"
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
{
|
{
|
||||||
"parent": "builtin/generated",
|
"parent": "item/generated",
|
||||||
"textures": {
|
"textures": {
|
||||||
"layer0": "computercraft:items/pocketComputerOn",
|
"layer0": "computercraft:items/pocketComputerOn",
|
||||||
"layer1": "computercraft:items/pocketComputerModemLight"
|
"layer1": "computercraft:items/pocketComputerModemLight"
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
{
|
{
|
||||||
"parent": "builtin/generated",
|
"parent": "item/generated",
|
||||||
"textures": {
|
"textures": {
|
||||||
"layer0": "computercraft:items/page"
|
"layer0": "computercraft:items/page"
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
{
|
{
|
||||||
"parent": "builtin/generated",
|
"parent": "item/generated",
|
||||||
"textures": {
|
"textures": {
|
||||||
"layer0": "computercraft:items/diskFrame",
|
"layer0": "computercraft:items/diskFrame",
|
||||||
"layer1": "computercraft:items/diskColour"
|
"layer1": "computercraft:items/diskColour"
|
||||||
|
Before Width: | Height: | Size: 414 B After Width: | Height: | Size: 416 B |
Before Width: | Height: | Size: 484 B After Width: | Height: | Size: 503 B |
Before Width: | Height: | Size: 615 B After Width: | Height: | Size: 633 B |
Before Width: | Height: | Size: 507 B After Width: | Height: | Size: 525 B |
Before Width: | Height: | Size: 297 B After Width: | Height: | Size: 421 B |
Before Width: | Height: | Size: 455 B After Width: | Height: | Size: 456 B |
Before Width: | Height: | Size: 467 B After Width: | Height: | Size: 501 B |
Before Width: | Height: | Size: 534 B After Width: | Height: | Size: 534 B |