From f45614175a1b7452e8bde0b247504ac9eabdc531 Mon Sep 17 00:00:00 2001 From: Jonathan Coates Date: Tue, 25 Oct 2022 19:17:55 +0100 Subject: [PATCH] Some improvements to Javadoc publishing - Use

everywhere. This is uglier, but also technically more correct. This requires a version bump to cct-javadoc, and will give me a massive headache when merging. - Link against the existing OpenJDK docs. --- build.gradle.kts | 1 + gradle/libs.versions.toml | 2 +- .../computercraft/api/ComputerCraftAPI.java | 12 +++--- .../computercraft/api/IUpgradeBase.java | 10 ++--- .../api/detail/BasicItemDetailProvider.java | 2 +- .../filesystem/FileOperationException.java | 2 +- .../api/filesystem/IFileSystem.java | 2 +- .../computercraft/api/filesystem/IMount.java | 2 +- .../api/filesystem/IWritableMount.java | 2 +- .../computercraft/api/lua/GenericSource.java | 8 ++-- .../computercraft/api/lua/IArguments.java | 6 +-- .../api/lua/IDynamicLuaObject.java | 2 +- .../dan200/computercraft/api/lua/ILuaAPI.java | 6 +-- .../computercraft/api/lua/ILuaContext.java | 4 +- .../computercraft/api/lua/LuaFunction.java | 8 ++-- .../computercraft/api/lua/MethodResult.java | 6 +-- .../computercraft/api/media/IMedia.java | 2 +- .../api/network/IPacketReceiver.java | 4 +- .../api/network/wired/IWiredElement.java | 4 +- .../api/network/wired/IWiredNetwork.java | 12 +++--- .../api/network/wired/IWiredNode.java | 16 ++++---- .../api/network/wired/IWiredSender.java | 4 +- .../api/peripheral/GenericPeripheral.java | 8 ++-- .../api/peripheral/IComputerAccess.java | 14 +++---- .../api/peripheral/IDynamicPeripheral.java | 4 +- .../api/peripheral/IPeripheral.java | 18 ++++----- .../api/peripheral/IPeripheralProvider.java | 2 +- .../api/peripheral/IWorkMonitor.java | 8 ++-- .../api/peripheral/PeripheralType.java | 2 +- .../api/pocket/AbstractPocketUpgrade.java | 2 +- .../api/pocket/IPocketAccess.java | 4 +- .../api/pocket/IPocketUpgrade.java | 2 +- .../api/turtle/AbstractTurtleUpgrade.java | 4 +- .../api/turtle/ITurtleAccess.java | 10 ++--- .../api/turtle/ITurtleCommand.java | 2 +- .../api/turtle/ITurtleUpgrade.java | 6 +-- .../api/turtle/TurtleAnimation.java | 2 +- .../api/turtle/event/TurtleActionEvent.java | 4 +- .../api/turtle/event/TurtleAttackEvent.java | 4 +- .../api/turtle/event/TurtleBlockEvent.java | 12 +++--- .../api/turtle/event/TurtleEvent.java | 2 +- .../turtle/event/TurtleInspectItemEvent.java | 2 +- .../api/turtle/event/TurtlePlayerEvent.java | 4 +- .../api/turtle/event/TurtleRefuelEvent.java | 6 +-- .../client/render/RenderTypes.java | 2 +- .../text/DirectFixedWidthFontRenderer.java | 4 +- .../render/text/FixedWidthFontRenderer.java | 2 +- .../dan200/computercraft/core/apis/FSAPI.java | 24 +++++------ .../dan200/computercraft/core/apis/OSAPI.java | 14 +++---- .../computercraft/core/apis/RedstoneAPI.java | 8 ++-- .../computercraft/core/apis/TermMethods.java | 12 +++--- .../apis/handles/BinaryReadableHandle.java | 4 +- .../apis/handles/BinaryWritableHandle.java | 4 +- .../core/apis/handles/HandleGeneric.java | 2 +- .../core/apis/http/CheckUrl.java | 2 +- .../core/apis/http/NetworkUtils.java | 4 +- .../core/apis/http/Resource.java | 2 +- .../computercraft/core/asm/ObjectSource.java | 2 +- .../core/computer/Environment.java | 2 +- .../core/computer/TimeoutState.java | 10 ++--- .../core/filesystem/ChannelWrapper.java | 2 +- .../core/filesystem/FileSystem.java | 2 +- .../core/filesystem/FileSystemWrapper.java | 6 +-- .../core/filesystem/TrackingCloseable.java | 2 +- .../computercraft/core/lua/BasicFunction.java | 2 +- .../computercraft/core/lua/ILuaMachine.java | 10 ++--- .../computercraft/core/lua/MachineResult.java | 2 +- .../computercraft/shared/CommonHooks.java | 2 +- .../shared/command/ClientCommands.java | 2 +- .../command/arguments/RepeatArgumentType.java | 4 +- .../shared/command/text/TableBuilder.java | 4 +- .../shared/computer/apis/CommandAPI.java | 10 ++--- .../computer/blocks/ComputerPeripheral.java | 2 +- .../computer/blocks/TileComputerBase.java | 2 +- .../ComputerMenuWithoutInventory.java | 2 +- .../shared/network/NetworkMessage.java | 2 +- .../client/PlayRecordClientMessage.java | 2 +- .../client/SpeakerAudioClientMessage.java | 2 +- .../client/SpeakerMoveClientMessage.java | 2 +- .../client/SpeakerPlayClientMessage.java | 2 +- .../client/SpeakerStopClientMessage.java | 2 +- .../commandblock/CommandBlockPeripheral.java | 4 +- .../diskdrive/DiskDrivePeripheral.java | 10 ++--- .../generic/methods/ArgumentHelpers.java | 2 +- .../generic/methods/EnergyMethods.java | 4 +- .../generic/methods/FluidMethods.java | 8 ++-- .../generic/methods/InventoryMethods.java | 14 +++---- .../peripheral/modem/ModemPeripheral.java | 18 ++++----- .../wired/WiredModemLocalPeripheral.java | 2 +- .../modem/wired/WiredModemPeripheral.java | 16 ++++---- .../peripheral/monitor/MonitorPeripheral.java | 6 +-- .../peripheral/printer/PrinterPeripheral.java | 2 +- .../peripheral/speaker/SpeakerPeripheral.java | 26 ++++++------ .../shared/pocket/apis/PocketAPI.java | 4 +- .../pocket/core/PocketServerComputer.java | 2 +- .../shared/turtle/apis/TurtleAPI.java | 40 +++++++++---------- .../shared/util/InventoryDelegate.java | 2 +- .../shared/util/ThreadUtils.java | 4 +- .../shared/util/TickScheduler.java | 2 +- .../shared/util/WaterloggableHelpers.java | 2 +- .../shared/wired/InvariantChecker.java | 2 +- 101 files changed, 287 insertions(+), 286 deletions(-) diff --git a/build.gradle.kts b/build.gradle.kts index 3c4bcfd1f..20fdf53e9 100644 --- a/build.gradle.kts +++ b/build.gradle.kts @@ -149,6 +149,7 @@ illuaminate { tasks.javadoc { include("dan200/computercraft/api/**/*.java") + (options as StandardJavadocDocletOptions).links("https://docs.oracle.com/javase/8/docs/api/") } val apiJar by tasks.registering(Jar::class) { diff --git a/gradle/libs.versions.toml b/gradle/libs.versions.toml index 5f164ed3b..f693343ad 100644 --- a/gradle/libs.versions.toml +++ b/gradle/libs.versions.toml @@ -18,7 +18,7 @@ jqwik = "1.7.0" junit = "5.9.1" # Build tools -cctJavadoc = "1.5.0" +cctJavadoc = "1.5.1" checkstyle = "8.25" # There's a reason we're pinned on an ancient version, but I can't remember what it is. curseForgeGradle = "1.0.11" forgeGradle = "5.1.+" diff --git a/src/main/java/dan200/computercraft/api/ComputerCraftAPI.java b/src/main/java/dan200/computercraft/api/ComputerCraftAPI.java index 0225f450c..05ef6b25d 100644 --- a/src/main/java/dan200/computercraft/api/ComputerCraftAPI.java +++ b/src/main/java/dan200/computercraft/api/ComputerCraftAPI.java @@ -38,7 +38,7 @@ import javax.annotation.Nullable; /** * The static entry point to the ComputerCraft API. - * + *

* Members in this class must be called after mod_ComputerCraft has been initialised, but may be called before it is * fully loaded. */ @@ -59,13 +59,13 @@ public final class ComputerCraftAPI /** * Creates a numbered directory in a subfolder of the save directory for a given world, and returns that number. - * + *

* 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" * @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. * @see #createSaveDirMount(World, String, long) @@ -77,7 +77,7 @@ public final class ComputerCraftAPI /** * Creates a file system mount that maps to a subfolder of the save directory for a given world, and returns it. - * + *

* Use in conjunction with IComputerAccess.mount() or IComputerAccess.mountWritable() to mount a folder from the * users save directory onto a computers file system. * @@ -101,10 +101,10 @@ public final class ComputerCraftAPI /** * Creates a file system mount to a resource folder, and returns it. - * + *

* Use in conjunction with {@link IComputerAccess#mount} or {@link 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 all mod jar, and data packs that contain * resources with the same domain and path. For instance, ComputerCraft's resources are stored in * "/data/computercraft/lua/rom". We construct a mount for that with diff --git a/src/main/java/dan200/computercraft/api/IUpgradeBase.java b/src/main/java/dan200/computercraft/api/IUpgradeBase.java index 8fb757ae0..572c82596 100644 --- a/src/main/java/dan200/computercraft/api/IUpgradeBase.java +++ b/src/main/java/dan200/computercraft/api/IUpgradeBase.java @@ -21,7 +21,7 @@ public interface IUpgradeBase /** * 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. * The upgrade will fail registration if an already used ID is specified. * @@ -32,7 +32,7 @@ public interface IUpgradeBase /** * Return an unlocalised string to describe this type of computer in item names. - * + *

* Examples of built-in adjectives are "Wireless", "Mining" and "Crafty". * * @return The localisation key for this upgrade's adjective. @@ -44,7 +44,7 @@ public interface IUpgradeBase * Return an item stack representing the type of item that a computer must be crafted * with to create a version which holds this upgrade. This item stack is also used * to determine the upgrade given by {@code turtle.equipLeft()} or {@code pocket.equipBack()} - * + *

* This should be constant over a session (or at least a datapack reload). It is recommended * that you cache the stack too, in order to prevent constructing it every time the method * is called. @@ -56,11 +56,11 @@ public interface IUpgradeBase /** * Determine if an item is suitable for being used for this upgrade. - * + *

* When un-equipping an upgrade, we return {@link #getCraftingItem()} rather than * the original stack. In order to prevent people losing items with enchantments (or * repairing items with non-0 damage), we impose additional checks on the item. - * + *

* The default check requires that any non-capability NBT is exactly the same as the * crafting item, but this may be relaxed for your upgrade. * diff --git a/src/main/java/dan200/computercraft/api/detail/BasicItemDetailProvider.java b/src/main/java/dan200/computercraft/api/detail/BasicItemDetailProvider.java index 17b05c299..80c9fa144 100644 --- a/src/main/java/dan200/computercraft/api/detail/BasicItemDetailProvider.java +++ b/src/main/java/dan200/computercraft/api/detail/BasicItemDetailProvider.java @@ -49,7 +49,7 @@ public abstract class BasicItemDetailProvider implements IDetailProvider * This method is always called on the server thread, so it is safe to interact with the world here, but you should * take care to avoid long blocking operations as this will stall the server and other computers. * diff --git a/src/main/java/dan200/computercraft/api/filesystem/FileOperationException.java b/src/main/java/dan200/computercraft/api/filesystem/FileOperationException.java index 71e2ed102..3a325dec5 100644 --- a/src/main/java/dan200/computercraft/api/filesystem/FileOperationException.java +++ b/src/main/java/dan200/computercraft/api/filesystem/FileOperationException.java @@ -12,7 +12,7 @@ import java.util.Objects; /** * An {@link IOException} which occurred on a specific file. - * + *

* This may be thrown from a {@link IMount} or {@link IWritableMount} to give more information about a failure. */ public class FileOperationException extends IOException diff --git a/src/main/java/dan200/computercraft/api/filesystem/IFileSystem.java b/src/main/java/dan200/computercraft/api/filesystem/IFileSystem.java index f9564b0c5..54e7103b2 100644 --- a/src/main/java/dan200/computercraft/api/filesystem/IFileSystem.java +++ b/src/main/java/dan200/computercraft/api/filesystem/IFileSystem.java @@ -9,7 +9,7 @@ import java.io.IOException; /** * Provides a mount of the entire computer's file system. - * + *

* This exists for use by various APIs - one should not attempt to mount it. */ public interface IFileSystem extends IWritableMount diff --git a/src/main/java/dan200/computercraft/api/filesystem/IMount.java b/src/main/java/dan200/computercraft/api/filesystem/IMount.java index 4c78e615c..0be71ee7c 100644 --- a/src/main/java/dan200/computercraft/api/filesystem/IMount.java +++ b/src/main/java/dan200/computercraft/api/filesystem/IMount.java @@ -18,7 +18,7 @@ import java.util.List; /** * Represents a read only 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 * {@link ComputerCraftAPI#createSaveDirMount(World, String, long)} or * {@link ComputerCraftAPI#createResourceMount(String, String)}, or you're free to implement it yourselves! diff --git a/src/main/java/dan200/computercraft/api/filesystem/IWritableMount.java b/src/main/java/dan200/computercraft/api/filesystem/IWritableMount.java index 598aabee2..4f56d1a6d 100644 --- a/src/main/java/dan200/computercraft/api/filesystem/IWritableMount.java +++ b/src/main/java/dan200/computercraft/api/filesystem/IWritableMount.java @@ -18,7 +18,7 @@ import java.util.OptionalLong; /** * Represents a part of a virtual filesystem that can be mounted onto a computer using {@link IComputerAccess#mount(String, IMount)} * or {@link IComputerAccess#mountWritable(String, IWritableMount)}, that can also be written to. - * + *

* Ready made implementations of this interface can be created using * {@link ComputerCraftAPI#createSaveDirMount(World, String, long)}, or you're free to implement it yourselves! * diff --git a/src/main/java/dan200/computercraft/api/lua/GenericSource.java b/src/main/java/dan200/computercraft/api/lua/GenericSource.java index 32fba606a..c10b61447 100644 --- a/src/main/java/dan200/computercraft/api/lua/GenericSource.java +++ b/src/main/java/dan200/computercraft/api/lua/GenericSource.java @@ -17,17 +17,17 @@ import javax.annotation.Nonnull; /** * A generic source of {@link LuaMethod} functions. - * + *

* Unlike normal objects ({@link IDynamicLuaObject} or {@link IPeripheral}), methods do not target this object but * instead are defined as {@code static} and accept their target as the first parameter. This allows you to inject * methods onto objects you do not own, as well as declaring methods for a specific "trait" (for instance, a * {@link Capability}). - * + *

* Currently the "generic peripheral" system is incompatible with normal peripherals. Normal {@link IPeripheralProvider} * or {@link IPeripheral} implementations take priority. Tile entities which use this system are given a peripheral name * determined by their id, rather than any peripheral provider. This will hopefully change in the future, once a suitable * design has been established. - * + *

* For example, the main CC: Tweaked mod defines a generic source for inventories, which works on {@link IItemHandler}s: * *

{@code
@@ -49,7 +49,7 @@ public interface GenericSource
 {
     /**
      * A unique identifier for this generic source.
-     *
+     * 

* This is currently unused, but may be used in the future to allow disabling specific sources. It is recommended * to return an identifier using your mod's ID. * diff --git a/src/main/java/dan200/computercraft/api/lua/IArguments.java b/src/main/java/dan200/computercraft/api/lua/IArguments.java index 731b00c45..4809cfc77 100644 --- a/src/main/java/dan200/computercraft/api/lua/IArguments.java +++ b/src/main/java/dan200/computercraft/api/lua/IArguments.java @@ -185,7 +185,7 @@ public interface IArguments /** * Get an argument as a table in an unsafe manner. - * + *

* Classes implementing this interface may choose to implement a more optimised version which does not copy the * table, instead returning a wrapper version, making it more efficient. However, the caller must guarantee that * they do not access the table the computer thread (and so should not be used with main-thread functions) or once @@ -334,7 +334,7 @@ public interface IArguments /** * Get an argument as a table in an unsafe manner. - * + *

* Classes implementing this interface may choose to implement a more optimised version which does not copy the * table, instead returning a wrapper version, making it more efficient. However, the caller must guarantee that * they do not access off the computer thread (and so should not be used with main-thread functions) or once the @@ -446,7 +446,7 @@ public interface IArguments /** * This is called when the current function finishes, before any main thread tasks have run. - * + *

* Called when the current function returns, and so some values are no longer guaranteed to be safe to access. * * @deprecated This method was an internal implementation detail and is no longer used. diff --git a/src/main/java/dan200/computercraft/api/lua/IDynamicLuaObject.java b/src/main/java/dan200/computercraft/api/lua/IDynamicLuaObject.java index 60c6c922d..c47fb3156 100644 --- a/src/main/java/dan200/computercraft/api/lua/IDynamicLuaObject.java +++ b/src/main/java/dan200/computercraft/api/lua/IDynamicLuaObject.java @@ -11,7 +11,7 @@ import javax.annotation.Nonnull; /** * An interface for representing custom objects returned by peripherals or other Lua objects. - * + *

* Generally, one does not need to implement this type - it is sufficient to return an object with some methods * annotated with {@link LuaFunction}. {@link IDynamicLuaObject} is useful when you wish your available methods to * change at runtime. diff --git a/src/main/java/dan200/computercraft/api/lua/ILuaAPI.java b/src/main/java/dan200/computercraft/api/lua/ILuaAPI.java index f4421be6e..44513ae28 100644 --- a/src/main/java/dan200/computercraft/api/lua/ILuaAPI.java +++ b/src/main/java/dan200/computercraft/api/lua/ILuaAPI.java @@ -10,7 +10,7 @@ import dan200.computercraft.api.ComputerCraftAPI; /** * Represents a Lua object which is stored as a global variable on computer startup. This must either provide * {@link LuaFunction} annotated functions or implement {@link IDynamicLuaObject}. - * + *

* Before implementing this interface, consider alternative methods of providing methods. It is generally preferred * to use peripherals to provide functionality to users. * @@ -28,7 +28,7 @@ public interface ILuaAPI /** * Called when the computer is turned on. - * + *

* One should only interact with the file system. */ default void startup() @@ -44,7 +44,7 @@ public interface ILuaAPI /** * Called when the computer is turned off or unloaded. - * + *

* This should reset the state of the object, disposing any remaining file handles, or other resources. */ default void shutdown() diff --git a/src/main/java/dan200/computercraft/api/lua/ILuaContext.java b/src/main/java/dan200/computercraft/api/lua/ILuaContext.java index 36c2d37a0..6690eb487 100644 --- a/src/main/java/dan200/computercraft/api/lua/ILuaContext.java +++ b/src/main/java/dan200/computercraft/api/lua/ILuaContext.java @@ -17,7 +17,7 @@ public interface ILuaContext * Queue a task to be executed on the main server thread at the beginning of next tick, but do not wait for it to * complete. This should be used when you need to interact with the world in a thread-safe manner but do not care * 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. * @@ -31,7 +31,7 @@ public interface ILuaContext /** * Queue a task to be executed on the main server thread at the beginning of next tick, waiting for it to complete. * This should be used when you need to interact with the world in a thread-safe manner. - * + *

* Note that the return values of your task are handled as events, meaning more complex objects such as maps or * {@link IDynamicLuaObject} will not preserve their identities. * diff --git a/src/main/java/dan200/computercraft/api/lua/LuaFunction.java b/src/main/java/dan200/computercraft/api/lua/LuaFunction.java index 77290dd14..644d0b4d4 100644 --- a/src/main/java/dan200/computercraft/api/lua/LuaFunction.java +++ b/src/main/java/dan200/computercraft/api/lua/LuaFunction.java @@ -14,7 +14,7 @@ import java.util.Optional; /** * Used to mark a Java function which is callable from Lua. - * + *

* Methods annotated with {@link LuaFunction} must be public final instance methods. They can have any number of * parameters, but they must be of the following types: * @@ -24,12 +24,12 @@ import java.util.Optional; *

  • * Alternatively, one may specify the desired arguments as normal parameters and the argument parsing code will * be generated automatically. - * + *

    * Each parameter must be one of the given types supported by {@link IArguments} (for instance, {@link int} or * {@link Map}). Optional values are supported by accepting a parameter of type {@link Optional}. *

  • * - * + *

    * This function may return {@link MethodResult}. However, if you simply return a value (rather than having to yield), * you may return {@code void}, a single value (either an object or a primitive like {@code int}) or array of objects. * These will be treated the same as {@link MethodResult#of()}, {@link MethodResult#of(Object)} and @@ -58,7 +58,7 @@ public @interface LuaFunction /** * Allow using "unsafe" arguments, such {@link IArguments#getTableUnsafe(int)}. - * + *

    * This is incompatible with {@link #mainThread()}. * * @return Whether this function supports unsafe arguments. diff --git a/src/main/java/dan200/computercraft/api/lua/MethodResult.java b/src/main/java/dan200/computercraft/api/lua/MethodResult.java index 7d05b8805..ee16cd0d8 100644 --- a/src/main/java/dan200/computercraft/api/lua/MethodResult.java +++ b/src/main/java/dan200/computercraft/api/lua/MethodResult.java @@ -16,7 +16,7 @@ import java.util.Objects; /** * The result of invoking a Lua method. - * + *

    * Method results either return a value immediately ({@link #of(Object...)} or yield control to the parent coroutine. * When the current coroutine is resumed, we invoke the provided {@link ILuaCallback#resume(Object[])} callback. */ @@ -55,11 +55,11 @@ public final class MethodResult /** * Return a single value immediately. - * + *

    * Integers, doubles, floats, strings, booleans, {@link Map}, {@link Collection}s, arrays and {@code null} will be * converted to their corresponding Lua type. {@code byte[]} and {@link ByteBuffer} will be treated as binary * strings. {@link ILuaFunction} will be treated as a function. - * + *

    * In order to provide a custom object with methods, one may return a {@link IDynamicLuaObject}, or an arbitrary * class with {@link LuaFunction} annotations. Anything else will be converted to {@code nil}. * diff --git a/src/main/java/dan200/computercraft/api/media/IMedia.java b/src/main/java/dan200/computercraft/api/media/IMedia.java index dfd30e49d..f72308e02 100644 --- a/src/main/java/dan200/computercraft/api/media/IMedia.java +++ b/src/main/java/dan200/computercraft/api/media/IMedia.java @@ -16,7 +16,7 @@ import javax.annotation.Nullable; /** * Represents an item that can be placed in a disk drive and used by a Computer. - * + *

    * Implement this interface on your {@link Item} class to allow it to be used in the drive. Alternatively, register * a {@link IMediaProvider}. */ diff --git a/src/main/java/dan200/computercraft/api/network/IPacketReceiver.java b/src/main/java/dan200/computercraft/api/network/IPacketReceiver.java index 751f7587b..55b9f9fb0 100644 --- a/src/main/java/dan200/computercraft/api/network/IPacketReceiver.java +++ b/src/main/java/dan200/computercraft/api/network/IPacketReceiver.java @@ -33,7 +33,7 @@ public interface IPacketReceiver /** * Get the maximum distance this receiver can send and receive messages. - * + *

    * When determining whether a receiver can receive a message, the largest distance of the packet and receiver is * used - ensuring it is within range. If the packet or receiver is inter-dimensional, then the packet will always * be received. @@ -47,7 +47,7 @@ public interface IPacketReceiver /** * Determine whether this receiver can receive packets from other dimensions. - * + *

    * A device will receive an inter-dimensional packet if either it or the sending device is inter-dimensional. * * @return Whether this receiver receives packets from other dimensions. diff --git a/src/main/java/dan200/computercraft/api/network/wired/IWiredElement.java b/src/main/java/dan200/computercraft/api/network/wired/IWiredElement.java index 635e58bce..0f4630b8c 100644 --- a/src/main/java/dan200/computercraft/api/network/wired/IWiredElement.java +++ b/src/main/java/dan200/computercraft/api/network/wired/IWiredElement.java @@ -11,11 +11,11 @@ import javax.annotation.Nonnull; /** * An object which may be part of a wired network. - * + *

    * Elements should construct a node using {@link ComputerCraftAPI#createWiredNodeForElement(IWiredElement)}. This acts * as a proxy for all network objects. Whilst the node may change networks, an element's node should remain constant * for its lifespan. - * + *

    * Elements are generally tied to a block or tile entity in world. In such as case, one should provide the * {@link IWiredElement} capability for the appropriate sides. */ diff --git a/src/main/java/dan200/computercraft/api/network/wired/IWiredNetwork.java b/src/main/java/dan200/computercraft/api/network/wired/IWiredNetwork.java index faf8bb22a..3d3b7f917 100644 --- a/src/main/java/dan200/computercraft/api/network/wired/IWiredNetwork.java +++ b/src/main/java/dan200/computercraft/api/network/wired/IWiredNetwork.java @@ -13,12 +13,12 @@ import java.util.Map; /** * A wired network is composed of one of more {@link IWiredNode}s, a set of connections between them, and a series * of peripherals. - * + *

    * Networks from a connected graph. This means there is some path between all nodes on the network. Further more, if * there is some path between two nodes then they must be on the same network. {@link IWiredNetwork} will automatically * handle the merging and splitting of networks (and thus changing of available nodes and peripherals) as connections * change. - * + *

    * This does mean one can not rely on the network remaining consistent between subsequent operations. Consequently, * it is generally preferred to use the methods provided by {@link IWiredNode}. * @@ -28,7 +28,7 @@ public interface IWiredNetwork { /** * Create a connection between two nodes. - * + *

    * This should only be used on the server thread. * * @param left The first node to connect @@ -43,7 +43,7 @@ public interface IWiredNetwork /** * Destroy a connection between this node and another. - * + *

    * This should only be used on the server thread. * * @param left The first node in the connection. @@ -58,7 +58,7 @@ public interface IWiredNetwork /** * Sever all connections this node has, removing it from this network. - * + *

    * This should only be used on the server thread. You should only call this on nodes * that your network element owns. * @@ -72,7 +72,7 @@ public interface IWiredNetwork /** * Update the peripherals a node provides. - * + *

    * This should only be used on the server thread. You should only call this on nodes * that your network element owns. * diff --git a/src/main/java/dan200/computercraft/api/network/wired/IWiredNode.java b/src/main/java/dan200/computercraft/api/network/wired/IWiredNode.java index a5fcd38d4..56bfd6f36 100644 --- a/src/main/java/dan200/computercraft/api/network/wired/IWiredNode.java +++ b/src/main/java/dan200/computercraft/api/network/wired/IWiredNode.java @@ -13,14 +13,14 @@ import java.util.Map; /** * Wired nodes act as a layer between {@link IWiredElement}s and {@link IWiredNetwork}s. - * + *

    * Firstly, a node acts as a packet network, capable of sending and receiving modem messages to connected nodes. These * methods may be safely used on any thread. - * + *

    * When sending a packet, the system will attempt to find the shortest path between the two nodes based on their * element's position. Note that packet senders and receivers can have different locations from their associated * element: the distance between the two will be added to the total packet's distance. - * + *

    * Wired nodes also provide several convenience methods for interacting with a wired network. These should only ever * be used on the main server thread. */ @@ -37,7 +37,7 @@ public interface IWiredNode extends IPacketNetwork /** * The network this node is currently connected to. Note that this may change * after any network operation, so it should not be cached. - * + *

    * This should only be used on the server thread. * * @return This node's network. @@ -47,7 +47,7 @@ public interface IWiredNode extends IPacketNetwork /** * Create a connection from this node to another. - * + *

    * This should only be used on the server thread. * * @param node The other node to connect to. @@ -62,7 +62,7 @@ public interface IWiredNode extends IPacketNetwork /** * Destroy a connection between this node and another. - * + *

    * This should only be used on the server thread. * * @param node The other node to disconnect from. @@ -78,7 +78,7 @@ public interface IWiredNode extends IPacketNetwork /** * Sever all connections this node has, removing it from this network. - * + *

    * This should only be used on the server thread. You should only call this on nodes * that your network element owns. * @@ -94,7 +94,7 @@ public interface IWiredNode extends IPacketNetwork /** * Mark this node's peripherals as having changed. - * + *

    * This should only be used on the server thread. You should only call this on nodes * that your network element owns. * diff --git a/src/main/java/dan200/computercraft/api/network/wired/IWiredSender.java b/src/main/java/dan200/computercraft/api/network/wired/IWiredSender.java index 830b5a7fd..b5e7be58d 100644 --- a/src/main/java/dan200/computercraft/api/network/wired/IWiredSender.java +++ b/src/main/java/dan200/computercraft/api/network/wired/IWiredSender.java @@ -11,7 +11,7 @@ import javax.annotation.Nonnull; /** * An object on a {@link IWiredNetwork} capable of sending packets. - * + *

    * Unlike a regular {@link IPacketSender}, this must be associated with the node you are attempting to * to send the packet from. */ @@ -19,7 +19,7 @@ public interface IWiredSender extends IPacketSender { /** * The node in the network representing this object. - * + *

    * This should be used as a proxy for the main network. One should send packets * and register receivers through this object. * diff --git a/src/main/java/dan200/computercraft/api/peripheral/GenericPeripheral.java b/src/main/java/dan200/computercraft/api/peripheral/GenericPeripheral.java index 5eb6d37be..ae8e9d787 100644 --- a/src/main/java/dan200/computercraft/api/peripheral/GenericPeripheral.java +++ b/src/main/java/dan200/computercraft/api/peripheral/GenericPeripheral.java @@ -13,7 +13,7 @@ import javax.annotation.Nonnull; /** * A {@link GenericSource} which provides methods for a peripheral. - * + *

    * Unlike a {@link GenericSource}, all methods should target the same type, for instance a * {@link TileEntity} subclass or a capability interface. This is not currently enforced. */ @@ -21,13 +21,13 @@ public interface GenericPeripheral extends GenericSource { /** * Get the type of the exposed peripheral. - * + *

    * Unlike normal {@link IPeripheral}s, {@link GenericPeripheral} do not have to have a type. By default, the * resulting peripheral uses the resource name of the wrapped {@link TileEntity} (for instance {@code minecraft:chest}). - * + *

    * However, in some cases it may be more appropriate to specify a more readable name. Overriding this method allows * you to do so. - * + *

    * When multiple {@link GenericPeripheral}s return a non-empty peripheral type for a single tile entity, the * lexicographically smallest will be chosen. In order to avoid this conflict, this method should only be * implemented when your peripheral targets a single tile entity AND it's likely that you're the diff --git a/src/main/java/dan200/computercraft/api/peripheral/IComputerAccess.java b/src/main/java/dan200/computercraft/api/peripheral/IComputerAccess.java index 5342ccf70..57c436d36 100644 --- a/src/main/java/dan200/computercraft/api/peripheral/IComputerAccess.java +++ b/src/main/java/dan200/computercraft/api/peripheral/IComputerAccess.java @@ -105,11 +105,11 @@ public interface IComputerAccess /** * Unmounts a directory previously mounted onto the computers file system by {@link #mount(String, IMount)} * or {@link #mountWritable(String, IWritableMount)}. - * + *

    * When a directory is unmounted, it will disappear from the computers file system, and the user will no longer be * able to 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. - * + *

    * Note that you cannot unmount another peripheral's mounts. * * @param location The desired location in the computers file system of the directory to unmount. @@ -124,7 +124,7 @@ public interface IComputerAccess /** * Returns the numerical ID of this computer. - * + *

    * 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. * @@ -145,7 +145,7 @@ public interface IComputerAccess * @param arguments In addition to a name, you may pass an array of extra arguments to the event, that will * be supplied as extra return values to os.pullEvent(). Objects in the array will be converted * 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 NotAttachedException If the peripheral has been detached. * @see MethodResult#pullEvent(String, ILuaCallback) @@ -167,7 +167,7 @@ public interface IComputerAccess /** * Get a set of peripherals that this computer access can "see", along with their attachment name. - * + *

    * This may include other peripherals on the wired network or peripherals on other sides of the computer. * * @return All reachable peripherals @@ -191,12 +191,12 @@ public interface IComputerAccess /** * Get a {@link IWorkMonitor} for tasks your peripheral might execute on the main (server) thread. - * + *

    * This should be used to ensure your peripheral integrates with ComputerCraft's monitoring and limiting of how much * server time each computer consumes. You should not need to use this if you use * {@link ILuaContext#issueMainThreadTask(ILuaTask)} - this is intended for mods with their own system for running * work on the main thread. - * + *

    * Please note that the returned implementation is not thread-safe, and should only be used from the main * thread. * diff --git a/src/main/java/dan200/computercraft/api/peripheral/IDynamicPeripheral.java b/src/main/java/dan200/computercraft/api/peripheral/IDynamicPeripheral.java index 920b3b855..6a93d3335 100644 --- a/src/main/java/dan200/computercraft/api/peripheral/IDynamicPeripheral.java +++ b/src/main/java/dan200/computercraft/api/peripheral/IDynamicPeripheral.java @@ -11,7 +11,7 @@ import javax.annotation.Nonnull; /** * A peripheral whose methods are not known at runtime. - * + *

    * This behaves similarly to {@link IDynamicLuaObject}, though also accepting the current {@link IComputerAccess}. * Generally one may use {@link LuaFunction} instead of implementing this interface. */ @@ -30,7 +30,7 @@ public interface IDynamicPeripheral extends IPeripheral /** * This is called when a lua program on an attached computer calls {@code peripheral.call()} with * one of the methods exposed by {@link #getMethodNames()}. - * + *

    * Be aware that this will be called from the ComputerCraft Lua thread, and must be thread-safe when interacting * with Minecraft objects. * diff --git a/src/main/java/dan200/computercraft/api/peripheral/IPeripheral.java b/src/main/java/dan200/computercraft/api/peripheral/IPeripheral.java index e4d3621cb..aa1ed99ef 100644 --- a/src/main/java/dan200/computercraft/api/peripheral/IPeripheral.java +++ b/src/main/java/dan200/computercraft/api/peripheral/IPeripheral.java @@ -15,10 +15,10 @@ import java.util.Set; /** * The interface that defines a peripheral. - * + *

    * In order to expose a peripheral for your block or tile entity, you may either attach a {@link Capability}, or * register a {@link IPeripheralProvider}. This cannot be implemented {@link IPeripheral} directly on the tile. - * + *

    * Peripherals should provide a series of methods to the user, either using {@link LuaFunction} or by implementing * {@link IDynamicPeripheral}. */ @@ -47,15 +47,15 @@ public interface IPeripheral /** * Is called when when a computer is attaching to the peripheral. - * + *

    * This will occur when a peripheral is placed next to an active computer, when a computer is turned on next to a * peripheral, when a turtle travels into a square next to a peripheral, or when a wired modem adjacent to this * peripheral is does any of the above. - * + *

    * Between calls to attach and {@link #detach}, the attached computer can make method calls on the peripheral using * {@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 will be called from both the server thread and ComputerCraft Lua thread, and so must be thread-safe * and reentrant. * @@ -69,14 +69,14 @@ public interface IPeripheral /** * Called when a computer is detaching from the peripheral. - * + *

    * This will occur when a computer shuts down, when the peripheral is removed while attached to computers, when a * turtle moves away from a block attached to a peripheral, or when a wired modem adjacent to this peripheral is * detached. - * + *

    * This method can be used to keep track of which computers are attached to the peripheral, or to take action when * detachment occurs. - * + *

    * Be aware that this will be called from both the server and ComputerCraft Lua thread, and must be thread-safe * and reentrant. * @@ -102,7 +102,7 @@ public interface IPeripheral /** * 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. * diff --git a/src/main/java/dan200/computercraft/api/peripheral/IPeripheralProvider.java b/src/main/java/dan200/computercraft/api/peripheral/IPeripheralProvider.java index 1c35fe2bf..31e08fdca 100644 --- a/src/main/java/dan200/computercraft/api/peripheral/IPeripheralProvider.java +++ b/src/main/java/dan200/computercraft/api/peripheral/IPeripheralProvider.java @@ -15,7 +15,7 @@ import javax.annotation.Nonnull; /** * This interface is used to create peripheral implementations for blocks. - * + *

    * If you have a {@link TileEntity} which acts as a peripheral, you may alternatively expose the {@link IPeripheral} * capability. * diff --git a/src/main/java/dan200/computercraft/api/peripheral/IWorkMonitor.java b/src/main/java/dan200/computercraft/api/peripheral/IWorkMonitor.java index e7364f122..86b3ce39c 100644 --- a/src/main/java/dan200/computercraft/api/peripheral/IWorkMonitor.java +++ b/src/main/java/dan200/computercraft/api/peripheral/IWorkMonitor.java @@ -12,14 +12,14 @@ import java.util.concurrent.TimeUnit; /** * Monitors "work" associated with a computer, keeping track of how much a computer has done, and ensuring every * computer receives a fair share of any processing time. - * + *

    * This is primarily intended for work done by peripherals on the main thread (such as on a tile entity's tick), but * could be used for other purposes (such as complex computations done on another thread). - * + *

    * Before running a task, one should call {@link #canWork()} to determine if the computer is currently allowed to * execute work. If that returns true, you should execute the task and use {@link #trackWork(long, TimeUnit)} to inform * the monitor how long that task took. - * + *

    * Alternatively, use {@link #runWork(Runnable)} to run and keep track of work. * * @see IComputerAccess#getMainThreadMonitor() @@ -35,7 +35,7 @@ public interface IWorkMonitor /** * If the owning computer is currently allowed to execute work, and has ample time to do so. - * + *

    * This is effectively a more restrictive form of {@link #canWork()}. One should use that in order to determine if * you may do an initial piece of work, and shouldWork to determine if any additional task may be performed. * diff --git a/src/main/java/dan200/computercraft/api/peripheral/PeripheralType.java b/src/main/java/dan200/computercraft/api/peripheral/PeripheralType.java index 8b64bd7d0..4bfd71a27 100644 --- a/src/main/java/dan200/computercraft/api/peripheral/PeripheralType.java +++ b/src/main/java/dan200/computercraft/api/peripheral/PeripheralType.java @@ -16,7 +16,7 @@ import java.util.Set; /** * The type of a {@link GenericPeripheral}. - * + *

    * When determining the final type of the resulting peripheral, the union of all types is taken, with the * lexicographically smallest non-empty name being chosen. */ diff --git a/src/main/java/dan200/computercraft/api/pocket/AbstractPocketUpgrade.java b/src/main/java/dan200/computercraft/api/pocket/AbstractPocketUpgrade.java index 761e2ef85..cd884eb33 100644 --- a/src/main/java/dan200/computercraft/api/pocket/AbstractPocketUpgrade.java +++ b/src/main/java/dan200/computercraft/api/pocket/AbstractPocketUpgrade.java @@ -17,7 +17,7 @@ import java.util.function.Supplier; /** * A base class for {@link IPocketUpgrade}s. - * + *

    * One does not have to use this, but it does provide a convenient template. */ public abstract class AbstractPocketUpgrade implements IPocketUpgrade diff --git a/src/main/java/dan200/computercraft/api/pocket/IPocketAccess.java b/src/main/java/dan200/computercraft/api/pocket/IPocketAccess.java index 2512ede02..3507cae39 100644 --- a/src/main/java/dan200/computercraft/api/pocket/IPocketAccess.java +++ b/src/main/java/dan200/computercraft/api/pocket/IPocketAccess.java @@ -21,7 +21,7 @@ public interface IPocketAccess { /** * Gets the entity holding this item. - * + *

    * This must be called on the server thread. * * @return The holding entity, or {@code null} if none exists. @@ -67,7 +67,7 @@ public interface IPocketAccess /** * Get the upgrade-specific NBT. - * + *

    * This is persisted between computer reboots and chunk loads. * * @return The upgrade's NBT. diff --git a/src/main/java/dan200/computercraft/api/pocket/IPocketUpgrade.java b/src/main/java/dan200/computercraft/api/pocket/IPocketUpgrade.java index 3a9c9fc72..fa29795ef 100644 --- a/src/main/java/dan200/computercraft/api/pocket/IPocketUpgrade.java +++ b/src/main/java/dan200/computercraft/api/pocket/IPocketUpgrade.java @@ -22,7 +22,7 @@ public interface IPocketUpgrade extends IUpgradeBase { /** * Creates a peripheral for the pocket computer. - * + *

    * The peripheral created will be stored for the lifetime of the upgrade, will be passed an argument to * {@link #update(IPocketAccess, IPeripheral)} and will be attached, detached and have methods called in the same * manner as an ordinary peripheral. diff --git a/src/main/java/dan200/computercraft/api/turtle/AbstractTurtleUpgrade.java b/src/main/java/dan200/computercraft/api/turtle/AbstractTurtleUpgrade.java index e3f3718b6..9b7fbfb9d 100644 --- a/src/main/java/dan200/computercraft/api/turtle/AbstractTurtleUpgrade.java +++ b/src/main/java/dan200/computercraft/api/turtle/AbstractTurtleUpgrade.java @@ -17,7 +17,7 @@ import java.util.function.Supplier; /** * A base class for {@link ITurtleUpgrade}s. - * + *

    * One does not have to use this, but it does provide a convenient template. */ public abstract class AbstractTurtleUpgrade implements ITurtleUpgrade @@ -100,7 +100,7 @@ public abstract class AbstractTurtleUpgrade implements ITurtleUpgrade /** * A supplier which converts an item into an item stack. - * + *

    * Constructing item stacks is somewhat expensive due to attaching capabilities. We cache it if given a consistent item. */ private static final class CachedStack implements NonNullSupplier diff --git a/src/main/java/dan200/computercraft/api/turtle/ITurtleAccess.java b/src/main/java/dan200/computercraft/api/turtle/ITurtleAccess.java index cb1fc89e2..5f248aedf 100644 --- a/src/main/java/dan200/computercraft/api/turtle/ITurtleAccess.java +++ b/src/main/java/dan200/computercraft/api/turtle/ITurtleAccess.java @@ -22,7 +22,7 @@ import javax.annotation.Nullable; /** * 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 * {@link ITurtleUpgrade}. */ @@ -46,7 +46,7 @@ public interface ITurtleAccess /** * 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)}. * @@ -144,7 +144,7 @@ public interface ITurtleAccess /** * Get the inventory of this turtle. - * + *

    * Note: this inventory should only be accessed and modified on the server thread. * * @return This turtle's inventory @@ -155,7 +155,7 @@ public interface ITurtleAccess /** * Get the inventory of this turtle as an {@link IItemHandlerModifiable}. - * + *

    * Note: this inventory should only be accessed and modified on the server thread. * * @return This turtle's inventory @@ -278,7 +278,7 @@ public interface ITurtleAccess /** * 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. * diff --git a/src/main/java/dan200/computercraft/api/turtle/ITurtleCommand.java b/src/main/java/dan200/computercraft/api/turtle/ITurtleCommand.java index 0ad021235..3eb5ec80c 100644 --- a/src/main/java/dan200/computercraft/api/turtle/ITurtleCommand.java +++ b/src/main/java/dan200/computercraft/api/turtle/ITurtleCommand.java @@ -17,7 +17,7 @@ public interface ITurtleCommand { /** * 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 * failure with an error message to indicate the command cannot be executed at this time. * diff --git a/src/main/java/dan200/computercraft/api/turtle/ITurtleUpgrade.java b/src/main/java/dan200/computercraft/api/turtle/ITurtleUpgrade.java index 30c2fcdbd..3c924057e 100644 --- a/src/main/java/dan200/computercraft/api/turtle/ITurtleUpgrade.java +++ b/src/main/java/dan200/computercraft/api/turtle/ITurtleUpgrade.java @@ -41,7 +41,7 @@ public interface ITurtleUpgrade extends IUpgradeBase /** * Will only be called for peripheral upgrades. Creates a peripheral for a turtle being placed using this upgrade. - * + *

    * The peripheral created will be stored for the lifetime of the upgrade and will be passed as an argument to * {@link #update(ITurtleAccess, TurtleSide)}. It will be attached, detached and have methods called in the same * manner as a Computer peripheral. @@ -60,7 +60,7 @@ public interface ITurtleUpgrade extends IUpgradeBase /** * 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. - * + *

    * Conforming implementations should fire {@link BlockEvent.BreakEvent} and {@link TurtleBlockEvent.Dig} for * digging, {@link AttackEntityEvent} and {@link TurtleAttackEvent} for attacking. * @@ -83,7 +83,7 @@ public interface ITurtleUpgrade extends IUpgradeBase /** * 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.model.ModelManager#getModel(ModelResourceLocation)} or any other * source. diff --git a/src/main/java/dan200/computercraft/api/turtle/TurtleAnimation.java b/src/main/java/dan200/computercraft/api/turtle/TurtleAnimation.java index 8f3a4df60..125b6b669 100644 --- a/src/main/java/dan200/computercraft/api/turtle/TurtleAnimation.java +++ b/src/main/java/dan200/computercraft/api/turtle/TurtleAnimation.java @@ -7,7 +7,7 @@ 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) diff --git a/src/main/java/dan200/computercraft/api/turtle/event/TurtleActionEvent.java b/src/main/java/dan200/computercraft/api/turtle/event/TurtleActionEvent.java index 6bf2ae3d7..b0200a26e 100644 --- a/src/main/java/dan200/computercraft/api/turtle/event/TurtleActionEvent.java +++ b/src/main/java/dan200/computercraft/api/turtle/event/TurtleActionEvent.java @@ -37,7 +37,7 @@ public class TurtleActionEvent extends TurtleEvent /** * Sets the cancellation state of this action. - * + *

    * If {@code cancel} is {@code true}, this action will not be carried out. * * @param cancel The new canceled value. @@ -53,7 +53,7 @@ public class TurtleActionEvent extends TurtleEvent /** * Set the cancellation state of this action, setting a failure message if required. - * + *

    * If {@code cancel} is {@code true}, this action will not be carried out. * * @param cancel The new canceled value. diff --git a/src/main/java/dan200/computercraft/api/turtle/event/TurtleAttackEvent.java b/src/main/java/dan200/computercraft/api/turtle/event/TurtleAttackEvent.java index f6dd38181..1253903bd 100644 --- a/src/main/java/dan200/computercraft/api/turtle/event/TurtleAttackEvent.java +++ b/src/main/java/dan200/computercraft/api/turtle/event/TurtleAttackEvent.java @@ -19,10 +19,10 @@ import java.util.Objects; /** * Fired when a turtle attempts to attack an entity. - * + *

    * This must be fired by {@link ITurtleUpgrade#useTool(ITurtleAccess, TurtleSide, TurtleVerb, Direction)}, * as the base {@code turtle.attack()} command does not fire it. - * + *

    * Note that such commands should also fire {@link AttackEntityEvent}, so you do not need to listen to both. * * @see TurtleAction#ATTACK diff --git a/src/main/java/dan200/computercraft/api/turtle/event/TurtleBlockEvent.java b/src/main/java/dan200/computercraft/api/turtle/event/TurtleBlockEvent.java index ee40cb6c1..eb89f7252 100644 --- a/src/main/java/dan200/computercraft/api/turtle/event/TurtleBlockEvent.java +++ b/src/main/java/dan200/computercraft/api/turtle/event/TurtleBlockEvent.java @@ -24,13 +24,13 @@ import java.util.Objects; /** * A general event for when a turtle interacts with a block or region. - * + *

    * You should generally listen to one of the sub-events instead, cancelling them where * appropriate. - * + *

    * Note that you are not guaranteed to receive this event, if it has been cancelled by other * mechanisms, such as block protection systems. - * + *

    * Be aware that some events (such as {@link TurtleInventoryEvent}) do not necessarily interact * with a block, simply objects within that block space. */ @@ -72,10 +72,10 @@ public abstract class TurtleBlockEvent extends TurtlePlayerEvent /** * Fired when a turtle attempts to dig a block. - * + *

    * This must be fired by {@link ITurtleUpgrade#useTool(ITurtleAccess, TurtleSide, TurtleVerb, Direction)}, * as the base {@code turtle.dig()} command does not fire it. - * + *

    * Note that such commands should also fire {@link BlockEvent.BreakEvent}, so you do not need to listen to both. * * @see TurtleAction#DIG @@ -176,7 +176,7 @@ public abstract class TurtleBlockEvent extends TurtlePlayerEvent /** * Fired when a turtle gathers data on a block in world. - * + *

    * You may prevent blocks being inspected, or add additional information to the result. * * @see TurtleAction#INSPECT diff --git a/src/main/java/dan200/computercraft/api/turtle/event/TurtleEvent.java b/src/main/java/dan200/computercraft/api/turtle/event/TurtleEvent.java index f0b39504f..28be6e84b 100644 --- a/src/main/java/dan200/computercraft/api/turtle/event/TurtleEvent.java +++ b/src/main/java/dan200/computercraft/api/turtle/event/TurtleEvent.java @@ -14,7 +14,7 @@ import java.util.Objects; /** * A base class for all events concerning a turtle. This will only ever constructed and fired on the server side, * so sever specific methods on {@link ITurtleAccess} are safe to use. - * + *

    * You should generally not need to subscribe to this event, preferring one of the more specific classes. * * @see TurtleActionEvent diff --git a/src/main/java/dan200/computercraft/api/turtle/event/TurtleInspectItemEvent.java b/src/main/java/dan200/computercraft/api/turtle/event/TurtleInspectItemEvent.java index 9a54c2b55..ab69fa615 100644 --- a/src/main/java/dan200/computercraft/api/turtle/event/TurtleInspectItemEvent.java +++ b/src/main/java/dan200/computercraft/api/turtle/event/TurtleInspectItemEvent.java @@ -15,7 +15,7 @@ import java.util.Objects; /** * Fired when a turtle gathers data on an item in its inventory. - * + *

    * You may prevent items being inspected, or add additional information to the result. Be aware that this may be fired * on the computer thread, and so any operations on it must be thread safe. * diff --git a/src/main/java/dan200/computercraft/api/turtle/event/TurtlePlayerEvent.java b/src/main/java/dan200/computercraft/api/turtle/event/TurtlePlayerEvent.java index fd15730e8..86975e01f 100644 --- a/src/main/java/dan200/computercraft/api/turtle/event/TurtlePlayerEvent.java +++ b/src/main/java/dan200/computercraft/api/turtle/event/TurtlePlayerEvent.java @@ -13,7 +13,7 @@ import java.util.Objects; /** * An action done by a turtle which is normally done by a player. - * + *

    * {@link #getPlayer()} may be used to modify the player's attributes or perform permission checks. */ public abstract class TurtlePlayerEvent extends TurtleActionEvent @@ -30,7 +30,7 @@ public abstract class TurtlePlayerEvent extends TurtleActionEvent /** * A fake player, representing this turtle. - * + *

    * This may be used for triggering permission checks. * * @return A {@link FakePlayer} representing this turtle. diff --git a/src/main/java/dan200/computercraft/api/turtle/event/TurtleRefuelEvent.java b/src/main/java/dan200/computercraft/api/turtle/event/TurtleRefuelEvent.java index 79cf5d568..2e9b7e2a6 100644 --- a/src/main/java/dan200/computercraft/api/turtle/event/TurtleRefuelEvent.java +++ b/src/main/java/dan200/computercraft/api/turtle/event/TurtleRefuelEvent.java @@ -14,7 +14,7 @@ import java.util.Objects; /** * Fired when a turtle attempts to refuel from an item. - * + *

    * One may use {@link #setCanceled(boolean, String)} to prevent refueling from this specific item. Additionally, you * may use {@link #setHandler(Handler)} to register a custom fuel provider. */ @@ -33,7 +33,7 @@ public class TurtleRefuelEvent extends TurtleActionEvent /** * Get the stack we are attempting to refuel from. - * + *

    * Do not modify the returned stack - all modifications should be done within the {@link Handler}. * * @return The stack to refuel from. @@ -57,7 +57,7 @@ public class TurtleRefuelEvent extends TurtleActionEvent /** * Set the refuel handler for this stack. - * + *

    * You should call this if you can actually refuel from this item, and ideally only if there are no existing * handlers. * diff --git a/src/main/java/dan200/computercraft/client/render/RenderTypes.java b/src/main/java/dan200/computercraft/client/render/RenderTypes.java index 772f379f0..73b0003ad 100644 --- a/src/main/java/dan200/computercraft/client/render/RenderTypes.java +++ b/src/main/java/dan200/computercraft/client/render/RenderTypes.java @@ -31,7 +31,7 @@ public class RenderTypes /** * Renders a fullbright terminal which also writes to the depth layer. This is used when z-fighting isn't an issue - * for instance rendering an empty terminal or inside a GUI. - * + *

    * This is identical to vanilla's {@link RenderType#text}. Forge overrides one with a definition which sets * sortOnUpload to true, which is entirely broken! */ diff --git a/src/main/java/dan200/computercraft/client/render/text/DirectFixedWidthFontRenderer.java b/src/main/java/dan200/computercraft/client/render/text/DirectFixedWidthFontRenderer.java index 53d29e699..492404873 100644 --- a/src/main/java/dan200/computercraft/client/render/text/DirectFixedWidthFontRenderer.java +++ b/src/main/java/dan200/computercraft/client/render/text/DirectFixedWidthFontRenderer.java @@ -24,14 +24,14 @@ import static org.lwjgl.system.MemoryUtil.memPutFloat; /** * An optimised copy of {@link FixedWidthFontRenderer} emitter emits directly to a {@link ByteBuffer} rather than * emitting to {@link IVertexBuilder}. This allows us to emit vertices very quickly, when using the VBO renderer. - * + *

    * There are some limitations here: *

    - * + *

    * Note this is almost an exact copy of {@link FixedWidthFontRenderer}. While the code duplication is unfortunate, * it is measurably faster than introducing polymorphism into {@link FixedWidthFontRenderer}. * diff --git a/src/main/java/dan200/computercraft/client/render/text/FixedWidthFontRenderer.java b/src/main/java/dan200/computercraft/client/render/text/FixedWidthFontRenderer.java index 90eb9e449..39a3cb157 100644 --- a/src/main/java/dan200/computercraft/client/render/text/FixedWidthFontRenderer.java +++ b/src/main/java/dan200/computercraft/client/render/text/FixedWidthFontRenderer.java @@ -21,7 +21,7 @@ import static dan200.computercraft.client.render.RenderTypes.FULL_BRIGHT_LIGHTMA /** * Handles rendering fixed width text and computer terminals. - * + *

    * This class has several modes of usage: *

    - * + *

    * :::note * All functions in the API work on absolute paths, and do not take the @{shell.dir|current directory} into account. * You can use @{shell.resolve} to convert a relative path into an absolute one. * ::: - * + *

    * ## Mounts * While a computer can only have one hard drive and filesystem, other filesystems may be "mounted" inside it. For * instance, the {@link dan200.computercraft.shared.peripheral.diskdrive.DiskDrivePeripheral drive peripheral} mounts * its disk's contents at {@code "disk/"}, {@code "disk1/"}, etc... - * + *

    * You can see which mount a path belongs to with the {@link #getDrive} function. This returns {@code "hdd"} for the * computer's main filesystem ({@code "/"}), {@code "rom"} for the rom ({@code "rom/"}). - * + *

    * Most filesystems have a limited capacity, operations which would cause that capacity to be reached (such as writing * an incredibly large file) will fail. You can see a mount's capacity with {@link #getCapacity} and the remaining * space with {@link #getFreeSpace}. @@ -287,7 +287,7 @@ public class FSAPI implements ILuaAPI /** * Moves a file or directory from one path to another. - * + *

    * Any parent directories are created as needed. * * @param path The current file or directory to move from. @@ -310,7 +310,7 @@ public class FSAPI implements ILuaAPI /** * Copies a file or directory to a new path. - * + *

    * Any parent directories are created as needed. * * @param path The file or directory to copy. @@ -333,7 +333,7 @@ public class FSAPI implements ILuaAPI /** * Deletes a file or directory. - * + *

    * If the path points to a directory, all of the enclosed files and * subdirectories are also deleted. * @@ -358,14 +358,14 @@ public class FSAPI implements ILuaAPI /** * Opens a file for reading or writing at a path. - * + *

    * The {@code mode} string can be any of the following: *

    - * + *

    * The mode may also have a "b" at the end, which opens the file in "binary * mode". This allows you to read binary files, as well as seek within a file. * @@ -516,7 +516,7 @@ public class FSAPI implements ILuaAPI /** * Searches for files matching a string with wildcards. - * + *

    * This string is formatted like a normal path string, but can include any * number of wildcards ({@code *}) to look for files matching anything. * For example, rom/*/command* will look for any path starting with @@ -568,10 +568,10 @@ public class FSAPI implements ILuaAPI /** * Get attributes about a specific file or folder. - * + *

    * The returned attributes table contains information about the size of the file, whether it is a directory, * when it was created and last modified, and whether it is read only. - * + *

    * The creation and modification times are given as the number of milliseconds since the UNIX epoch. This may be * given to {@link OSAPI#date} in order to convert it to more usable form. * diff --git a/src/main/java/dan200/computercraft/core/apis/OSAPI.java b/src/main/java/dan200/computercraft/core/apis/OSAPI.java index 9312b4c1d..9b7b0c943 100644 --- a/src/main/java/dan200/computercraft/core/apis/OSAPI.java +++ b/src/main/java/dan200/computercraft/core/apis/OSAPI.java @@ -173,7 +173,7 @@ public class OSAPI implements ILuaAPI * Starts a timer that will run for the specified number of seconds. Once * the timer fires, a {@code timer} event will be added to the queue with * the ID returned from this function as the first parameter. - * + *

    * As with @{os.sleep|sleep}, {@code timer} will automatically be rounded up * to the nearest multiple of 0.05 seconds, as it waits for a fixed amount * of world ticks. @@ -315,13 +315,13 @@ public class OSAPI implements ILuaAPI /** * Returns the current time depending on the string passed in. This will * always be in the range [0.0, 24.0). - * + *

    * * If called with {@code ingame}, the current world time will be returned. * This is the default if nothing is passed. * * If called with {@code utc}, returns the hour of the day in UTC time. * * If called with {@code local}, returns the hour of the day in the * timezone the server is located in. - * + *

    * This function can also be called with a table returned from {@link #date}, * which will convert the date fields into a UNIX timestamp (number of * seconds since 1 January 1970). @@ -363,7 +363,7 @@ public class OSAPI implements ILuaAPI /** * Returns the day depending on the locale specified. - * + *

    * * If called with {@code ingame}, returns the number of days since the * world was created. This is the default. * * If called with {@code utc}, returns the number of days since 1 January @@ -395,7 +395,7 @@ public class OSAPI implements ILuaAPI /** * Returns the number of milliseconds since an epoch depending on the locale. - * + *

    * * If called with {@code ingame}, returns the number of milliseconds since the * world was created. This is the default. * * If called with {@code utc}, returns the number of milliseconds since 1 @@ -446,12 +446,12 @@ public class OSAPI implements ILuaAPI /** * Returns a date string (or table) using a specified format string and * optional time to format. - * + *

    * The format string takes the same formats as C's {@code strftime} function * (http://www.cplusplus.com/reference/ctime/strftime/). In extension, it * can be prefixed with an exclamation mark ({@code !}) to use UTC time * instead of the server's local timezone. - * + *

    * If the format is exactly {@code *t} (optionally prefixed with {@code !}), a * table will be returned instead. This table has fields for the year, month, * day, hour, minute, second, day of the week, day of the year, and whether diff --git a/src/main/java/dan200/computercraft/core/apis/RedstoneAPI.java b/src/main/java/dan200/computercraft/core/apis/RedstoneAPI.java index 9d13b6f2d..3b6a69c4b 100644 --- a/src/main/java/dan200/computercraft/core/apis/RedstoneAPI.java +++ b/src/main/java/dan200/computercraft/core/apis/RedstoneAPI.java @@ -12,7 +12,7 @@ import dan200.computercraft.core.computer.ComputerSide; /** * Get and set redstone signals adjacent to this computer. - * + *

    * The {@link RedstoneAPI} library exposes three "types" of redstone control: * - Binary input/output ({@link #setOutput}/{@link #getInput}): These simply check if a redstone wire has any input or * output. A signal strength of 1 and 15 are treated the same. @@ -21,10 +21,10 @@ import dan200.computercraft.core.computer.ComputerSide; * - Bundled cables ({@link #setBundledOutput}/{@link #getBundledInput}): These interact with "bundled" cables, such * as those from Project:Red. These allow you to send 16 separate on/off signals. Each channel corresponds to a * colour, with the first being @{colors.white} and the last @{colors.black}. - * + *

    * Whenever a redstone input changes, a @{event!redstone} event will be fired. This may be used instead of repeativly * polling. - * + *

    * This module may also be referred to as {@code rs}. For example, one may call {@code rs.getSides()} instead of * {@link #getSides}. * @@ -47,7 +47,7 @@ import dan200.computercraft.core.computer.ComputerSide; * os.pullEvent("redstone") -- Wait for a change to inputs. * end * }

    - * + *

    * [comparator]: https://minecraft.gamepedia.com/Redstone_Comparator#Subtract_signal_strength "Redstone Comparator on * the Minecraft wiki." * @cc.module redstone diff --git a/src/main/java/dan200/computercraft/core/apis/TermMethods.java b/src/main/java/dan200/computercraft/core/apis/TermMethods.java index 4235b8c0e..b6435915b 100644 --- a/src/main/java/dan200/computercraft/core/apis/TermMethods.java +++ b/src/main/java/dan200/computercraft/core/apis/TermMethods.java @@ -39,7 +39,7 @@ public abstract class TermMethods /** * Write {@code text} at the current cursor position, moving the cursor to the end of the text. - * + *

    * Unlike functions like {@code write} and {@code print}, this does not wrap the text - it simply copies the * text to the current terminal line. * @@ -61,7 +61,7 @@ public abstract class TermMethods /** * Move all positions up (or down) by {@code y} pixels. - * + *

    * Every pixel in the terminal will be replaced by the line {@code y} pixels below it. If {@code y} is negative, it * will copy pixels from above instead. * @@ -245,7 +245,7 @@ public abstract class TermMethods /** * Determine if this terminal supports colour. - * + *

    * Terminals which do not support colour will still allow writing coloured text/backgrounds, but it will be * displayed in greyscale. * @@ -261,10 +261,10 @@ public abstract class TermMethods /** * Writes {@code text} to the terminal with the specific foreground and background characters. - * + *

    * As with {@link #write(IArguments)}, the text will be written at the current cursor location, with the cursor * moving to the end of the text. - * + *

    * {@code textColour} and {@code backgroundColour} must both be strings the same length as {@code text}. All * characters represent a single hexadecimal digit, which is converted to one of CC's colours. For instance, * {@code "a"} corresponds to purple. @@ -299,7 +299,7 @@ public abstract class TermMethods /** * Set the palette for a specific colour. - * + *

    * ComputerCraft's palette system allows you to change how a specific colour should be displayed. For instance, you * can make @{colors.red} more red by setting its palette to #FF0000. This does now allow you to draw more * colours - you are still limited to 16 on the screen at one time - but you can change which colours are diff --git a/src/main/java/dan200/computercraft/core/apis/handles/BinaryReadableHandle.java b/src/main/java/dan200/computercraft/core/apis/handles/BinaryReadableHandle.java index d45fada35..0af250a2c 100644 --- a/src/main/java/dan200/computercraft/core/apis/handles/BinaryReadableHandle.java +++ b/src/main/java/dan200/computercraft/core/apis/handles/BinaryReadableHandle.java @@ -249,11 +249,11 @@ public class BinaryReadableHandle extends HandleGeneric /** * Seek to a new position within the file, changing where bytes are written to. The new position is an offset * given by {@code offset}, relative to a start position determined by {@code whence}: - * + *

    * - {@code "set"}: {@code offset} is relative to the beginning of the file. * - {@code "cur"}: Relative to the current position. This is the default. * - {@code "end"}: Relative to the end of the file. - * + *

    * In case of success, {@code seek} returns the new file position from the beginning of the file. * * @param whence Where the offset is relative to. diff --git a/src/main/java/dan200/computercraft/core/apis/handles/BinaryWritableHandle.java b/src/main/java/dan200/computercraft/core/apis/handles/BinaryWritableHandle.java index c68eacf34..78be1750b 100644 --- a/src/main/java/dan200/computercraft/core/apis/handles/BinaryWritableHandle.java +++ b/src/main/java/dan200/computercraft/core/apis/handles/BinaryWritableHandle.java @@ -117,11 +117,11 @@ public class BinaryWritableHandle extends HandleGeneric /** * Seek to a new position within the file, changing where bytes are written to. The new position is an offset * given by {@code offset}, relative to a start position determined by {@code whence}: - * + *

    * - {@code "set"}: {@code offset} is relative to the beginning of the file. * - {@code "cur"}: Relative to the current position. This is the default. * - {@code "end"}: Relative to the end of the file. - * + *

    * In case of success, {@code seek} returns the new file position from the beginning of the file. * * @param whence Where the offset is relative to. diff --git a/src/main/java/dan200/computercraft/core/apis/handles/HandleGeneric.java b/src/main/java/dan200/computercraft/core/apis/handles/HandleGeneric.java index 094b613a4..44f001e69 100644 --- a/src/main/java/dan200/computercraft/core/apis/handles/HandleGeneric.java +++ b/src/main/java/dan200/computercraft/core/apis/handles/HandleGeneric.java @@ -39,7 +39,7 @@ public abstract class HandleGeneric /** * Close this file, freeing any resources it uses. - * + *

    * Once a file is closed it may no longer be read or written to. * * @throws LuaException If the file has already been closed. diff --git a/src/main/java/dan200/computercraft/core/apis/http/CheckUrl.java b/src/main/java/dan200/computercraft/core/apis/http/CheckUrl.java index 65467643d..ff3581522 100644 --- a/src/main/java/dan200/computercraft/core/apis/http/CheckUrl.java +++ b/src/main/java/dan200/computercraft/core/apis/http/CheckUrl.java @@ -13,7 +13,7 @@ import java.util.concurrent.Future; /** * Checks a URL using {@link NetworkUtils#getAddress(String, int, boolean)}} - * + *

    * This requires a DNS lookup, and so needs to occur off-thread. */ public class CheckUrl extends Resource diff --git a/src/main/java/dan200/computercraft/core/apis/http/NetworkUtils.java b/src/main/java/dan200/computercraft/core/apis/http/NetworkUtils.java index 27ee23fb8..05d312b55 100644 --- a/src/main/java/dan200/computercraft/core/apis/http/NetworkUtils.java +++ b/src/main/java/dan200/computercraft/core/apis/http/NetworkUtils.java @@ -126,7 +126,7 @@ public final class NetworkUtils /** * Create a {@link InetSocketAddress} from a {@link java.net.URI}. - * + *

    * Note, this may require a DNS lookup, and so should not be executed on the main CC thread. * * @param uri The URI to fetch. @@ -141,7 +141,7 @@ public final class NetworkUtils /** * Create a {@link InetSocketAddress} from the resolved {@code host} and port. - * + *

    * Note, this may require a DNS lookup, and so should not be executed on the main CC thread. * * @param host The host to resolve. diff --git a/src/main/java/dan200/computercraft/core/apis/http/Resource.java b/src/main/java/dan200/computercraft/core/apis/http/Resource.java index ac776ff7a..8c61b31a0 100644 --- a/src/main/java/dan200/computercraft/core/apis/http/Resource.java +++ b/src/main/java/dan200/computercraft/core/apis/http/Resource.java @@ -68,7 +68,7 @@ public abstract class Resource> implements Closeable /** * Clean up any pending resources - * + *

    * Note, this may be called multiple times, and so should be thread-safe and * avoid any major side effects. */ diff --git a/src/main/java/dan200/computercraft/core/asm/ObjectSource.java b/src/main/java/dan200/computercraft/core/asm/ObjectSource.java index 40866c27d..b47c862e8 100644 --- a/src/main/java/dan200/computercraft/core/asm/ObjectSource.java +++ b/src/main/java/dan200/computercraft/core/asm/ObjectSource.java @@ -9,7 +9,7 @@ import java.util.function.BiConsumer; /** * A Lua object which exposes additional methods. - * + *

    * This can be used to merge multiple objects together into one. Ideally this'd be part of the API, but I'm not entirely * happy with the interface - something I'd like to think about first. */ diff --git a/src/main/java/dan200/computercraft/core/computer/Environment.java b/src/main/java/dan200/computercraft/core/computer/Environment.java index 18a8a0595..480354dcd 100644 --- a/src/main/java/dan200/computercraft/core/computer/Environment.java +++ b/src/main/java/dan200/computercraft/core/computer/Environment.java @@ -22,7 +22,7 @@ import java.util.Iterator; /** * Represents the "environment" that a {@link Computer} exists in. - * + *

    * This handles storing and updating of peripherals and redstone. * *

    Redstone

    diff --git a/src/main/java/dan200/computercraft/core/computer/TimeoutState.java b/src/main/java/dan200/computercraft/core/computer/TimeoutState.java index 021c706db..dffd7b32b 100644 --- a/src/main/java/dan200/computercraft/core/computer/TimeoutState.java +++ b/src/main/java/dan200/computercraft/core/computer/TimeoutState.java @@ -12,18 +12,18 @@ import java.util.concurrent.TimeUnit; /** * Used to measure how long a computer has executed for, and thus the relevant timeout states. - * + *

    * Timeouts are mostly used for execution of Lua code: we should ideally never have a state where constructing the APIs * or machines themselves takes more than a fraction of a second. - * + *

    * When a computer runs, it is allowed to run for 7 seconds ({@link #TIMEOUT}). After that point, the "soft abort" flag * is set ({@link #isSoftAborted()}). Here, the Lua machine will attempt to abort the program in some safe manner * (namely, throwing a "Too long without yielding" error). - * + *

    * Now, if a computer still does not stop after that period, they're behaving really badly. 1.5 seconds after a soft * abort ({@link #ABORT_TIMEOUT}), we trigger a hard abort (note, this is done from the computer thread manager). This * will destroy the entire Lua runtime and shut the computer down. - * + *

    * The Lua runtime is also allowed to pause execution if there are other computers contesting for work. All computers * are allowed to run for {@link ComputerThread#scaledPeriod()} nanoseconds (see {@link #currentDeadline}). After that * period, if any computers are waiting to be executed then we'll set the paused flag to true ({@link #isPaused()}. @@ -104,7 +104,7 @@ public final class TimeoutState /** * Whether we should pause execution of this machine. - * + *

    * This is determined by whether we've consumed our time slice, and if there are other computers waiting to perform * work. * diff --git a/src/main/java/dan200/computercraft/core/filesystem/ChannelWrapper.java b/src/main/java/dan200/computercraft/core/filesystem/ChannelWrapper.java index 94f60b2d5..a41aae499 100644 --- a/src/main/java/dan200/computercraft/core/filesystem/ChannelWrapper.java +++ b/src/main/java/dan200/computercraft/core/filesystem/ChannelWrapper.java @@ -11,7 +11,7 @@ import java.nio.channels.Channel; /** * Wraps some closeable object such as a buffered writer, and the underlying stream. - * + *

    * When flushing a buffer before closing, some implementations will not close the buffer if an exception is thrown * this causes us to release the channel, but not actually close it. This wrapper will attempt to close the wrapper (and * so hopefully flush the channel), and then close the underlying channel. diff --git a/src/main/java/dan200/computercraft/core/filesystem/FileSystem.java b/src/main/java/dan200/computercraft/core/filesystem/FileSystem.java index 089c42054..c2c2e16d8 100644 --- a/src/main/java/dan200/computercraft/core/filesystem/FileSystem.java +++ b/src/main/java/dan200/computercraft/core/filesystem/FileSystem.java @@ -31,7 +31,7 @@ public class FileSystem { /** * Maximum depth that {@link #copyRecursive(String, MountWrapper, String, MountWrapper, int)} will descend into. - * + *

    * This is a pretty arbitrary value, though hopefully it is large enough that it'll never be normally hit. This * exists to prevent it overflowing if it ever gets into an infinite loop. */ diff --git a/src/main/java/dan200/computercraft/core/filesystem/FileSystemWrapper.java b/src/main/java/dan200/computercraft/core/filesystem/FileSystemWrapper.java index 604b94427..5e9777d80 100644 --- a/src/main/java/dan200/computercraft/core/filesystem/FileSystemWrapper.java +++ b/src/main/java/dan200/computercraft/core/filesystem/FileSystemWrapper.java @@ -15,12 +15,12 @@ import java.lang.ref.WeakReference; /** * An alternative closeable implementation that will free up resources in the filesystem. - * + *

    * The {@link FileSystem} maps weak references of this to its underlying object. If the wrapper has been disposed of * (say, the Lua object referencing it has gone), then the wrapped object will be closed by the filesystem. - * + *

    * Closing this will stop the filesystem tracking it, reducing the current descriptor count. - * + *

    * In an ideal world, we'd just wrap the closeable. However, as we do some {@code instanceof} checks * on the stream, it's not really possible as it'd require numerous instances. * diff --git a/src/main/java/dan200/computercraft/core/filesystem/TrackingCloseable.java b/src/main/java/dan200/computercraft/core/filesystem/TrackingCloseable.java index a3679b05c..272be8a06 100644 --- a/src/main/java/dan200/computercraft/core/filesystem/TrackingCloseable.java +++ b/src/main/java/dan200/computercraft/core/filesystem/TrackingCloseable.java @@ -10,7 +10,7 @@ import java.io.IOException; /** * A {@link Closeable} which knows when it has been closed. - * + *

    * This is a quick (though racey) way of providing more friendly (and more similar to Lua) * error messages to the user. */ diff --git a/src/main/java/dan200/computercraft/core/lua/BasicFunction.java b/src/main/java/dan200/computercraft/core/lua/BasicFunction.java index b6a12ddec..1b9fa4905 100644 --- a/src/main/java/dan200/computercraft/core/lua/BasicFunction.java +++ b/src/main/java/dan200/computercraft/core/lua/BasicFunction.java @@ -17,7 +17,7 @@ import org.squiddev.cobalt.function.VarArgFunction; /** * An "optimised" version of {@link ResultInterpreterFunction} which is guaranteed to never yield. - * + *

    * As we never yield, we do not need to push a function to the stack, which removes a small amount of overhead. */ class BasicFunction extends VarArgFunction diff --git a/src/main/java/dan200/computercraft/core/lua/ILuaMachine.java b/src/main/java/dan200/computercraft/core/lua/ILuaMachine.java index 45f0e2ea8..85c866897 100644 --- a/src/main/java/dan200/computercraft/core/lua/ILuaMachine.java +++ b/src/main/java/dan200/computercraft/core/lua/ILuaMachine.java @@ -15,11 +15,11 @@ import java.io.InputStream; /** * Represents a machine which will execute Lua code. Technically this API is flexible enough to support many languages, * but you'd need a way to provide alternative ROMs, BIOSes, etc... - * + *

    * There should only be one concrete implementation at any one time, which is currently {@link CobaltLuaMachine}. If * external mod authors are interested in registering their own machines, we can look into how we can provide some * mechanism for registering these. - * + *

    * This should provide implementations of {@link dan200.computercraft.api.lua.ILuaContext}, and the ability to convert * {@link IDynamicLuaObject}s into something the VM understands, as well as handling method calls. */ @@ -28,7 +28,7 @@ public interface ILuaMachine /** * Inject an API into the global environment of this machine. This should construct an object, as it would for any * {@link IDynamicLuaObject} and set it to all names in {@link ILuaAPI#getNames()}. - * + *

    * Called before {@link #loadBios(InputStream)}. * * @param api The API to register. @@ -38,7 +38,7 @@ public interface ILuaMachine /** * Create a function from the provided program, and set it up to run when {@link #handleEvent(String, Object[])} is * called. - * + *

    * This should destroy the machine if it failed to load the bios. * * @param bios The stream containing the boot program. @@ -48,7 +48,7 @@ public interface ILuaMachine /** * Resume the machine, either starting or resuming the coroutine. - * + *

    * This should destroy the machine if it failed to execute successfully. * * @param eventName The name of the event. This is {@code null} when first starting the machine. Note, this may diff --git a/src/main/java/dan200/computercraft/core/lua/MachineResult.java b/src/main/java/dan200/computercraft/core/lua/MachineResult.java index a0313abfc..8ce4e8be0 100644 --- a/src/main/java/dan200/computercraft/core/lua/MachineResult.java +++ b/src/main/java/dan200/computercraft/core/lua/MachineResult.java @@ -13,7 +13,7 @@ import java.io.InputStream; /** * The result of executing an action on a machine. - * + *

    * Errors should halt the machine and display the error to the user. * * @see ILuaMachine#loadBios(InputStream) diff --git a/src/main/java/dan200/computercraft/shared/CommonHooks.java b/src/main/java/dan200/computercraft/shared/CommonHooks.java index e1cbbdd06..0683a6719 100644 --- a/src/main/java/dan200/computercraft/shared/CommonHooks.java +++ b/src/main/java/dan200/computercraft/shared/CommonHooks.java @@ -33,7 +33,7 @@ import java.util.Set; /** * Miscellaneous hooks which are present on the client and server. - * + *

    * These should possibly be refactored into separate classes at some point, but are fine here for now. * * @see dan200.computercraft.client.ClientHooks For client-specific ones. diff --git a/src/main/java/dan200/computercraft/shared/command/ClientCommands.java b/src/main/java/dan200/computercraft/shared/command/ClientCommands.java index aac33bbcc..b167bcf3f 100644 --- a/src/main/java/dan200/computercraft/shared/command/ClientCommands.java +++ b/src/main/java/dan200/computercraft/shared/command/ClientCommands.java @@ -19,7 +19,7 @@ import java.io.File; /** * Basic client-side commands. - * + *

    * Simply hooks into client chat messages and intercepts matching strings. */ @Mod.EventBusSubscriber( modid = ComputerCraft.MOD_ID, value = Dist.CLIENT ) diff --git a/src/main/java/dan200/computercraft/shared/command/arguments/RepeatArgumentType.java b/src/main/java/dan200/computercraft/shared/command/arguments/RepeatArgumentType.java index 82e2f283d..d6e350f84 100644 --- a/src/main/java/dan200/computercraft/shared/command/arguments/RepeatArgumentType.java +++ b/src/main/java/dan200/computercraft/shared/command/arguments/RepeatArgumentType.java @@ -30,10 +30,10 @@ import java.util.function.BiConsumer; /** * Reads one argument multiple times. - * + *

    * Note that this must be the last element in an argument chain: in order to improve the quality of error messages, * we will always try to consume another argument while there is input remaining. - * + *

    * One problem with how parsers function, is that they must consume some input: and thus we * * @param The type of each value returned diff --git a/src/main/java/dan200/computercraft/shared/command/text/TableBuilder.java b/src/main/java/dan200/computercraft/shared/command/text/TableBuilder.java index 9b666f81d..60deeb8fa 100644 --- a/src/main/java/dan200/computercraft/shared/command/text/TableBuilder.java +++ b/src/main/java/dan200/computercraft/shared/command/text/TableBuilder.java @@ -59,7 +59,7 @@ public class TableBuilder /** * Get the unique identifier for this table type. - * + *

    * When showing a table within Minecraft, previous instances of this table with * the same ID will be removed from chat. * @@ -72,7 +72,7 @@ public class TableBuilder /** * Get the number of columns for this table. - * + *

    * This will be the same as {@link #getHeaders()}'s length if it is is non-{@code null}, * otherwise the length of the first column. * diff --git a/src/main/java/dan200/computercraft/shared/computer/apis/CommandAPI.java b/src/main/java/dan200/computercraft/shared/computer/apis/CommandAPI.java index fe8a22bd8..d762e2709 100644 --- a/src/main/java/dan200/computercraft/shared/computer/apis/CommandAPI.java +++ b/src/main/java/dan200/computercraft/shared/computer/apis/CommandAPI.java @@ -110,11 +110,11 @@ public class CommandAPI implements ILuaAPI /** * Asynchronously execute a command. - * + *

    * Unlike {@link #exec}, this will immediately return, instead of waiting for the * command to execute. This allows you to run multiple commands at the same * time. - * + *

    * When this command has finished executing, it will queue a `task_complete` * event containing the result of executing this command (what {@link #exec} would * return). @@ -184,10 +184,10 @@ public class CommandAPI implements ILuaAPI /** * Get information about a range of blocks. - * + *

    * This returns the same information as @{getBlockInfo}, just for multiple * blocks at once. - * + *

    * Blocks are traversed by ascending y level, followed by z and x - the returned * table may be indexed using `x + z*width + y*depth*depth`. * @@ -245,7 +245,7 @@ public class CommandAPI implements ILuaAPI /** * Get some basic information about a block. - * + *

    * The returned table contains the current name, metadata and block state (as * with @{turtle.inspect}). If there is a tile entity for that block, its NBT * will also be returned. diff --git a/src/main/java/dan200/computercraft/shared/computer/blocks/ComputerPeripheral.java b/src/main/java/dan200/computercraft/shared/computer/blocks/ComputerPeripheral.java index 5ea9df771..b854d56bf 100644 --- a/src/main/java/dan200/computercraft/shared/computer/blocks/ComputerPeripheral.java +++ b/src/main/java/dan200/computercraft/shared/computer/blocks/ComputerPeripheral.java @@ -14,7 +14,7 @@ import javax.annotation.Nullable; /** * A computer or turtle wrapped as a peripheral. - * + *

    * This allows for basic interaction with adjacent computers. Computers wrapped as peripherals will have the type * {@code computer} while turtles will be {@code turtle}. * diff --git a/src/main/java/dan200/computercraft/shared/computer/blocks/TileComputerBase.java b/src/main/java/dan200/computercraft/shared/computer/blocks/TileComputerBase.java index 28ad57ed1..d19a74440 100644 --- a/src/main/java/dan200/computercraft/shared/computer/blocks/TileComputerBase.java +++ b/src/main/java/dan200/computercraft/shared/computer/blocks/TileComputerBase.java @@ -279,7 +279,7 @@ public abstract class TileComputerBase extends TileGeneric implements IComputerT /** * Update all redstone and peripherals. - * + *

    * This should only be really be called when the computer is being ticked (though there are some cases where it * won't be), as peripheral scanning requires adjacent tiles to be in a "correct" state - which may not be the case * if they're still updating! diff --git a/src/main/java/dan200/computercraft/shared/computer/inventory/ComputerMenuWithoutInventory.java b/src/main/java/dan200/computercraft/shared/computer/inventory/ComputerMenuWithoutInventory.java index ed3eee627..9b80a9023 100644 --- a/src/main/java/dan200/computercraft/shared/computer/inventory/ComputerMenuWithoutInventory.java +++ b/src/main/java/dan200/computercraft/shared/computer/inventory/ComputerMenuWithoutInventory.java @@ -19,7 +19,7 @@ import java.util.function.Predicate; /** * A computer menu which does not have any visible inventory. - * + *

    * This adds invisible versions of the player's hotbars slots, to ensure they're synced to the client when changed. */ public class ComputerMenuWithoutInventory extends ContainerComputerBase diff --git a/src/main/java/dan200/computercraft/shared/network/NetworkMessage.java b/src/main/java/dan200/computercraft/shared/network/NetworkMessage.java index bea9af919..65ac2679f 100644 --- a/src/main/java/dan200/computercraft/shared/network/NetworkMessage.java +++ b/src/main/java/dan200/computercraft/shared/network/NetworkMessage.java @@ -20,7 +20,7 @@ public interface NetworkMessage { /** * Write this packet to a buffer. - * + *

    * This may be called on any thread, so this should be a pure operation. * * @param buf The buffer to write data to. diff --git a/src/main/java/dan200/computercraft/shared/network/client/PlayRecordClientMessage.java b/src/main/java/dan200/computercraft/shared/network/client/PlayRecordClientMessage.java index 765d99269..20c269c92 100644 --- a/src/main/java/dan200/computercraft/shared/network/client/PlayRecordClientMessage.java +++ b/src/main/java/dan200/computercraft/shared/network/client/PlayRecordClientMessage.java @@ -19,7 +19,7 @@ import javax.annotation.Nonnull; /** * Starts or stops a record on the client, depending on if {@link #soundEvent} is {@code null}. - * + *

    * Used by disk drives to play record items. * * @see dan200.computercraft.shared.peripheral.diskdrive.TileDiskDrive diff --git a/src/main/java/dan200/computercraft/shared/network/client/SpeakerAudioClientMessage.java b/src/main/java/dan200/computercraft/shared/network/client/SpeakerAudioClientMessage.java index 57f8ba342..f71ea01ec 100644 --- a/src/main/java/dan200/computercraft/shared/network/client/SpeakerAudioClientMessage.java +++ b/src/main/java/dan200/computercraft/shared/network/client/SpeakerAudioClientMessage.java @@ -19,7 +19,7 @@ import java.util.UUID; /** * Starts a sound on the client. - * + *

    * Used by speakers to play sounds. * * @see dan200.computercraft.shared.peripheral.speaker.TileSpeaker diff --git a/src/main/java/dan200/computercraft/shared/network/client/SpeakerMoveClientMessage.java b/src/main/java/dan200/computercraft/shared/network/client/SpeakerMoveClientMessage.java index 2fc17a053..17969e366 100644 --- a/src/main/java/dan200/computercraft/shared/network/client/SpeakerMoveClientMessage.java +++ b/src/main/java/dan200/computercraft/shared/network/client/SpeakerMoveClientMessage.java @@ -18,7 +18,7 @@ import java.util.UUID; /** * Starts a sound on the client. - * + *

    * Used by speakers to play sounds. * * @see dan200.computercraft.shared.peripheral.speaker.TileSpeaker diff --git a/src/main/java/dan200/computercraft/shared/network/client/SpeakerPlayClientMessage.java b/src/main/java/dan200/computercraft/shared/network/client/SpeakerPlayClientMessage.java index 692eb7733..637b4d334 100644 --- a/src/main/java/dan200/computercraft/shared/network/client/SpeakerPlayClientMessage.java +++ b/src/main/java/dan200/computercraft/shared/network/client/SpeakerPlayClientMessage.java @@ -19,7 +19,7 @@ import java.util.UUID; /** * Starts a sound on the client. - * + *

    * Used by speakers to play sounds. * * @see dan200.computercraft.shared.peripheral.speaker.TileSpeaker diff --git a/src/main/java/dan200/computercraft/shared/network/client/SpeakerStopClientMessage.java b/src/main/java/dan200/computercraft/shared/network/client/SpeakerStopClientMessage.java index 43db5c0c4..2b91572c2 100644 --- a/src/main/java/dan200/computercraft/shared/network/client/SpeakerStopClientMessage.java +++ b/src/main/java/dan200/computercraft/shared/network/client/SpeakerStopClientMessage.java @@ -17,7 +17,7 @@ import java.util.UUID; /** * Stops a sound on the client - * + *

    * Called when a speaker is broken. * * @see dan200.computercraft.shared.peripheral.speaker.TileSpeaker diff --git a/src/main/java/dan200/computercraft/shared/peripheral/commandblock/CommandBlockPeripheral.java b/src/main/java/dan200/computercraft/shared/peripheral/commandblock/CommandBlockPeripheral.java index c9158726d..4092930c0 100644 --- a/src/main/java/dan200/computercraft/shared/peripheral/commandblock/CommandBlockPeripheral.java +++ b/src/main/java/dan200/computercraft/shared/peripheral/commandblock/CommandBlockPeripheral.java @@ -28,10 +28,10 @@ import static dan200.computercraft.shared.Capabilities.CAPABILITY_PERIPHERAL; /** * This peripheral allows you to interact with command blocks. - * + *

    * Command blocks are only wrapped as peripherals if the {@code enable_command_block} option is true within the * config. - * + *

    * This API is not the same as the {@link CommandAPI} API, which is exposed on command computers. * * @cc.module command diff --git a/src/main/java/dan200/computercraft/shared/peripheral/diskdrive/DiskDrivePeripheral.java b/src/main/java/dan200/computercraft/shared/peripheral/diskdrive/DiskDrivePeripheral.java index db47fe6ef..b4cf0c6cc 100644 --- a/src/main/java/dan200/computercraft/shared/peripheral/diskdrive/DiskDrivePeripheral.java +++ b/src/main/java/dan200/computercraft/shared/peripheral/diskdrive/DiskDrivePeripheral.java @@ -22,14 +22,14 @@ import java.util.Optional; /** * Disk drives are a peripheral which allow you to read and write to floppy disks and other "mountable media" (such as * computers or turtles). They also allow you to {@link #playAudio play records}. - * + *

    * When a disk drive attaches some mount (such as a floppy disk or computer), it attaches a folder called {@code disk}, * {@code disk2}, etc... to the root directory of the computer. This folder can be used to interact with the files on * that disk. - * + *

    * When a disk is inserted, a {@code disk} event is fired, with the side peripheral is on. Likewise, when the disk is * detached, a {@code disk_eject} event is fired. - * + *

    * ## Recipe *

    * @@ -80,9 +80,9 @@ public class DiskDrivePeripheral implements IPeripheral /** * Sets or clears the label for a disk. - * + *

    * If no label or {@code nil} is passed, the label will be cleared. - * + *

    * If the inserted disk's label can't be changed (for example, a record), * an error will be thrown. * diff --git a/src/main/java/dan200/computercraft/shared/peripheral/generic/methods/ArgumentHelpers.java b/src/main/java/dan200/computercraft/shared/peripheral/generic/methods/ArgumentHelpers.java index 45df94641..87ba464f7 100644 --- a/src/main/java/dan200/computercraft/shared/peripheral/generic/methods/ArgumentHelpers.java +++ b/src/main/java/dan200/computercraft/shared/peripheral/generic/methods/ArgumentHelpers.java @@ -15,7 +15,7 @@ import javax.annotation.Nonnull; /** * A few helpers for working with arguments. - * + *

    * This should really be moved into the public API. However, until I have settled on a suitable format, we'll keep it * where it is used. */ diff --git a/src/main/java/dan200/computercraft/shared/peripheral/generic/methods/EnergyMethods.java b/src/main/java/dan200/computercraft/shared/peripheral/generic/methods/EnergyMethods.java index 22bddd3ac..3bb359167 100644 --- a/src/main/java/dan200/computercraft/shared/peripheral/generic/methods/EnergyMethods.java +++ b/src/main/java/dan200/computercraft/shared/peripheral/generic/methods/EnergyMethods.java @@ -16,9 +16,9 @@ import javax.annotation.Nonnull; /** * Methods for interacting with blocks using Forge's energy storage system. - * + *

    * This works with energy storage blocks, as well as generators and machines which consume energy. - * + *

    * :::note * Due to limitations with Forge's energy API, it is not possible to measure throughput (i.e. RF * used/generated per tick). diff --git a/src/main/java/dan200/computercraft/shared/peripheral/generic/methods/FluidMethods.java b/src/main/java/dan200/computercraft/shared/peripheral/generic/methods/FluidMethods.java index bb44ea614..260d491ec 100644 --- a/src/main/java/dan200/computercraft/shared/peripheral/generic/methods/FluidMethods.java +++ b/src/main/java/dan200/computercraft/shared/peripheral/generic/methods/FluidMethods.java @@ -54,10 +54,10 @@ public class FluidMethods implements GenericPeripheral /** * Get all "tanks" in this fluid storage. - * + *

    * Each tank either contains some amount of fluid or is empty. Tanks with fluids inside will return some basic * information about the fluid, including its name and amount. - * + *

    * The returned table is sparse, and so empty tanks will be `nil` - it is recommended to loop over using `pairs` * rather than `ipairs`. * @@ -81,7 +81,7 @@ public class FluidMethods implements GenericPeripheral /** * Move a fluid from one fluid container to another connected one. - * + *

    * This allows you to pull fluid in the current fluid container to another container on the same wired * network. Both containers must attached to wired modems which are connected via a cable. * @@ -122,7 +122,7 @@ public class FluidMethods implements GenericPeripheral /** * Move a fluid from a connected fluid container into this oneone. - * + *

    * This allows you to pull fluid in the current fluid container from another container on the same wired * network. Both containers must attached to wired modems which are connected via a cable. * diff --git a/src/main/java/dan200/computercraft/shared/peripheral/generic/methods/InventoryMethods.java b/src/main/java/dan200/computercraft/shared/peripheral/generic/methods/InventoryMethods.java index f847923a2..b8cf441e4 100644 --- a/src/main/java/dan200/computercraft/shared/peripheral/generic/methods/InventoryMethods.java +++ b/src/main/java/dan200/computercraft/shared/peripheral/generic/methods/InventoryMethods.java @@ -67,12 +67,12 @@ public class InventoryMethods implements GenericPeripheral /** * List all items in this inventory. This returns a table, with an entry for each slot. - * + *

    * Each item in the inventory is represented by a table containing some basic information, much like * {@link dan200.computercraft.shared.turtle.apis.TurtleAPI#getItemDetail} includes. More information can be fetched * with {@link #getItemDetail}. The table contains the item `name`, the `count` and an a (potentially nil) hash of * the item's `nbt.` This NBT data doesn't contain anything useful, but allows you to distinguish identical items. - * + *

    * The returned table is sparse, and so empty slots will be `nil` - it is recommended to loop over using `pairs` * rather than `ipairs`. * @@ -104,13 +104,13 @@ public class InventoryMethods implements GenericPeripheral /** * Get detailed information about an item. - * + *

    * The returned information contains the same information as each item in * {@link #list}, as well as additional details like the display name * (`displayName`), item groups (`itemGroups`), which are the creative tabs * an item will appear under, and item and item durability (`damage`, * `maxDamage`, `durability`). - * + *

    * Some items include more information (such as enchantments) - it is * recommended to print it out using @{textutils.serialize} or in the Lua * REPL, to explore what is available. @@ -151,7 +151,7 @@ public class InventoryMethods implements GenericPeripheral /** * Get the maximum number of items which can be stored in this slot. - * + *

    * Typically this will be limited to 64 items. However, some inventories (such as barrels or caches) can store * hundreds or thousands of items in one slot. * @@ -178,7 +178,7 @@ public class InventoryMethods implements GenericPeripheral /** * Push items from one inventory to another connected one. - * + *

    * This allows you to push an item in an inventory to another inventory on the same wired network. Both * inventories must attached to wired modems which are connected via a cable. * @@ -225,7 +225,7 @@ public class InventoryMethods implements GenericPeripheral /** * Pull items from a connected inventory into this one. - * + *

    * This allows you to transfer items between inventories on the same wired network. Both this and the source * inventory must attached to wired modems which are connected via a cable. * diff --git a/src/main/java/dan200/computercraft/shared/peripheral/modem/ModemPeripheral.java b/src/main/java/dan200/computercraft/shared/peripheral/modem/ModemPeripheral.java index c815f67ab..547b1a33b 100644 --- a/src/main/java/dan200/computercraft/shared/peripheral/modem/ModemPeripheral.java +++ b/src/main/java/dan200/computercraft/shared/peripheral/modem/ModemPeripheral.java @@ -22,31 +22,31 @@ import java.util.Set; /** * Modems allow you to send messages between computers over long distances. - * + *

    * :::tip * Modems provide a fairly basic set of methods, which makes them very flexible but often hard to work with. The * {@literal @}{rednet} API is built on top of modems, and provides a more user-friendly interface. * ::: - * + *

    * ## Sending and receiving messages * Modems operate on a series of channels, a bit like frequencies on a radio. Any modem can send a message on a * particular channel, but only those which have {@link #open opened} the channel and are "listening in" can receive * messages. - * + *

    * Channels are represented as an integer between 0 and 65535 inclusive. These channels don't have any defined meaning, * though some APIs or programs will assign a meaning to them. For instance, the @{gps} module sends all its messages on * channel 65534 (@{gps.CHANNEL_GPS}), while @{rednet} uses channels equal to the computer's ID. - * + *

    * - Sending messages is done with the {@link #transmit(int, int, Object)} message. * - Receiving messages is done by listening to the @{modem_message} event. - * + *

    * ## Types of modem * CC: Tweaked comes with three kinds of modem, with different capabilities. * *