1
0
mirror of https://github.com/SquidDev-CC/CC-Tweaked synced 2025-01-13 10:50:30 +00:00
Modernized/improved/actually updated version of ComputerCraft: https://tweaked.cc
Go to file
Jonathan Coates e7fe22d4f8
Don't round trip values in executeMainThreadTask
I've been meaning to fix this for over 6 years, and just kept
forgetting.

Previously ILuaContext.executeMainThreadTask worked by running
ILuaContext.issueMainThreadTask, pulling task_complete events, and then
returning the results.

While this makes the implementation simple, it means that the task's
results were converted into Lua values (in order to queue the event) and
then back into Java ones (when the event was pulled), before eventually
being converted into Lua once more.

Not only is this inefficient, as roundtripping isn't lossless, you
couldn't return functions or rich objects from main thread functions
(see https://github.com/dan200/ComputerCraft/issues/125).

We now store the return value on the Java side and then return that when
the receiving the task_complete event - the event no longer carries the
result. Note this does not affect methods using issueMainThreadTask!
2022-12-15 20:19:28 +00:00
.github Support renaming files directly without copying/deleting 2022-12-04 21:59:30 +00:00
buildSrc Use git shortlog for gathering contributors 2022-12-13 20:31:59 +00:00
config Add a couple of errorprone plugins 2022-11-10 08:54:09 +00:00
doc Move some functions out of bios into their own APIs 2022-11-21 22:47:07 +00:00
gradle Update to latest Forge 2022-12-15 17:53:50 +00:00
projects Don't round trip values in executeMainThreadTask 2022-12-15 20:19:28 +00:00
tools Some refactoring of mounts 2022-12-09 22:02:31 +00:00
.editorconfig Reformat everything 2022-11-04 13:41:38 +00:00
.git-blame-ignore-revs Exclude the previous commit from git blame 2022-11-04 13:42:00 +00:00
.gitattributes Update project paths in our utility build scripts 2022-11-10 09:12:28 +00:00
.gitignore Split CC:T into common and forge projects 2022-11-10 08:54:09 +00:00
.gitpod.yml Use a Gradle plugin to download illuaminate 2022-09-11 14:11:33 +01:00
.pre-commit-config.yaml Split CC:T into common and forge projects 2022-11-10 08:54:09 +00:00
build.gradle.kts Various improvements to packaging 2022-11-17 09:26:57 +00:00
CODE_OF_CONDUCT.md Add a code of conduct 2022-07-08 22:08:50 +01:00
CONTRIBUTING.md Generate en_us.json via datagen 2022-11-20 13:00:43 +00:00
gradle.properties Update to Minecraft 1.19.3 2022-12-08 19:45:02 +00:00
gradlew Bump Gradle and Kotlin versions 2021-11-26 21:12:20 +00:00
gradlew.bat Bump Gradle/ForgeGradle version 2021-02-13 12:39:52 +00:00
illuaminate.sexp Support renaming files directly without copying/deleting 2022-12-04 21:59:30 +00:00
LICENSE Add a pre commit hook to lint code 2021-04-28 21:24:27 +01:00
package-lock.json Update npm packages 2022-07-21 20:38:44 +01:00
package.json Update npm packages 2022-07-21 20:38:44 +01:00
README.md Actually update README with the new maven coordinates 2022-12-09 18:05:35 +00:00
settings.gradle.kts Initial pass of the API breaking changes for 1.19.3 (#1232) 2022-12-03 15:02:00 +00:00

CC: Tweaked

Current build status Download CC: Tweaked on CurseForge

CC: Tweaked is a mod for Minecraft which adds programmable computers, turtles and more to the game. A fork of the much-beloved ComputerCraft, it continues its legacy with better performance, stability, and a wealth of new features.

CC: Tweaked can be installed from CurseForge or Modrinth. It requires the Minecraft Forge mod loader, but versions are available for Fabric.

Contributing

Any contribution is welcome, be that using the mod, reporting bugs or contributing code. If you want to get started developing the mod, check out the instructions here.

Community

If you need help getting started with CC: Tweaked, want to show off your latest project, or just want to chat about ComputerCraft, do check out our forum and GitHub discussions page! There's also a fairly populated, albeit quiet IRC channel, if that's more your cup of tea.

We also host fairly comprehensive documentation at tweaked.cc.

Using

CC: Tweaked is hosted on my maven repo, and so is relatively simple to depend on. You may wish to add a soft (or hard) dependency in your mods.toml file, with the appropriate version bounds, to ensure that API functionality you depend on is present.

repositories {
  maven {
    url "https://squiddev.cc/maven/"
    content {
      includeGroup("cc.tweaked")
      includeModule("org.squiddev", "Cobalt")
    }
  }
}

dependencies {
  // Vanilla (i.e. for multi-loader systems)
  compileOnly("cc.tweaked:cc-tweaked-$mcVersion-common-api")

  // Forge Gradle
  compileOnly(fg.deobf("cc.tweaked:cc-tweaked-$mcVersion-forge-api:$cctVersion"))
  runtimeOnly(fg.deobf("cc.tweaked:cc-tweaked-$mcVersion-forge:$cctVersion"))

  // Fabric Loom
  modCompileOnly("cc.tweaked:cc-tweaked-$mcVersion-fabric-api:$cctVersion")
  modRuntimeOnly("cc.tweaked:cc-tweaked-$mcVersion-fabric:$cctVersion")
}

You should also be careful to only use classes within the dan200.computercraft.api package. Non-API classes are subject to change at any point. If you depend on functionality outside the API, file an issue, and we can look into exposing more features.

We bundle the API sources with the jar, so documentation should be easily viewable within your editor. Alternatively, the generated documentation can be browsed online.