mirror of
				https://github.com/SquidDev-CC/CC-Tweaked
				synced 2025-10-21 17:07:39 +00:00 
			
		
		
		
	Compare commits
	
		
			119 Commits
		
	
	
		
			v1.16.5-1.
			...
			v1.19.2
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 5e31dcde83 | ||
|   | 5184883af1 | ||
|   | 0c45112262 | ||
|   | 0bf1672f45 | ||
|   | e1b8ac1f84 | ||
|   | deea552d99 | ||
|   | 54229c2ce1 | ||
|   | 1346a26179 | ||
|   | 14df44f09d | ||
|   | 1a21529499 | ||
|   | 2546990f41 | ||
|   | b39ca02464 | ||
|   | 628618105c | ||
|   | 075ba03f5d | ||
|   | 10bf84b631 | ||
|   | c346e22a45 | ||
|   | 418e1335b1 | ||
|   | d52372df31 | ||
|   | cc72e1c2bd | ||
|   | d28afcc6a9 | ||
|   | 220ed21e6e | ||
|   | 09d465774d | ||
|   | dfc8f48f12 | ||
|   | abe2ec4686 | ||
|   | 5333cda44e | ||
|   | dc88fbeb12 | ||
|   | c5eb7a9501 | ||
|   | bc969db2be | ||
|   | 50b7646178 | ||
|   | 3fa6b5bc9d | ||
|   | 33e65e39e3 | ||
|   | 0380e60590 | ||
|   | 2918892ee2 | ||
|   | e43dd9f7c6 | ||
|   | 244fd95034 | ||
|   | 14e98e2fcb | ||
|   | dcf5d59109 | ||
|   | b95083c77e | ||
|   | c54c8c3ea6 | ||
|   | f79c67e243 | ||
|   | 6ec7ebe439 | ||
|   | 76fe33760d | ||
|   | cb549d8f43 | ||
|   | 7b400fdcdd | ||
|   | ab70d918b5 | ||
|   | c64644b9ec | ||
|   | afb12eb342 | ||
|   | 64f5ca02b3 | ||
|   | 84bca21b0c | ||
|   | b6757c416f | ||
|   | dc9d3f2d15 | ||
|   | 807825d74e | ||
|   | 14c17676c6 | ||
|   | 324519575c | ||
|   | fbcf26bdc9 | ||
|   | 30ab6bd045 | ||
|   | 2ea816b78b | ||
|   | 56dcc57755 | ||
|   | a4830aff86 | ||
|   | 621bc526be | ||
|   | 605e1f6b9b | ||
|   | cb66ef7e30 | ||
|   | fd2f6a38c1 | ||
|   | 229821d398 | ||
|   | 1f2e0c444d | ||
|   | 429baa350c | ||
|   | 7fe62485fa | ||
|   | fe10c68099 | ||
|   | 06092cfddd | ||
|   | 9967dc5740 | ||
|   | b920e04c59 | ||
|   | baa1b5a5c9 | ||
|   | e84663a5c5 | ||
|   | 1c46220c42 | ||
|   | 889b445855 | ||
|   | 19553a981e | ||
|   | 15f4dbd061 | ||
|   | 98e12c7c3e | ||
|   | dfad319864 | ||
|   | 111b58f533 | ||
|   | 9345652808 | ||
|   | d40163b409 | ||
|   | 96400966d7 | ||
|   | db83bd4f64 | ||
|   | 579a38d366 | ||
|   | 0e6797c7da | ||
|   | c935577768 | ||
|   | c2b4077aa1 | ||
|   | ac020859f3 | ||
|   | 238be8955b | ||
|   | f997b02b8f | ||
|   | 799bb77847 | ||
|   | 2f66792a0d | ||
|   | 6cae8e211e | ||
|   | 48b1b2f01d | ||
|   | 8c45fd362a | ||
|   | 07b13dd2b4 | ||
|   | 45e84e1ede | ||
|   | 725dfa764f | ||
|   | c221502ec9 | ||
|   | 234f18c228 | ||
|   | 006ad109cb | ||
|   | 0db080154c | ||
|   | 200311033f | ||
|   | 3192dc81ac | ||
|   | b11d4bb209 | ||
|   | 2a716244e9 | ||
|   | 19b7ed538a | ||
|   | b0d9dc0b88 | ||
|   | e6094a59fa | ||
|   | e8d7e6a562 | ||
|   | 536c2d9b2d | ||
|   | f15a278f3b | ||
|   | 26b73c2ff3 | ||
|   | c1e08fc3c7 | ||
|   | b9ec6f236d | ||
|   | b1fff97bff | ||
|   | c81bc70475 | ||
|   | 55a7ee4acf | 
| @@ -11,8 +11,5 @@ insert_final_newline = true | |||||||
| [*.md] | [*.md] | ||||||
| trim_trailing_whitespace = false | trim_trailing_whitespace = false | ||||||
|  |  | ||||||
| [*.sexp] | [*.properties] | ||||||
| indent_size = 2 | insert_final_newline = false | ||||||
|  |  | ||||||
| [*.yml] |  | ||||||
| indent_size = 2 |  | ||||||
|   | |||||||
							
								
								
									
										15
									
								
								.gitattributes
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										15
									
								
								.gitattributes
									
									
									
									
										vendored
									
									
								
							| @@ -1,15 +0,0 @@ | |||||||
| # Ignore changes in generated files |  | ||||||
| src/generated/resources/data/** linguist-generated |  | ||||||
| src/test/server-files/structures linguist-generated |  | ||||||
|  |  | ||||||
| * text=auto |  | ||||||
|  |  | ||||||
| *.gradle eol=lf diff=java |  | ||||||
| *.java   eol=lf diff=java |  | ||||||
| *.kt     eol=lf diff=java |  | ||||||
| *.lua    eol=lf |  | ||||||
| *.md     eol=lf diff=markdown |  | ||||||
| *.txt    eol=lf |  | ||||||
|  |  | ||||||
| *.png binary |  | ||||||
| *.jar binary |  | ||||||
							
								
								
									
										15
									
								
								.github/ISSUE_TEMPLATE/bug_report.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								.github/ISSUE_TEMPLATE/bug_report.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,15 @@ | |||||||
|  | --- | ||||||
|  | name: Bug report | ||||||
|  | about: Report some misbehaviour in the mod | ||||||
|  | labels: bug | ||||||
|  | --- | ||||||
|  |  | ||||||
|  | <!-- | ||||||
|  | ## Before reporting | ||||||
|  |  - Search for the bug on the issue tracker. Make sure to look at closed issues too! | ||||||
|  | --> | ||||||
|  |  | ||||||
|  | ## Useful information to include: | ||||||
|  |  - Minecraft version | ||||||
|  |  - CC: Tweaked version | ||||||
|  |  - Detailed reproduction steps: sometimes I can spot a bug pretty easily, but often it's much more obscure. The more information I have to help reproduce it, the quicker it'll get fixed. | ||||||
							
								
								
									
										33
									
								
								.github/ISSUE_TEMPLATE/bug_report.yaml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										33
									
								
								.github/ISSUE_TEMPLATE/bug_report.yaml
									
									
									
									
										vendored
									
									
								
							| @@ -1,33 +0,0 @@ | |||||||
| name: Bug report |  | ||||||
| description: Report some misbehaviour in the mod |  | ||||||
| labels: [ bug ] |  | ||||||
| body: |  | ||||||
| - type: dropdown |  | ||||||
|   id: mc-version |  | ||||||
|   attributes: |  | ||||||
|     label: Minecraft Version |  | ||||||
|     description: What version of Minecraft are you using? |  | ||||||
|     options: |  | ||||||
|       - 1.15.x |  | ||||||
|       - 1.16.x |  | ||||||
|   validations: |  | ||||||
|     required: true |  | ||||||
| - type: input |  | ||||||
|   id: version |  | ||||||
|   attributes: |  | ||||||
|     label: Version |  | ||||||
|     description: "What version of CC: Tweaked are you using?" |  | ||||||
|     placeholder: "e.g. 1.96.0" |  | ||||||
|   validations: |  | ||||||
|     required: true |  | ||||||
| - type: textarea |  | ||||||
|   id: details |  | ||||||
|   attributes: |  | ||||||
|     label: Details |  | ||||||
|     description: | |  | ||||||
|       Description of the bug. Please include the following: |  | ||||||
|       - Logs: These will be located in the `logs/` directory of your Minecraft |  | ||||||
|         instance. Please upload them as a gist or directly into this editor. |  | ||||||
|       - Detailed reproduction steps: sometimes I can spot a bug pretty easily, |  | ||||||
|         but often it's much more obscure. The more information I have to help |  | ||||||
|         reproduce it, the quicker it'll get fixed. |  | ||||||
							
								
								
									
										8
									
								
								.github/ISSUE_TEMPLATE/config.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								.github/ISSUE_TEMPLATE/config.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,8 +0,0 @@ | |||||||
| blank_issues_enabled: false |  | ||||||
| contact_links: |  | ||||||
| - name: ComputerCraft Discord |  | ||||||
|   url: https://discord.computercraft.cc |  | ||||||
|   about: Get help on the ComputerCraft Discord. |  | ||||||
| - name: GitHub Discussions |  | ||||||
|   url: https://github.com/SquidDev-CC/CC-Tweaked/discussions |  | ||||||
|   about: Or ask questions on GitHub Discussions. |  | ||||||
							
								
								
									
										4
									
								
								.github/ISSUE_TEMPLATE/something_else.md
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.github/ISSUE_TEMPLATE/something_else.md
									
									
									
									
										vendored
									
									
								
							| @@ -1,4 +0,0 @@ | |||||||
| --- |  | ||||||
| name: Something else |  | ||||||
| about: An issue about something else. |  | ||||||
| --- |  | ||||||
							
								
								
									
										17
									
								
								.github/matchers/checkstyle.json
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										17
									
								
								.github/matchers/checkstyle.json
									
									
									
									
										vendored
									
									
								
							| @@ -1,17 +0,0 @@ | |||||||
| { |  | ||||||
|     "problemMatcher": [ |  | ||||||
|         { |  | ||||||
|             "owner": "checkstyle", |  | ||||||
|             "pattern": [ |  | ||||||
|                 { |  | ||||||
|                     "regexp": "^([a-z]+) ([\\w./-]+):(\\d+):(\\d+): (.*)$", |  | ||||||
|                     "severity": 1, |  | ||||||
|                     "file": 2, |  | ||||||
|                     "line": 3, |  | ||||||
|                     "column": 4, |  | ||||||
|                     "message": 5 |  | ||||||
|                 } |  | ||||||
|             ] |  | ||||||
|         } |  | ||||||
|     ] |  | ||||||
| } |  | ||||||
							
								
								
									
										18
									
								
								.github/matchers/illuaminate.json
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										18
									
								
								.github/matchers/illuaminate.json
									
									
									
									
										vendored
									
									
								
							| @@ -1,18 +0,0 @@ | |||||||
| { |  | ||||||
|     "problemMatcher": [ |  | ||||||
|         { |  | ||||||
|             "owner": "illuaminate", |  | ||||||
|             "severity": "warning", |  | ||||||
|             "pattern": [ |  | ||||||
|                 { |  | ||||||
|                     "regexp": "^([\\w./-]+):\\[(\\d+):(\\d+)\\-(?:\\d+):(?:\\d+)\\]: (.*) \\[([a-z:-]+)\\]$", |  | ||||||
|                     "file": 1, |  | ||||||
|                     "line": 2, |  | ||||||
|                     "column": 3, |  | ||||||
|                     "message": 4, |  | ||||||
|                     "code": 5 |  | ||||||
|                 } |  | ||||||
|             ] |  | ||||||
|         } |  | ||||||
|     ] |  | ||||||
| } |  | ||||||
							
								
								
									
										15
									
								
								.github/matchers/junit.json
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										15
									
								
								.github/matchers/junit.json
									
									
									
									
										vendored
									
									
								
							| @@ -1,15 +0,0 @@ | |||||||
| { |  | ||||||
|     "problemMatcher": [ |  | ||||||
|         { |  | ||||||
|             "owner": "junit", |  | ||||||
|             "pattern": [ |  | ||||||
|                 { |  | ||||||
|                     "regexp": "^## ([\\w./-]+):(\\d+): (.*)$", |  | ||||||
|                     "file": 1, |  | ||||||
|                     "line": 2, |  | ||||||
|                     "message": 3 |  | ||||||
|                 } |  | ||||||
|             ] |  | ||||||
|         } |  | ||||||
|     ] |  | ||||||
| } |  | ||||||
							
								
								
									
										61
									
								
								.github/workflows/main-ci.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										61
									
								
								.github/workflows/main-ci.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,61 +0,0 @@ | |||||||
| name: Build |  | ||||||
|  |  | ||||||
| on: [push, pull_request] |  | ||||||
|  |  | ||||||
| jobs: |  | ||||||
|   build: |  | ||||||
|     name: Build |  | ||||||
|     runs-on: ubuntu-latest |  | ||||||
|  |  | ||||||
|     steps: |  | ||||||
|     - uses: actions/checkout@v2 |  | ||||||
|  |  | ||||||
|     - name: Set up Java 8 |  | ||||||
|       uses: actions/setup-java@v1 |  | ||||||
|       with: |  | ||||||
|         java-version: 8 |  | ||||||
|  |  | ||||||
|     - name: Cache gradle dependencies |  | ||||||
|       uses: actions/cache@v2 |  | ||||||
|       with: |  | ||||||
|         path: ~/.gradle/caches |  | ||||||
|         key: ${{ runner.os }}-gradle-${{ hashFiles('gradle.properties') }} |  | ||||||
|         restore-keys: | |  | ||||||
|           ${{ runner.os }}-gradle- |  | ||||||
|  |  | ||||||
|     - name: Disable Gradle daemon |  | ||||||
|       run: | |  | ||||||
|         mkdir -p ~/.gradle |  | ||||||
|         echo "org.gradle.daemon=false" >> ~/.gradle/gradle.properties |  | ||||||
|  |  | ||||||
|     - name: Build with Gradle |  | ||||||
|       run: | |  | ||||||
|         ./gradlew assemble || ./gradlew assemble |  | ||||||
|         ./gradlew downloadAssets || ./gradlew downloadAssets |  | ||||||
|         ./gradlew build |  | ||||||
|  |  | ||||||
|     - name: Upload Jar |  | ||||||
|       uses: actions/upload-artifact@v2 |  | ||||||
|       with: |  | ||||||
|         name: CC-Tweaked |  | ||||||
|         path: build/libs |  | ||||||
|  |  | ||||||
|     - name: Upload Coverage |  | ||||||
|       uses: codecov/codecov-action@v1 |  | ||||||
|  |  | ||||||
|     - name: Parse test reports |  | ||||||
|       run: ./tools/parse-reports.py |  | ||||||
|       if: ${{ failure() }} |  | ||||||
|  |  | ||||||
|     - name: Cache pre-commit |  | ||||||
|       uses: actions/cache@v2 |  | ||||||
|       with: |  | ||||||
|         path: ~/.cache/pre-commit |  | ||||||
|         key: ${{ runner.os }}-pre-commit-${{ hashFiles('config/pre-commit/config.yml') }} |  | ||||||
|         restore-keys: | |  | ||||||
|           ${{ runner.os }}-pre-commit- |  | ||||||
|  |  | ||||||
|     - name: Run linters |  | ||||||
|       run: | |  | ||||||
|         pip install pre-commit |  | ||||||
|         pre-commit run --config config/pre-commit/config.yml --show-diff-on-failure --all --color=always |  | ||||||
							
								
								
									
										19
									
								
								.github/workflows/make-doc.sh
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										19
									
								
								.github/workflows/make-doc.sh
									
									
									
									
										vendored
									
									
								
							| @@ -1,19 +0,0 @@ | |||||||
| #!/usr/bin/env bash |  | ||||||
|  |  | ||||||
| set -eu |  | ||||||
|  |  | ||||||
| DEST="${GITHUB_REF#refs/*/}" |  | ||||||
| echo "Uploading docs to https://tweaked.cc/$DEST" |  | ||||||
|  |  | ||||||
| # Setup ssh key |  | ||||||
| mkdir -p "$HOME/.ssh/" |  | ||||||
| echo "$SSH_KEY" > "$HOME/.ssh/key" |  | ||||||
| chmod 600 "$HOME/.ssh/key" |  | ||||||
|  |  | ||||||
| # And upload |  | ||||||
| rsync -avc -e "ssh -i $HOME/.ssh/key -o StrictHostKeyChecking=no -p $SSH_PORT" \ |  | ||||||
|       "$GITHUB_WORKSPACE/build/docs/lua/" \ |  | ||||||
|       "$SSH_USER@$SSH_HOST:/var/www/tweaked.cc/$DEST" |  | ||||||
| rsync -avc -e "ssh -i $HOME/.ssh/key -o StrictHostKeyChecking=no -p $SSH_PORT" \ |  | ||||||
|       "$GITHUB_WORKSPACE/build/docs/javadoc/" \ |  | ||||||
|       "$SSH_USER@$SSH_HOST:/var/www/tweaked.cc/$DEST/javadoc" |  | ||||||
							
								
								
									
										50
									
								
								.github/workflows/make-doc.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										50
									
								
								.github/workflows/make-doc.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,50 +0,0 @@ | |||||||
| name: Build documentation |  | ||||||
|  |  | ||||||
| on: |  | ||||||
|   push: |  | ||||||
|     branches: |  | ||||||
|     - mc-1.16.x |  | ||||||
|  |  | ||||||
| jobs: |  | ||||||
|   make_doc: |  | ||||||
|     name: Build |  | ||||||
|     runs-on: ubuntu-latest |  | ||||||
|  |  | ||||||
|     steps: |  | ||||||
|     - uses: actions/checkout@v2 |  | ||||||
|  |  | ||||||
|     - name: Set up Java 8 |  | ||||||
|       uses: actions/setup-java@v1 |  | ||||||
|       with: |  | ||||||
|         java-version: 8 |  | ||||||
|  |  | ||||||
|     - name: Cache gradle dependencies |  | ||||||
|       uses: actions/cache@v2 |  | ||||||
|       with: |  | ||||||
|         path: ~/.gradle/caches |  | ||||||
|         key: ${{ runner.os }}-gradle-${{ hashFiles('gradle.properties') }} |  | ||||||
|         restore-keys: | |  | ||||||
|           ${{ runner.os }}-gradle- |  | ||||||
|  |  | ||||||
|     - name: Setup illuaminate |  | ||||||
|       run: | |  | ||||||
|         test -d bin || mkdir bin |  | ||||||
|         test -f bin/illuaminate || wget -q -Obin/illuaminate https://squiddev.cc/illuaminate/linux-x86-64/illuaminate |  | ||||||
|         chmod +x bin/illuaminate |  | ||||||
|  |  | ||||||
|     - name: Setup node |  | ||||||
|       run: npm ci |  | ||||||
|  |  | ||||||
|     - name: Build with Gradle |  | ||||||
|       run: ./gradlew compileJava --no-daemon || ./gradlew compileJava --no-daemon |  | ||||||
|  |  | ||||||
|     - name: Generate documentation |  | ||||||
|       run: ./gradlew docWebsite javadoc --no-daemon |  | ||||||
|  |  | ||||||
|     - name: Upload documentation |  | ||||||
|       run: .github/workflows/make-doc.sh 2> /dev/null |  | ||||||
|       env: |  | ||||||
|         SSH_KEY:  ${{ secrets.SSH_KEY  }} |  | ||||||
|         SSH_USER: ${{ secrets.SSH_USER }} |  | ||||||
|         SSH_HOST: ${{ secrets.SSH_HOST }} |  | ||||||
|         SSH_PORT: ${{ secrets.SSH_PORT }} |  | ||||||
							
								
								
									
										12
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										12
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -3,8 +3,6 @@ | |||||||
| /logs | /logs | ||||||
| /build | /build | ||||||
| /out | /out | ||||||
| /doc/out/ |  | ||||||
| /node_modules |  | ||||||
|  |  | ||||||
| # Runtime directories | # Runtime directories | ||||||
| /run | /run | ||||||
| @@ -17,13 +15,3 @@ | |||||||
| .idea | .idea | ||||||
| .gradle | .gradle | ||||||
| *.DS_Store | *.DS_Store | ||||||
|  |  | ||||||
| /.classpath |  | ||||||
| /.project |  | ||||||
| /.settings |  | ||||||
| /.vscode |  | ||||||
| bin/ |  | ||||||
| *.launch |  | ||||||
|  |  | ||||||
| /src/generated/resources/.cache |  | ||||||
| /src/web/mount/*.d.ts |  | ||||||
|   | |||||||
							
								
								
									
										22
									
								
								.gitpod.yml
									
									
									
									
									
								
							
							
						
						
									
										22
									
								
								.gitpod.yml
									
									
									
									
									
								
							| @@ -1,22 +0,0 @@ | |||||||
| image: |  | ||||||
|   file: config/gitpod/Dockerfile |  | ||||||
|  |  | ||||||
| ports: |  | ||||||
|   - port: 25565 |  | ||||||
|     onOpen: notify |  | ||||||
|  |  | ||||||
| vscode: |  | ||||||
|   extensions: |  | ||||||
|     - eamodio.gitlens |  | ||||||
|     - github.vscode-pull-request-github |  | ||||||
|     - ms-azuretools.vscode-docker |  | ||||||
|     - redhat.java |  | ||||||
|     - richardwillis.vscode-gradle |  | ||||||
|     - vscjava.vscode-java-debug |  | ||||||
|     - vscode.github |  | ||||||
|  |  | ||||||
| tasks: |  | ||||||
|   - name: Setup pre-commit hool |  | ||||||
|     init: pre-commit install --config config/pre-commit/config.yml --allow-missing-config |  | ||||||
|   - name: Install npm packages |  | ||||||
|     init: npm ci |  | ||||||
							
								
								
									
										34
									
								
								.luacheckrc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										34
									
								
								.luacheckrc
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,34 @@ | |||||||
|  | std = "max" | ||||||
|  |  | ||||||
|  | ignore = { | ||||||
|  |     -- Allow access to undefined globals or their fields. In the future we'll | ||||||
|  |     -- define all of CC's globals within this file | ||||||
|  |     '113', '143', | ||||||
|  |  | ||||||
|  |     -- FIXME: Ignore unused arguments and loop variables | ||||||
|  |     '212', '213', | ||||||
|  |  | ||||||
|  |     -- Disable line is too long for now. It would be possible to clean | ||||||
|  |     -- this up in the future. | ||||||
|  |     '631', | ||||||
|  | } | ||||||
|  |  | ||||||
|  | -- Only run the linter on ROM and bios for now, as the treasure disks | ||||||
|  | -- are largely unsupported. | ||||||
|  | include_files = { | ||||||
|  |     'src/main/resources/assets/computercraft/lua/rom', | ||||||
|  |     'src/main/resources/assets/computercraft/lua/bios.lua' | ||||||
|  | } | ||||||
|  |  | ||||||
|  | files['src/main/resources/assets/computercraft/lua/bios.lua'] = { | ||||||
|  |     -- Allow declaring and mutating globals | ||||||
|  |     allow_defined_top = true, | ||||||
|  |     ignore = { '112', '121', '122', '131', '142' }, | ||||||
|  | } | ||||||
|  |  | ||||||
|  | files['src/main/resources/assets/computercraft/lua/rom/apis'] = { | ||||||
|  |     -- APIs may define globals on the top level. We'll ignore unused globals, | ||||||
|  |     -- as obviously they may be used outside that API. | ||||||
|  |     allow_defined_top = true, | ||||||
|  |     ignore = { '131' }, | ||||||
|  | } | ||||||
							
								
								
									
										14
									
								
								.travis.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								.travis.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,14 @@ | |||||||
|  | language: java | ||||||
|  |  | ||||||
|  | script: ./gradlew build --no-daemon | ||||||
|  |  | ||||||
|  | before_cache: | ||||||
|  |   - rm -f  $HOME/.gradle/caches/modules-2/modules-2.lock | ||||||
|  |   - rm -fr $HOME/.gradle/caches/*/plugin-resolution/ | ||||||
|  | cache: | ||||||
|  |   directories: | ||||||
|  |     - $HOME/.gradle/caches/ | ||||||
|  |     - $HOME/.gradle/wrapper/s | ||||||
|  |  | ||||||
|  | jdk: | ||||||
|  |     - oraclejdk8 | ||||||
							
								
								
									
										114
									
								
								CONTRIBUTING.md
									
									
									
									
									
								
							
							
						
						
									
										114
									
								
								CONTRIBUTING.md
									
									
									
									
									
								
							| @@ -1,114 +0,0 @@ | |||||||
| # Contributing to CC: Tweaked |  | ||||||
| As with many open source projects, CC: Tweaked thrives on contributions from other people! This document (hopefully) |  | ||||||
| provides an introduction as to how to get started in helping out. |  | ||||||
|  |  | ||||||
| If you've any other questions, [just ask the community][community] or [open an issue][new-issue]. |  | ||||||
|  |  | ||||||
| ## Reporting issues |  | ||||||
| If you have a bug, suggestion, or other feedback, the best thing to do is [file an issue][new-issue]. When doing so, |  | ||||||
| do use the issue templates - they provide a useful hint on what information to provide. |  | ||||||
|  |  | ||||||
| ## Translations |  | ||||||
| Translations are managed through [Weblate], an online interface for managing language strings. This is synced |  | ||||||
| automatically with GitHub, so please don't submit PRs adding/changing translations! |  | ||||||
|  |  | ||||||
| ## Developing |  | ||||||
| In order to develop CC: Tweaked, you'll need to download the source code and then run it. This is a pretty simple |  | ||||||
| process. When building on Windows, Use `gradlew.bat` instead of `./gradlew`. |  | ||||||
|  |  | ||||||
|  - **Clone the repository:** `git clone https://github.com/SquidDev-CC/CC-Tweaked.git && cd CC-Tweaked` |  | ||||||
|  - **Setup Forge:** `./gradlew build` |  | ||||||
|  - **Run Minecraft:** `./gradlew runClient` (or run the `GradleStart` class from your IDE). |  | ||||||
|  - **Optionally:** For small PRs (especially those only touching Lua code), it may be easier to use GitPod, which |  | ||||||
|    provides a pre-configured environment: [](https://gitpod.io/#https://github.com/SquidDev-CC/CC-Tweaked/) |  | ||||||
|  |  | ||||||
|    Do note you will need to download the mod after compiling to test. |  | ||||||
|  |  | ||||||
| If you want to run CC:T in a normal Minecraft instance, run `./gradlew build` and copy the `.jar` from `build/libs`. |  | ||||||
| These commands may take a few minutes to run the first time, as the environment is set up, but should be much faster |  | ||||||
| afterwards. |  | ||||||
|  |  | ||||||
| The following sections describe the more niche sections of CC: Tweaked's build system. Some bits of these are |  | ||||||
| quite-complex, and (dare I say) over-engineered, so you may wish to ignore them. Well tested/documented PRs are always |  | ||||||
| preferred (and I'd definitely recommend setting up the tooling if you're doing serious development work), but for |  | ||||||
| small changes it can be a lot. |  | ||||||
|  |  | ||||||
| ### Code linters |  | ||||||
| CC: Tweaked uses a couple of "linters" on its source code, to enforce a consistent style across the project. While these |  | ||||||
| are run whenever you submit a PR, it's often useful to run this before committing. |  | ||||||
|  |  | ||||||
|  - **[Checkstyle]:** Checks Java code to ensure it is consistently formatted. This can be run with `./gradlew build` or |  | ||||||
|    `./gradle check`. |  | ||||||
|  - **[illuaminate]:** Checks Lua code for semantic and styleistic issues. See [the usage section][illuaminate-usage] for |  | ||||||
|    how to download and run it. You may need to generate the Java documentation stubs (see "Documentation" below) for all |  | ||||||
|    lints to pass. |  | ||||||
|  |  | ||||||
| ### Documentation |  | ||||||
| When writing documentation for [CC: Tweaked's documentation website][docs], it may be useful to build the documentation |  | ||||||
| and preview it yourself before submitting a PR. |  | ||||||
|  |  | ||||||
| Building all documentation is, sadly, a multi-stage process (though this is largely hidden by Gradle). First we need to |  | ||||||
| convert Java doc-comments into Lua ones, we also generate some Javascript to embed. All of this is then finally fed into |  | ||||||
| illuaminate, which spits out our HTML. |  | ||||||
|  |  | ||||||
| #### Setting up the tooling |  | ||||||
| For various reasons, getting the environment set up to build documentation can be pretty complex. I'd quite like to |  | ||||||
| automate this via Docker and/or nix in the future, but this needs to be done manually for now. |  | ||||||
|  |  | ||||||
| This tooling is only needed if you need to build the whole website. If you just want to generate the Lua stubs, you can |  | ||||||
| skp this section. |  | ||||||
|  - Install Node/npm and install our Node packages with `npm ci`. |  | ||||||
|  - Install [illuaminate][illuaminate-usage] as described above. |  | ||||||
|  |  | ||||||
| #### Building documentation |  | ||||||
| Gradle should be your entrypoint to building most documentation. There's two tasks which are of interest: |  | ||||||
|  |  | ||||||
|  - `./gradlew luaJavadoc` - Generate documentation stubs for Java methods. |  | ||||||
|  - `./gradlew docWebsite` - Generate the whole website (including Javascript pages). The resulting HTML is stored at |  | ||||||
|    `./build/docs/lua/`. |  | ||||||
|  |  | ||||||
| #### Writing documentation |  | ||||||
| illuaminate's documentation system is not currently documented (somewhat ironic), but is _largely_ the same as |  | ||||||
| [ldoc][ldoc]. Documentation comments are written in Markdown, |  | ||||||
|  |  | ||||||
| Our markdown engine does _not_ support GitHub flavoured markdown, and so does not support all the features one might |  | ||||||
| expect (such as tables). It is very much recommended that you build and preview the docs locally first. |  | ||||||
|  |  | ||||||
| ### Testing |  | ||||||
| Thankfully running tests is much simpler than running the documentation generator! `./gradlew check` will run the |  | ||||||
| entire test suite (and some additional bits of verification). |  | ||||||
|  |  | ||||||
| Before we get into writing tests, it's worth mentioning the various test suites that CC: Tweaked has: |  | ||||||
|  - "Core" Java (`./src/test/java`): These test core bits of the mod which don't require any Minecraft interaction. |  | ||||||
|    This includes the `@LuaFunction` system, file system code, etc... |  | ||||||
|  |  | ||||||
|    These tests are run by `./gradlew test`. |  | ||||||
|  |  | ||||||
|  - CraftOS (`./src/test/resources/test-rom/`): These tests are written in Lua, and ensure the Lua environment, libraries |  | ||||||
|    and programs work as expected. These are (generally) written to be able to be run on emulators too, to provide some |  | ||||||
|    sort of compliance test. |  | ||||||
|  |  | ||||||
|    These tests are run by the '"Core" Java' test suite, and so are also run with `./gradlew test`. |  | ||||||
|  |  | ||||||
|  - In-game (`./src/test/java/dan200/computercraft/ingame/`): These tests are run on an actual Minecraft server, using |  | ||||||
|    [the same system Mojang do][mc-test]. The aim of these is to test in-game behaviour of blocks and peripherals. |  | ||||||
|  |  | ||||||
|    These are run by `./gradlew testInGame`. |  | ||||||
|  |  | ||||||
| ## CraftOS tests |  | ||||||
| CraftOS's tests are written using a test system called "mcfly", heavily inspired by [busted] (and thus RSpec). Groups of |  | ||||||
| tests go inside `describe` blocks, and a single test goes inside `it`. |  | ||||||
|  |  | ||||||
| Assertions are generally written using `expect` (inspired by Hamcrest and the like). For instance, `expect(foo):eq("bar")` |  | ||||||
| asserts that your variable `foo` is equal to the expected value `"bar"`. |  | ||||||
|  |  | ||||||
| [new-issue]: https://github.com/SquidDev-CC/CC-Tweaked/issues/new/choose "Create a new issue" |  | ||||||
| [community]: README.md#Community "Get in touch with the community." |  | ||||||
| [checkstyle]: https://checkstyle.org/ |  | ||||||
| [illuaminate]: https://github.com/SquidDev/illuaminate/ "Illuaminate on GitHub" |  | ||||||
| [illuaminate-usage]: https://github.com/SquidDev/illuaminate/blob/master/README.md#usage "Installing Illuaminate" |  | ||||||
| [weblate]: https://i18n.tweaked.cc/projects/cc-tweaked/minecraft/ "CC: Tweaked weblate instance" |  | ||||||
| [docs]: https://tweaked.cc/ "CC: Tweaked documentation" |  | ||||||
| [ldoc]: http://stevedonovan.github.io/ldoc/ "ldoc, a Lua documentation generator." |  | ||||||
| [mc-test]: https://www.youtube.com/watch?v=vXaWOJTCYNg |  | ||||||
| [busted]: https://github.com/Olivine-Labs/busted "busted: Elegant Lua unit testing." |  | ||||||
							
								
								
									
										73
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										73
									
								
								README.md
									
									
									
									
									
								
							| @@ -1,72 +1,7 @@ | |||||||
| #  | # CC:T for Fabric | ||||||
| [](https://github.com/SquidDev-CC/CC-Tweaked/actions "Current build status") [](https://minecraft.curseforge.com/projects/cc-tweaked "Download CC: Tweaked on CurseForge") |  | ||||||
|  |  | ||||||
| CC: Tweaked is a fork of [ComputerCraft](https://github.com/dan200/ComputerCraft), adding programmable computers, | * [Download on CurseForge](https://www.curseforge.com/minecraft/mc-mods/cc-restitched) | ||||||
| turtles and more to Minecraft. |  | ||||||
|  |  | ||||||
| ## What? | A fork of [CC: Tweaked](https://github.com/SquidDev-CC/CC-Tweaked) for use with the latest Fabric. | ||||||
| ComputerCraft has always held a fond place in my heart: it's the mod which really got me into Minecraft, and it's the |  | ||||||
| mod which has kept me playing it for many years. However, development of the original mod has slowed, as the original |  | ||||||
| developers have had less time to work on the mod, and moved onto other projects and commitments. |  | ||||||
|  |  | ||||||
| CC: Tweaked (or CC:T for short) is an attempt to continue ComputerCraft's legacy. It's not intended to be a competitor | NOTE: This project is currently in alpha stage. It may not be well-tested and stable, so use it at your own peril! | ||||||
| to CC, nor do I want to take it in a vastly different direction to the original mod. Instead, CC:T focuses on making the |  | ||||||
| ComputerCraft experience as _solid_ as possible, ironing out any wrinkles that may have developed over time. |  | ||||||
|  |  | ||||||
| ## Features |  | ||||||
| CC: Tweaked contains all the features of the latest version of ComputerCraft, as well as numerous fixes, performance |  | ||||||
| improvements and several nifty additions. I'd recommend checking out [the releases page](https://github.com/SquidDev-CC/CC-Tweaked/releases) |  | ||||||
| to see the full set of changes, but here's a couple of the more interesting additions: |  | ||||||
|  |  | ||||||
|  - Improvements to the `http` library, including websockets, support for other HTTP methods (`PUT`, `DELETE`, etc...) |  | ||||||
|    and configurable limits on HTTP usage. |  | ||||||
|  - Full-block wired modems, allowing one to wrap non-solid peripherals (such as turtles, or chests if Plethora is |  | ||||||
|    installed). |  | ||||||
|  - Pocket computers can be held like maps, allowing you to view the screen without entering a GUI. |  | ||||||
|  - Printed pages and books can be placed in item frames and held like maps. |  | ||||||
|  - Several profiling and administration tools for server owners, via the `/computercraft` command. This allows operators |  | ||||||
|    to track which computers are hogging resources, turn on and shutdown multiple computers at once and interact with |  | ||||||
|    computers remotely. |  | ||||||
|  - Closer emulation of standard Lua, adding the `debug` and `io` libraries. This also enables seeking within binary |  | ||||||
|    files, meaning you don't need to read large files into memory. |  | ||||||
|  - Allow running multiple computers on multiple threads, reducing latency on worlds with many computers. |  | ||||||
|  |  | ||||||
| ## Relation to CCTweaks? |  | ||||||
| This mod has nothing to do with CCTweaks, though there is no denying the name is a throwback to it. That being said, |  | ||||||
| several features have been included, such as full block modems, the Cobalt runtime and map-like rendering for pocket |  | ||||||
| computers. |  | ||||||
|  |  | ||||||
| ## 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](CONTRIBUTING.md#developing). |  | ||||||
|  |  | ||||||
| ## Community |  | ||||||
| If you need help getting started with CC: Tweaked, want to show off your latest project, or just want to chat about |  | ||||||
| ComputerCraft we have a [forum](https://forums.computercraft.cc/) and [Discord guild](https://discord.computercraft.cc)! |  | ||||||
| There's also a fairly populated, albeit quiet [IRC channel](http://webchat.esper.net/?channels=computercraft), if that's |  | ||||||
| more your cup of tea. |  | ||||||
|  |  | ||||||
| I'd generally recommend you don't contact me directly (email, DM, etc...) unless absolutely necessary (i.e. in order to |  | ||||||
| report exploits). You'll get a far quicker response if you ask the whole community! |  | ||||||
|  |  | ||||||
| ## 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. |  | ||||||
|  |  | ||||||
| ```groovy |  | ||||||
| repositories { |  | ||||||
|   maven { url 'https://squiddev.cc/maven/' } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| dependencies { |  | ||||||
|   implementation fg.deobf("org.squiddev:cc-tweaked-${mc_version}:${cct_version}") |  | ||||||
| } |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| 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](https://tweaked.cc/javadoc/). |  | ||||||
|   | |||||||
							
								
								
									
										560
									
								
								build.gradle
									
									
									
									
									
								
							
							
						
						
									
										560
									
								
								build.gradle
									
									
									
									
									
								
							| @@ -1,114 +1,15 @@ | |||||||
| buildscript { |  | ||||||
|     repositories { |  | ||||||
|         mavenCentral() |  | ||||||
|         maven { |  | ||||||
|             name = "forge" |  | ||||||
|             url = "https://maven.minecraftforge.net" |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|     dependencies { |  | ||||||
|         classpath 'net.minecraftforge.gradle:ForgeGradle:5.0.24' |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| plugins { | plugins { | ||||||
|     id "checkstyle" |     id 'fabric-loom' version '0.5-SNAPSHOT' | ||||||
|     id "jacoco" |     id 'maven-publish' | ||||||
|     id "maven-publish" |  | ||||||
|     id "com.github.hierynomus.license" version "0.16.1" |  | ||||||
|     id "com.matthewprenger.cursegradle" version "1.4.0" |  | ||||||
|     id "com.github.breadmoirai.github-release" version "2.2.12" |  | ||||||
|     id "org.jetbrains.kotlin.jvm" version "1.3.72" |  | ||||||
|     id "com.modrinth.minotaur" version "1.2.1" |  | ||||||
| } | } | ||||||
|  |  | ||||||
| apply plugin: 'net.minecraftforge.gradle' | sourceCompatibility = JavaVersion.VERSION_1_8 | ||||||
|  | targetCompatibility = JavaVersion.VERSION_1_8 | ||||||
|  |  | ||||||
| version = mod_version | version = mod_version | ||||||
|  |  | ||||||
| group = "org.squiddev" | group = "dan200.computercraft" | ||||||
| archivesBaseName = "cc-tweaked-${mc_version}" | archivesBaseName = "cc-tweaked-fabric-${mc_version}" | ||||||
|  |  | ||||||
| def javaVersion = JavaLanguageVersion.of(8) |  | ||||||
| java { |  | ||||||
|     toolchain { |  | ||||||
|         languageVersion = javaVersion |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     withSourcesJar() |  | ||||||
|     withJavadocJar() |  | ||||||
| } |  | ||||||
|  |  | ||||||
| tasks.withType(JavaExec).configureEach { |  | ||||||
|     javaLauncher = javaToolchains.launcherFor { |  | ||||||
|         languageVersion = javaVersion |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| minecraft { |  | ||||||
|     runs { |  | ||||||
|         client { |  | ||||||
|             workingDirectory project.file('run') |  | ||||||
|             property 'forge.logging.markers', 'REGISTRIES' |  | ||||||
|             property 'forge.logging.console.level', 'debug' |  | ||||||
|  |  | ||||||
|             mods { |  | ||||||
|                 computercraft { |  | ||||||
|                     source sourceSets.main |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         server { |  | ||||||
|             workingDirectory project.file("run/server") |  | ||||||
|             property 'forge.logging.markers', 'REGISTRIES' |  | ||||||
|             property 'forge.logging.console.level', 'debug' |  | ||||||
|             arg "--nogui" |  | ||||||
|  |  | ||||||
|             mods { |  | ||||||
|                 computercraft { |  | ||||||
|                     source sourceSets.main |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         data { |  | ||||||
|             workingDirectory project.file('run') |  | ||||||
|             property 'forge.logging.markers', 'REGISTRIES' |  | ||||||
|             property 'forge.logging.console.level', 'debug' |  | ||||||
|  |  | ||||||
|             args '--mod', 'computercraft', '--all', '--output', file('src/generated/resources/'), '--existing', file('src/main/resources/') |  | ||||||
|             mods { |  | ||||||
|                 computercraft { |  | ||||||
|                     source sourceSets.main |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         testServer { |  | ||||||
|             workingDirectory project.file('test-files/server') |  | ||||||
|             parent runs.server |  | ||||||
|             arg "--nogui" |  | ||||||
|  |  | ||||||
|             mods { |  | ||||||
|                 cctest { |  | ||||||
|                     source sourceSets.test |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     mappings channel: 'official', version: mc_version |  | ||||||
|  |  | ||||||
|     accessTransformer file('src/main/resources/META-INF/accesstransformer.cfg') |  | ||||||
|     accessTransformer file('src/test/resources/META-INF/accesstransformer.cfg') |  | ||||||
| } |  | ||||||
|  |  | ||||||
| sourceSets { |  | ||||||
|     main.resources { |  | ||||||
|         srcDir 'src/generated/resources' |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| repositories { | repositories { | ||||||
|     mavenCentral() |     mavenCentral() | ||||||
| @@ -119,437 +20,98 @@ repositories { | |||||||
| } | } | ||||||
|  |  | ||||||
| configurations { | configurations { | ||||||
|     shade |  | ||||||
|     compile.extendsFrom shade |     compile.extendsFrom shade | ||||||
|     cctJavadoc |  | ||||||
| } | } | ||||||
|  |  | ||||||
| dependencies { | dependencies { | ||||||
|     checkstyle "com.puppycrawl.tools:checkstyle:8.25" |     minecraft "com.mojang:minecraft:${mc_version}" | ||||||
|  |     mappings "net.fabricmc:yarn:${mc_version}+build.${mappings_version}:v2" | ||||||
|  |     modImplementation "net.fabricmc:fabric-loader:${fabric_loader_version}" | ||||||
|  |     modImplementation "net.fabricmc.fabric-api:fabric-api:${fabric_api_version}" | ||||||
|  |  | ||||||
|     minecraft "net.minecraftforge:forge:${mc_version}-${forge_version}" |     modImplementation "me.shedaniel.cloth:config-2:${cloth_config_version}" | ||||||
|  |     modImplementation "io.github.prospector:modmenu:${modmenu_version}" | ||||||
|  |  | ||||||
|     compileOnly fg.deobf("mezz.jei:jei-1.16.5:7.7.0.104:api") |     modApi "me.shedaniel.cloth.api:cloth-utils-v1:${project.cloth_api_version}" | ||||||
|     compileOnly fg.deobf("com.blamejared.crafttweaker:CraftTweaker-1.16.5:7.1.0.313") |     include "me.shedaniel.cloth.api:cloth-utils-v1:${project.cloth_api_version}" | ||||||
|     compileOnly fg.deobf("commoble.morered:morered-1.16.5:2.1.1.0") |  | ||||||
|  |  | ||||||
|     runtimeOnly fg.deobf("mezz.jei:jei-1.16.5:7.7.0.104") |     implementation "blue.endless:jankson:${jankson_version}" | ||||||
|  |     implementation 'com.google.code.findbugs:jsr305:3.0.2' | ||||||
|  |  | ||||||
|     shade 'org.squiddev:Cobalt:0.5.2-SNAPSHOT' |     include "me.shedaniel.cloth:config-2:${cloth_config_version}" | ||||||
|  |     include "blue.endless:jankson:${jankson_version}" | ||||||
|  |     include 'javax.vecmath:vecmath:1.5.2' | ||||||
|  |  | ||||||
|     testImplementation 'org.junit.jupiter:junit-jupiter-api:5.7.0' |     compile 'javax.vecmath:vecmath:1.5.2' | ||||||
|     testImplementation 'org.junit.jupiter:junit-jupiter-params:5.7.0' |  | ||||||
|     testRuntimeOnly 'org.junit.jupiter:junit-jupiter-engine:5.7.0' |  | ||||||
|     testImplementation 'org.hamcrest:hamcrest:2.2' |  | ||||||
|     testImplementation 'org.jetbrains.kotlin:kotlin-stdlib-jdk8:1.3.72' |  | ||||||
|     testImplementation 'org.jetbrains.kotlin:kotlin-reflect:1.3.72' |  | ||||||
|     testImplementation 'org.jetbrains.kotlinx:kotlinx-coroutines-core:1.3.8' |  | ||||||
|  |  | ||||||
|     cctJavadoc 'cc.tweaked:cct-javadoc:1.4.1' |     shade 'org.squiddev:Cobalt:0.5.1-SNAPSHOT' | ||||||
|  |  | ||||||
|  |     testImplementation 'org.junit.jupiter:junit-jupiter-api:5.1.0' | ||||||
|  |     testRuntimeOnly 'org.junit.jupiter:junit-jupiter-engine:5.1.0' | ||||||
|  |  | ||||||
|  |     modRuntime "me.shedaniel:RoughlyEnoughItems-api:5.2.10" | ||||||
|  |     modRuntime "me.shedaniel:RoughlyEnoughItems:5.2.10" | ||||||
| } | } | ||||||
|  |  | ||||||
| // Compile tasks | sourceSets { | ||||||
|  |     main { | ||||||
| javadoc { |         java { | ||||||
|     include "dan200/computercraft/api/**/*.java" |             exclude 'dan200/computercraft/shared/integration' | ||||||
| } |         } | ||||||
|  |  | ||||||
| task luaJavadoc(type: Javadoc) { |  | ||||||
|     description "Generates documentation for Java-side Lua functions." |  | ||||||
|     group "documentation" |  | ||||||
|  |  | ||||||
|     source = sourceSets.main.allJava |  | ||||||
|     destinationDir = file("${project.docsDir}/luaJavadoc") |  | ||||||
|     classpath = sourceSets.main.compileClasspath |  | ||||||
|  |  | ||||||
|     options.docletpath = configurations.cctJavadoc.files as List |  | ||||||
|     options.doclet = "cc.tweaked.javadoc.LuaDoclet" |  | ||||||
|     options.noTimestamp = false |  | ||||||
|  |  | ||||||
|     javadocTool = javaToolchains.javadocToolFor { |  | ||||||
|         languageVersion = JavaLanguageVersion.of(11) |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| jar { |  | ||||||
|     manifest { |  | ||||||
|         attributes(["Specification-Title"     : "computercraft", |  | ||||||
|                     "Specification-Vendor"    : "SquidDev", |  | ||||||
|                     "Specification-Version"   : "1", |  | ||||||
|                     "Implementation-Title"    : "CC: Tweaked", |  | ||||||
|                     "Implementation-Version"  : "${mod_version}", |  | ||||||
|                     "Implementation-Vendor"   : "SquidDev", |  | ||||||
|                     "Implementation-Timestamp": new Date().format("yyyy-MM-dd'T'HH:mm:ssZ")]) |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     from configurations.shade.collect { it.isDirectory() ? it : zipTree(it) } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| [compileJava, compileTestJava].forEach { |  | ||||||
|     it.configure { |  | ||||||
|         options.compilerArgs << "-Xlint" << "-Xlint:-processing" |  | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| processResources { | processResources { | ||||||
|     inputs.property "version", mod_version |     inputs.property "version", project.version | ||||||
|     inputs.property "mcversion", mc_version |  | ||||||
|  |  | ||||||
|     def hash = 'none' |  | ||||||
|     Set<String> contributors = [] |  | ||||||
|     try { |  | ||||||
|         hash = ["git", "-C", projectDir, "rev-parse", "HEAD"].execute().text.trim() |  | ||||||
|  |  | ||||||
|         def blacklist = ['GitHub', 'dan200', 'Daniel Ratcliffe'] |  | ||||||
|         ["git", "-C", projectDir, "log", "--format=tformat:%an%n%cn"].execute().text.split('\n').each { |  | ||||||
|             if (!blacklist.contains(it)) contributors.add(it) |  | ||||||
|         } |  | ||||||
|     } catch (Exception e) { |  | ||||||
|         e.printStackTrace() |  | ||||||
|     } |  | ||||||
|     inputs.property "commithash", hash |  | ||||||
|     duplicatesStrategy = DuplicatesStrategy.INCLUDE |  | ||||||
|  |  | ||||||
|     from(sourceSets.main.resources.srcDirs) { |     from(sourceSets.main.resources.srcDirs) { | ||||||
|         include 'META-INF/mods.toml' |         include "fabric.mod.json" | ||||||
|         include 'data/computercraft/lua/rom/help/credits.txt' |         expand "version": project.version | ||||||
|  |  | ||||||
|         expand 'version': mod_version, |  | ||||||
|                 'mcversion': mc_version, |  | ||||||
|                 'gitcontributors': contributors.sort(false, String.CASE_INSENSITIVE_ORDER).join('\n') |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     from(sourceSets.main.resources.srcDirs) { |     from(sourceSets.main.resources.srcDirs) { | ||||||
|         exclude 'META-INF/mods.toml' |         exclude "fabric.mod.json" | ||||||
|         exclude 'data/computercraft/lua/rom/help/credits.txt' |  | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| sourcesJar { | // ensure that the encoding is set to UTF-8, no matter what the system default is | ||||||
|     duplicatesStrategy = DuplicatesStrategy.INCLUDE | // this fixes some edge cases with special characters not displaying correctly | ||||||
|  | // see http://yodaconditions.net/blog/fix-for-java-file-encoding-problems-with-gradle.html | ||||||
|  | tasks.withType(JavaCompile) { | ||||||
|  |     options.encoding = "UTF-8" | ||||||
| } | } | ||||||
|  |  | ||||||
| // Web tasks | // Loom will automatically attach sourcesJar to a RemapSourcesJar task and to the "build" task | ||||||
|  | // if it is present. | ||||||
|  | // If you remove this task, sources will not be generated. | ||||||
| import com.hierynomus.gradle.license.tasks.LicenseCheck | task sourcesJar(type: Jar, dependsOn: classes) { | ||||||
| import com.hierynomus.gradle.license.tasks.LicenseFormat |     classifier = "sources" | ||||||
| import org.apache.tools.ant.taskdefs.condition.Os |     from sourceSets.main.allSource | ||||||
|  |  | ||||||
| List<String> mkCommand(String command) { |  | ||||||
|     return Os.isFamily(Os.FAMILY_WINDOWS) ? ["cmd", "/c", command] : ["sh", "-c", command] |  | ||||||
| } | } | ||||||
|  |  | ||||||
| task rollup(type: Exec) { | jar { | ||||||
|     group = "build" |     from "LICENSE" | ||||||
|     description = "Bundles JS into rollup" |  | ||||||
|  |  | ||||||
|     inputs.files(fileTree("src/web")).withPropertyName("sources") |     from configurations.shade.collect { it.isDirectory() ? it : zipTree(it) } | ||||||
|     inputs.file("package-lock.json").withPropertyName("package-lock.json") |  | ||||||
|     inputs.file("tsconfig.json").withPropertyName("Typescript config") |  | ||||||
|     inputs.file("rollup.config.js").withPropertyName("Rollup config") |  | ||||||
|     outputs.file("$buildDir/rollup/index.js").withPropertyName("output") |  | ||||||
|  |  | ||||||
|     commandLine mkCommand('"node_modules/.bin/rollup" --config rollup.config.js') |  | ||||||
| } |  | ||||||
|  |  | ||||||
| task minifyWeb(type: Exec, dependsOn: rollup) { |  | ||||||
|     group = "build" |  | ||||||
|     description = "Bundles JS into rollup" |  | ||||||
|  |  | ||||||
|     inputs.file("$buildDir/rollup/index.js").withPropertyName("sources") |  | ||||||
|     inputs.file("package-lock.json").withPropertyName("package-lock.json") |  | ||||||
|     outputs.file("$buildDir/rollup/index.min.js").withPropertyName("output") |  | ||||||
|  |  | ||||||
|     commandLine mkCommand('"node_modules/.bin/terser"' + " -o '$buildDir/rollup/index.min.js' '$buildDir/rollup/index.js'") |  | ||||||
| } |  | ||||||
|  |  | ||||||
| task illuaminateDocs(type: Exec, dependsOn: [minifyWeb, luaJavadoc]) { |  | ||||||
|     group = "build" |  | ||||||
|     description = "Bundles JS into rollup" |  | ||||||
|  |  | ||||||
|     inputs.files(fileTree("doc")).withPropertyName("docs") |  | ||||||
|     inputs.files(fileTree("src/main/resources/data/computercraft/lua/rom")).withPropertyName("lua rom") |  | ||||||
|     inputs.file("illuaminate.sexp").withPropertyName("illuaminate.sexp") |  | ||||||
|     inputs.dir("$buildDir/docs/luaJavadoc") |  | ||||||
|     inputs.file("$buildDir/rollup/index.min.js").withPropertyName("scripts") |  | ||||||
|     inputs.file("src/web/styles.css").withPropertyName("styles") |  | ||||||
|     outputs.dir("$buildDir/docs/lua") |  | ||||||
|  |  | ||||||
|     commandLine mkCommand('"bin/illuaminate" doc-gen') |  | ||||||
| } |  | ||||||
|  |  | ||||||
| task docWebsite(type: Copy, dependsOn: [illuaminateDocs]) { |  | ||||||
|     from 'doc/logo.png' |  | ||||||
|     into "${project.docsDir}/lua" |  | ||||||
| } |  | ||||||
|  |  | ||||||
| // Check tasks |  | ||||||
|  |  | ||||||
| test { |  | ||||||
|     useJUnitPlatform() |  | ||||||
|     testLogging { |  | ||||||
|         events "skipped", "failed" |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| jacocoTestReport { |  | ||||||
|     dependsOn('test') |  | ||||||
|     reports { |  | ||||||
|         xml.required = true |  | ||||||
|         html.required = true |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| check.dependsOn jacocoTestReport |  | ||||||
|  |  | ||||||
| license { |  | ||||||
|     mapping("java", "SLASHSTAR_STYLE") |  | ||||||
|     strictCheck true |  | ||||||
|  |  | ||||||
|     ext.year = Calendar.getInstance().get(Calendar.YEAR) |  | ||||||
| } |  | ||||||
|  |  | ||||||
| [licenseMain, licenseFormatMain].forEach { |  | ||||||
|     it.configure { |  | ||||||
|         include("**/*.java") |  | ||||||
|         exclude("dan200/computercraft/api/**") |  | ||||||
|         header file('config/license/main.txt') |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| [licenseTest, licenseFormatTest].forEach { |  | ||||||
|     it.configure { |  | ||||||
|         include("**/*.java") |  | ||||||
|         header file('config/license/main.txt') |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| gradle.projectsEvaluated { |  | ||||||
|     tasks.withType(LicenseFormat) { |  | ||||||
|         outputs.upToDateWhen { false } |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| task licenseAPI(type: LicenseCheck) |  | ||||||
| task licenseFormatAPI(type: LicenseFormat) |  | ||||||
| [licenseAPI, licenseFormatAPI].forEach { |  | ||||||
|     it.configure { |  | ||||||
|         source = sourceSets.main.java |  | ||||||
|         include("dan200/computercraft/api/**") |  | ||||||
|         header file('config/license/api.txt') |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| task setupServer(type: Copy) { |  | ||||||
|     group "test server" |  | ||||||
|     description "Sets up the environment for the test server." |  | ||||||
|  |  | ||||||
|     from("src/test/server-files") { |  | ||||||
|         include "eula.txt" |  | ||||||
|         include "server.properties" |  | ||||||
|     } |  | ||||||
|     into "test-files/server" |  | ||||||
| } |  | ||||||
|  |  | ||||||
| tasks.register('testInGame', JavaExec.class).configure { |  | ||||||
|     it.group('test server') |  | ||||||
|     it.description("Runs tests on a temporary Minecraft server.") |  | ||||||
|     it.dependsOn(setupServer, 'prepareRunTestServer', 'cleanTestInGame') |  | ||||||
|  |  | ||||||
|     // Copy from runTestServer. We do it in this slightly odd way as runTestServer |  | ||||||
|     // isn't created until the task is configured (which is no good for us). |  | ||||||
|     JavaExec exec = tasks.getByName('runTestServer') |  | ||||||
|     exec.copyTo(it) |  | ||||||
|     it.setClasspath(exec.getClasspath()) |  | ||||||
|     it.mainClass = exec.mainClass |  | ||||||
|     it.setArgs(exec.getArgs()) |  | ||||||
|  |  | ||||||
|     it.systemProperty('forge.logging.console.level', 'info') |  | ||||||
|     it.systemProperty('cctest.run', 'true') |  | ||||||
|  |  | ||||||
|     // Jacoco and modlauncher don't play well together as the classes loaded in-game don't |  | ||||||
|     // match up with those written to disk. We get Jacoco to dump all classes to disk, and |  | ||||||
|     // use that when generating the report. |  | ||||||
|     def coverageOut = new File(buildDir, 'jacocoClassDump/testInGame') |  | ||||||
|     jacoco.applyTo(it) |  | ||||||
|     it.jacoco.setIncludes(["dan200.computercraft.*"]) |  | ||||||
|     it.jacoco.setClassDumpDir(coverageOut) |  | ||||||
|     it.outputs.dir(coverageOut) |  | ||||||
|     // Older versions of modlauncher don't include a protection domain (and thus no code |  | ||||||
|     // source). Jacoco skips such classes by default, so we need to explicitly include them. |  | ||||||
|     it.jacoco.setIncludeNoLocationClasses(true) |  | ||||||
| } |  | ||||||
|  |  | ||||||
| tasks.register('jacocoTestInGameReport', JacocoReport.class).configure { |  | ||||||
|     it.group('test server') |  | ||||||
|     it.description('Generate coverage reports for in-game tests (testInGame)') |  | ||||||
|     it.dependsOn('testInGame') |  | ||||||
|  |  | ||||||
|     it.executionData(new File(buildDir, 'jacoco/testInGame.exec')) |  | ||||||
|     it.sourceDirectories.from(sourceSets.main.allJava.srcDirs) |  | ||||||
|     it.classDirectories.from(new File(buildDir, 'jacocoClassDump/testInGame')) |  | ||||||
|  |  | ||||||
|     it.reports { |  | ||||||
|         xml.enabled true |  | ||||||
|         html.enabled true |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| check.dependsOn('jacocoTestInGameReport') |  | ||||||
|  |  | ||||||
|  |  | ||||||
| // Upload tasks |  | ||||||
|  |  | ||||||
| task checkRelease { |  | ||||||
|     group "upload" |  | ||||||
|     description "Verifies that everything is ready for a release" |  | ||||||
|  |  | ||||||
|     inputs.property "version", mod_version |  | ||||||
|     inputs.file("src/main/resources/data/computercraft/lua/rom/help/changelog.md") |  | ||||||
|     inputs.file("src/main/resources/data/computercraft/lua/rom/help/whatsnew.md") |  | ||||||
|  |  | ||||||
|     doLast { |  | ||||||
|         def ok = true |  | ||||||
|  |  | ||||||
|         // Check we're targetting the current version |  | ||||||
|         def whatsnew = new File(projectDir, "src/main/resources/data/computercraft/lua/rom/help/whatsnew.md").readLines() |  | ||||||
|         if (whatsnew[0] != "New features in CC: Tweaked $mod_version") { |  | ||||||
|             ok = false |  | ||||||
|             project.logger.error("Expected `whatsnew.md' to target $mod_version.") |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         // Check "read more" exists and trim it |  | ||||||
|         def idx = whatsnew.findIndexOf { it == 'Type "help changelog" to see the full version history.' } |  | ||||||
|         if (idx == -1) { |  | ||||||
|             ok = false |  | ||||||
|             project.logger.error("Must mention the changelog in whatsnew.md") |  | ||||||
|         } else { |  | ||||||
|             whatsnew = whatsnew.getAt(0..<idx) |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         // Check whatsnew and changelog match. |  | ||||||
|         def versionChangelog = "# " + whatsnew.join("\n") |  | ||||||
|         def changelog = new File(projectDir, "src/main/resources/data/computercraft/lua/rom/help/changelog.md").getText() |  | ||||||
|         if (!changelog.startsWith(versionChangelog)) { |  | ||||||
|             ok = false |  | ||||||
|             project.logger.error("whatsnew and changelog are not in sync") |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         if (!ok) throw new IllegalStateException("Could not check release") |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| check.dependsOn checkRelease |  | ||||||
|  |  | ||||||
| curseforge { |  | ||||||
|     apiKey = project.hasProperty('curseForgeApiKey') ? project.curseForgeApiKey : '' |  | ||||||
|     project { |  | ||||||
|         id = '282001' |  | ||||||
|         releaseType = 'release' |  | ||||||
|         changelog = "Release notes can be found on the GitHub repository (https://github.com/SquidDev-CC/CC-Tweaked/releases/tag/v${mc_version}-${mod_version})." |  | ||||||
|  |  | ||||||
|         relations { |  | ||||||
|             incompatible "computercraft" |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         addGameVersion "${mc_version}" |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| import com.modrinth.minotaur.TaskModrinthUpload |  | ||||||
| tasks.register('publishModrinth', TaskModrinthUpload.class).configure { |  | ||||||
|     dependsOn('assemble', 'reobfJar') |  | ||||||
|     onlyIf { |  | ||||||
|         project.hasProperty('modrinthApiKey') |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     token = project.hasProperty('modrinthApiKey') ? project.getProperty('modrinthApiKey') : '' |  | ||||||
|     projectId = 'gu7yAYhd' |  | ||||||
|     versionNumber = "${project.mc_version}-${project.mod_version}" |  | ||||||
|     uploadFile = jar |  | ||||||
|     addGameVersion(project.mc_version) |  | ||||||
|     changelog = "Release notes can be found on the [GitHub repository](https://github.com/SquidDev-CC/CC-Tweaked/releases/tag/v${mc_version}-${mod_version})." |  | ||||||
|     addLoader('forge') |  | ||||||
| } |  | ||||||
|  |  | ||||||
| tasks.withType(GenerateModuleMetadata) { |  | ||||||
|     // We can't generate metadata as that includes Forge as a dependency. |  | ||||||
|     enabled = false |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  | // configure the maven publication | ||||||
| publishing { | publishing { | ||||||
|     publications { |     publications { | ||||||
|         maven(MavenPublication) { |         mavenJava(MavenPublication) { | ||||||
|             from components.java |             // add all the jars that should be included when publishing to maven | ||||||
|  |             artifact(remapJar) { | ||||||
|             pom { |                 builtBy remapJar | ||||||
|                 name = 'CC: Tweaked' |             } | ||||||
|                 description = 'CC: Tweaked is a fork of ComputerCraft, adding programmable computers, turtles and more to Minecraft.' |             artifact(sourcesJar) { | ||||||
|                 url = 'https://github.com/SquidDev-CC/CC-Tweaked' |                 builtBy remapSourcesJar | ||||||
|  |  | ||||||
|                 scm { |  | ||||||
|                     url = 'https://github.com/SquidDev-CC/CC-Tweaked.git' |  | ||||||
|                 } |  | ||||||
|  |  | ||||||
|                 issueManagement { |  | ||||||
|                     system = 'github' |  | ||||||
|                     url = 'https://github.com/SquidDev-CC/CC-Tweaked/issues' |  | ||||||
|                 } |  | ||||||
|  |  | ||||||
|                 licenses { |  | ||||||
|                     license { |  | ||||||
|                         name = 'ComputerCraft Public License, Version 1.0' |  | ||||||
|                         url = 'https://github.com/SquidDev-CC/CC-Tweaked/blob/mc-1.15.x/LICENSE' |  | ||||||
|                     } |  | ||||||
|                 } |  | ||||||
|  |  | ||||||
|                 withXml { asNode().remove(asNode().get("dependencies")) } |  | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     // select the repositories you want to publish to | ||||||
|     repositories { |     repositories { | ||||||
|         if (project.hasProperty("mavenUser")) { |         // uncomment to publish to the local maven | ||||||
|             maven { |         // mavenLocal() | ||||||
|                 name = "SquidDev" |  | ||||||
|                 url = "https://squiddev.cc/maven" |  | ||||||
|                 credentials { |  | ||||||
|                     username = project.property("mavenUser") as String |  | ||||||
|                     password = project.property("mavenPass") as String |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| githubRelease { |  | ||||||
|     token project.hasProperty('githubApiKey') ? project.githubApiKey : '' |  | ||||||
|     owner 'SquidDev-CC' |  | ||||||
|     repo 'CC-Tweaked' |  | ||||||
|     targetCommitish.set(project.provider({ |  | ||||||
|         try { |  | ||||||
|             return ["git", "-C", projectDir, "rev-parse", "--abbrev-ref", "HEAD"].execute().text.trim() |  | ||||||
|         } catch (Exception e) { |  | ||||||
|             e.printStackTrace() |  | ||||||
|         } |  | ||||||
|         return "master" |  | ||||||
|     })) |  | ||||||
|  |  | ||||||
|     tagName "v${mc_version}-${mod_version}" |  | ||||||
|     releaseName "[${mc_version}] ${mod_version}" |  | ||||||
|     body.set(project.provider({ |  | ||||||
|         "## " + new File(projectDir, "src/main/resources/data/computercraft/lua/rom/help/whatsnew.md") |  | ||||||
|             .readLines() |  | ||||||
|             .takeWhile { it != 'Type "help changelog" to see the full version history.' } |  | ||||||
|             .join("\n").trim() |  | ||||||
|     })) |  | ||||||
|     prerelease false |  | ||||||
| } |  | ||||||
|  |  | ||||||
| def uploadTasks = ["publish", "curseforge", "publishModrinth", "githubRelease"] |  | ||||||
| uploadTasks.forEach { tasks.getByName(it).dependsOn checkRelease } |  | ||||||
|  |  | ||||||
| task uploadAll(dependsOn: uploadTasks) { |  | ||||||
|     group "upload" |  | ||||||
|     description "Uploads to all repositories (Maven, Curse, Modrinth, GitHub release)" |  | ||||||
| } |  | ||||||
|   | |||||||
| @@ -1,164 +0,0 @@ | |||||||
| <?xml version="1.0" encoding="UTF-8"?> |  | ||||||
| <!DOCTYPE module PUBLIC |  | ||||||
|     "-//Checkstyle//DTD Checkstyle Configuration 1.3//EN" |  | ||||||
|     "https://checkstyle.org/dtds/configuration_1_3.dtd"> |  | ||||||
| <module name="Checker"> |  | ||||||
|     <property name="tabWidth" value="4"/> |  | ||||||
|     <property name="charset" value="UTF-8" /> |  | ||||||
|  |  | ||||||
|     <module name="SuppressionFilter"> |  | ||||||
| 	<property name="file" value="${config_loc}/suppressions.xml" /> |  | ||||||
|     </module> |  | ||||||
|  |  | ||||||
|     <module name="BeforeExecutionExclusionFileFilter"> |  | ||||||
|         <property name="fileNamePattern" value="render_old"/> |  | ||||||
|     </module> |  | ||||||
|  |  | ||||||
|     <module name="TreeWalker"> |  | ||||||
|         <!-- Annotations --> |  | ||||||
|         <module name="AnnotationLocation" /> |  | ||||||
|         <module name="AnnotationUseStyle" /> |  | ||||||
|         <module name="MissingDeprecated" /> |  | ||||||
|         <module name="MissingOverride" /> |  | ||||||
|  |  | ||||||
|         <!-- Blocks --> |  | ||||||
|         <module name="EmptyBlock" /> |  | ||||||
|         <module name="EmptyCatchBlock"> |  | ||||||
|             <property name="exceptionVariableName" value="ignored" /> |  | ||||||
|         </module> |  | ||||||
|         <module name="LeftCurly"> |  | ||||||
|             <property name="option" value="nl" /> |  | ||||||
|             <!-- The defaults, minus lambdas. --> |  | ||||||
|             <property name="tokens" value="ANNOTATION_DEF,CLASS_DEF,CTOR_DEF,ENUM_CONSTANT_DEF,ENUM_DEF,INTERFACE_DEF,LITERAL_CASE,LITERAL_CATCH,LITERAL_DEFAULT,LITERAL_DO,LITERAL_ELSE,LITERAL_FINALLY,LITERAL_FOR,LITERAL_IF,LITERAL_SWITCH,LITERAL_SYNCHRONIZED,LITERAL_TRY,LITERAL_WHILE,METHOD_DEF,OBJBLOCK,STATIC_INIT" /> |  | ||||||
|         </module> |  | ||||||
|         <module name="NeedBraces"> |  | ||||||
|             <property name="allowSingleLineStatement" value="true"/> |  | ||||||
|         </module> |  | ||||||
|         <module name="RightCurly"> |  | ||||||
|             <property name="option" value="alone" /> |  | ||||||
|         </module> |  | ||||||
|  |  | ||||||
|         <!-- Class design. As if we've ever followed good practice here. --> |  | ||||||
|         <module name="FinalClass" /> |  | ||||||
|         <module name="InterfaceIsType" /> |  | ||||||
|         <module name="MutableException" /> |  | ||||||
|         <module name="OneTopLevelClass" /> |  | ||||||
|  |  | ||||||
|         <!-- Coding --> |  | ||||||
|         <module name="ArrayTrailingComma" /> |  | ||||||
|         <module name="EqualsHashCode" /> |  | ||||||
|         <!-- FallThrough does not handle unreachable code well --> |  | ||||||
|         <module name="IllegalInstantiation" /> |  | ||||||
|         <module name="IllegalThrows" /> |  | ||||||
|         <module name="ModifiedControlVariable" /> |  | ||||||
|         <module name="NoClone" /> |  | ||||||
|         <module name="NoFinalizer" /> |  | ||||||
|         <module name="OneStatementPerLine" /> |  | ||||||
|         <module name="PackageDeclaration" /> |  | ||||||
|         <module name="SimplifyBooleanExpression" /> |  | ||||||
|         <module name="SimplifyBooleanReturn" /> |  | ||||||
|         <module name="StringLiteralEquality" /> |  | ||||||
|         <module name="UnnecessaryParentheses" /> |  | ||||||
|         <module name="UnnecessarySemicolonAfterTypeMemberDeclaration" /> |  | ||||||
|         <module name="UnnecessarySemicolonInTryWithResources" /> |  | ||||||
|         <module name="UnnecessarySemicolonInEnumeration" /> |  | ||||||
|  |  | ||||||
|         <!-- Imports --> |  | ||||||
|         <module name="CustomImportOrder" /> |  | ||||||
|         <module name="IllegalImport" /> |  | ||||||
|         <module name="RedundantImport" /> |  | ||||||
|         <module name="UnusedImports" /> |  | ||||||
|  |  | ||||||
|         <!-- Javadoc --> |  | ||||||
|         <!-- TODO: Missing* checks for the dan200.computercraft.api package? --> |  | ||||||
|         <module name="AtclauseOrder" /> |  | ||||||
|         <module name="InvalidJavadocPosition" /> |  | ||||||
|         <module name="JavadocBlockTagLocation" /> |  | ||||||
|         <module name="JavadocMethod"/> |  | ||||||
|         <module name="JavadocType"/> |  | ||||||
|         <module name="JavadocStyle" /> |  | ||||||
|         <module name="NonEmptyAtclauseDescription" /> |  | ||||||
|         <module name="SingleLineJavadoc" /> |  | ||||||
|         <module name="SummaryJavadocCheck"/> |  | ||||||
|  |  | ||||||
|         <!-- Misc --> |  | ||||||
|         <module name="ArrayTypeStyle" /> |  | ||||||
|         <module name="CommentsIndentation" /> |  | ||||||
|         <module name="Indentation" /> |  | ||||||
|         <module name="OuterTypeFilename" /> |  | ||||||
|  |  | ||||||
|         <!-- Modifiers --> |  | ||||||
|         <module name="ModifierOrder" /> |  | ||||||
|         <module name="RedundantModifier" /> |  | ||||||
|  |  | ||||||
|         <!-- Naming --> |  | ||||||
|         <module name="ClassTypeParameterName" /> |  | ||||||
|         <module name="InterfaceTypeParameterName" /> |  | ||||||
|         <module name="LambdaParameterName" /> |  | ||||||
|         <module name="LocalFinalVariableName" /> |  | ||||||
|         <module name="LocalVariableName" /> |  | ||||||
|         <module name="MemberName" /> |  | ||||||
|         <module name="MethodName" /> |  | ||||||
|         <module name="MethodTypeParameterName" /> |  | ||||||
|         <module name="PackageName"> |  | ||||||
|             <property name="format" value="^dan200\.computercraft(\.[a-z][a-z0-9]*)*" /> |  | ||||||
|         </module> |  | ||||||
|         <module name="ParameterName" /> |  | ||||||
|         <module name="StaticVariableName"> |  | ||||||
|             <property name="format" value="^[a-z][a-zA-Z0-9]*|CAPABILITY(_[A-Z_]+)?$" /> |  | ||||||
|             <property name="applyToPrivate" value="false" /> |  | ||||||
|         </module> |  | ||||||
|         <module name="StaticVariableName"> |  | ||||||
|             <property name="format" value="^(s_)?[a-z][a-zA-Z0-9]*|CAPABILITY(_[A-Z_]+)?$" /> |  | ||||||
|             <property name="applyToPrivate" value="true" /> |  | ||||||
|         </module> |  | ||||||
|         <module name="TypeName" /> |  | ||||||
|  |  | ||||||
|         <!-- Whitespace --> |  | ||||||
|         <module name="EmptyForInitializerPad"/> |  | ||||||
|         <module name="EmptyForIteratorPad"> |  | ||||||
|             <property name="option" value="space"/> |  | ||||||
|         </module> |  | ||||||
|         <module name="GenericWhitespace" /> |  | ||||||
|         <module name="MethodParamPad" /> |  | ||||||
|         <module name="NoLineWrap" /> |  | ||||||
|         <module name="NoWhitespaceAfter"> |  | ||||||
|             <property name="tokens" value="AT,INC,DEC,UNARY_MINUS,UNARY_PLUS,BNOT,LNOT,DOT,ARRAY_DECLARATOR,INDEX_OP" /> |  | ||||||
|         </module> |  | ||||||
|         <module name="NoWhitespaceBefore" /> |  | ||||||
|         <!-- TODO: Decide on an OperatorWrap style. --> |  | ||||||
|         <module name="ParenPad"> |  | ||||||
|             <property name="option" value="space" /> |  | ||||||
|             <property name="tokens" value="ANNOTATION,ANNOTATION_FIELD_DEF,CTOR_CALL,CTOR_DEF,ENUM_CONSTANT_DEF,LITERAL_CATCH,LITERAL_DO,LITERAL_FOR,LITERAL_IF,LITERAL_NEW,LITERAL_SWITCH,LITERAL_SYNCHRONIZED,LITERAL_WHILE,METHOD_CALL,METHOD_DEF,RESOURCE_SPECIFICATION,SUPER_CTOR_CALL,LAMBDA" /> |  | ||||||
|         </module> |  | ||||||
|         <module name="ParenPad"> |  | ||||||
|             <property name="option" value="nospace" /> |  | ||||||
|             <property name="tokens" value="DOT,EXPR,QUESTION" /> |  | ||||||
|         </module> |  | ||||||
|         <module name="SeparatorWrap"> |  | ||||||
|             <property name="option" value="eol" /> |  | ||||||
|             <property name="tokens" value="COMMA,SEMI,ELLIPSIS,ARRAY_DECLARATOR,RBRACK,METHOD_REF" /> |  | ||||||
|         </module> |  | ||||||
|         <module name="SeparatorWrap"> |  | ||||||
|             <property name="option" value="nl" /> |  | ||||||
|             <property name="tokens" value="DOT,AT" /> |  | ||||||
|         </module> |  | ||||||
|         <module name="SingleSpaceSeparator" /> |  | ||||||
|         <module name="TypecastParenPad" /> |  | ||||||
|         <module name="WhitespaceAfter"> |  | ||||||
|             <property name="tokens" value="COMMA" /> |  | ||||||
|         </module> |  | ||||||
|         <module name="WhitespaceAround"> |  | ||||||
|             <property name="allowEmptyConstructors" value="true" /> |  | ||||||
|             <property name="ignoreEnhancedForColon" value="false" /> |  | ||||||
|             <property name="tokens" value="ASSIGN,BAND,BAND_ASSIGN,BOR,BOR_ASSIGN,BSR,BSR_ASSIGN,BXOR,BXOR_ASSIGN,COLON,DIV,DIV_ASSIGN,EQUAL,GE,GT,LAMBDA,LAND,LCURLY,LE,LITERAL_RETURN,LOR,LT,MINUS,MINUS_ASSIGN,MOD,MOD_ASSIGN,NOT_EQUAL,PLUS,PLUS_ASSIGN,QUESTION,RCURLY,SL,SLIST,SL_ASSIGN,SR,SR_ASSIGN,STAR,STAR_ASSIGN,LITERAL_ASSERT,TYPE_EXTENSION_AND" /> |  | ||||||
|         </module> |  | ||||||
|     </module> |  | ||||||
|  |  | ||||||
|     <module name="FileTabCharacter" /> |  | ||||||
|     <module name="NewlineAtEndOfFile" /> |  | ||||||
|     <module name="RegexpSingleline"> |  | ||||||
|         <property name="format" value="\s+$"/> |  | ||||||
|         <property name="message" value="Trailing whitespace"/> |  | ||||||
|     </module> |  | ||||||
| </module> |  | ||||||
| @@ -1,12 +0,0 @@ | |||||||
| <?xml version="1.0" encoding="UTF-8"?> |  | ||||||
| <!DOCTYPE suppressions PUBLIC |  | ||||||
|     "-//Checkstyle//DTD SuppressionFilter Configuration 1.2//EN" |  | ||||||
|     "https://checkstyle.org/dtds/suppressions_1_2.dtd"> |  | ||||||
| <suppressions> |  | ||||||
|     <!-- All the config options and method fields. --> |  | ||||||
|     <suppress checks="StaticVariableName" files=".*[\\/]ComputerCraft.java" /> |  | ||||||
|     <suppress checks="StaticVariableName" files=".*[\\/]ComputerCraftAPI.java" /> |  | ||||||
|  |  | ||||||
|     <!-- The commands API is documented in Lua. --> |  | ||||||
|     <suppress checks="SummaryJavadocCheck" files=".*[\\/]CommandAPI.java" /> |  | ||||||
| </suppressions> |  | ||||||
| @@ -1,8 +0,0 @@ | |||||||
| FROM gitpod/workspace-base |  | ||||||
|  |  | ||||||
| USER gitpod |  | ||||||
|  |  | ||||||
| RUN sudo apt-get -q update \ |  | ||||||
|  && sudo apt-get install -yq openjdk-8-jdk openjdk-16-jdk python3-pip npm \ |  | ||||||
|  && sudo pip3 install pre-commit \ |  | ||||||
|  && sudo update-java-alternatives --set java-1.8.0-openjdk-amd64 |  | ||||||
| @@ -1,3 +0,0 @@ | |||||||
| This file is part of the public ComputerCraft API - http://www.computercraft.info |  | ||||||
| Copyright Daniel Ratcliffe, 2011-${year}. This API may be redistributed unmodified and in full only. |  | ||||||
| For help using the API, and posting your mods, visit the forums at computercraft.info. |  | ||||||
| @@ -1,3 +0,0 @@ | |||||||
| This file is part of ComputerCraft - http://www.computercraft.info |  | ||||||
| Copyright Daniel Ratcliffe, 2011-${year}. Do not distribute without permission. |  | ||||||
| Send enquiries to dratcliffe@gmail.com |  | ||||||
| @@ -1,55 +0,0 @@ | |||||||
| # See https://pre-commit.com for more information |  | ||||||
| # See https://pre-commit.com/hooks.html for more hooks |  | ||||||
| repos: |  | ||||||
| - repo: https://github.com/pre-commit/pre-commit-hooks |  | ||||||
|   rev: v3.2.0 |  | ||||||
|   hooks: |  | ||||||
|   - id: trailing-whitespace |  | ||||||
|   - id: end-of-file-fixer |  | ||||||
|   - id: check-merge-conflict |  | ||||||
|  |  | ||||||
|   # Quick syntax checkers |  | ||||||
|   - id: check-xml |  | ||||||
|   - id: check-yaml |  | ||||||
|   - id: check-toml |  | ||||||
|   - id: check-json |  | ||||||
|     exclude: "tsconfig\\.json$" |  | ||||||
|  |  | ||||||
| - repo: https://github.com/editorconfig-checker/editorconfig-checker.python |  | ||||||
|   rev: 2.3.5 |  | ||||||
|   hooks: |  | ||||||
|   - id: editorconfig-checker |  | ||||||
|     args: ['-disable-indentation'] |  | ||||||
|     exclude: "^(.*\\.(bat)|LICENSE)$" |  | ||||||
|  |  | ||||||
| - repo: local |  | ||||||
|   hooks: |  | ||||||
|   - id: checkstyle |  | ||||||
|     name: Check Java codestyle |  | ||||||
|     files: ".*\\.java$" |  | ||||||
|     language: system |  | ||||||
|     entry: ./gradlew checkstyleMain checkstyleTest |  | ||||||
|     pass_filenames: false |  | ||||||
|     require_serial: true |  | ||||||
|   - id: license |  | ||||||
|     name: Check Java license headers |  | ||||||
|     files: ".*\\.java$" |  | ||||||
|     language: system |  | ||||||
|     entry: ./gradlew licenseFormat |  | ||||||
|     pass_filenames: false |  | ||||||
|     require_serial: true |  | ||||||
|   - id: illuaminate |  | ||||||
|     name: Check Lua code |  | ||||||
|     files: ".*\\.(lua|java|md)" |  | ||||||
|     language: script |  | ||||||
|     entry: config/pre-commit/illuaminate-lint.sh |  | ||||||
|     pass_filenames: false |  | ||||||
|     require_serial: true |  | ||||||
|  |  | ||||||
| exclude: | |  | ||||||
|   (?x)^( |  | ||||||
|     src/generated| |  | ||||||
|     src/test/resources/test-rom/data/json-parsing/| |  | ||||||
|     src/test/server-files/| |  | ||||||
|     config/idea/ |  | ||||||
|   ) |  | ||||||
| @@ -1,16 +0,0 @@ | |||||||
| #!/usr/bin/env sh |  | ||||||
| set -e |  | ||||||
|  |  | ||||||
| test -d bin || mkdir bin |  | ||||||
| test -f bin/illuaminate || curl -s -obin/illuaminate https://squiddev.cc/illuaminate/linux-x86-64/illuaminate |  | ||||||
| chmod +x bin/illuaminate |  | ||||||
|  |  | ||||||
| if [ -n ${GITHUB_ACTIONS+x} ]; then |  | ||||||
|     # Register a problem matcher (see https://github.com/actions/toolkit/blob/master/docs/problem-matchers.md) |  | ||||||
|     # for illuaminate. |  | ||||||
|     echo "::add-matcher::.github/matchers/illuaminate.json" |  | ||||||
|     trap 'echo "::remove-matcher owner=illuaminate::"' EXIT |  | ||||||
| fi |  | ||||||
|  |  | ||||||
| ./gradlew luaJavadoc |  | ||||||
| bin/illuaminate lint |  | ||||||
| @@ -1,21 +0,0 @@ | |||||||
| --- |  | ||||||
| module: [kind=event] alarm |  | ||||||
| see: os.setAlarm To start an alarm. |  | ||||||
| --- |  | ||||||
|  |  | ||||||
| The @{timer} event is fired when an alarm started with @{os.setAlarm} completes. |  | ||||||
|  |  | ||||||
| ## Return Values |  | ||||||
| 1. @{string}: The event name. |  | ||||||
| 2. @{number}: The ID of the alarm that finished. |  | ||||||
|  |  | ||||||
| ## Example |  | ||||||
| Starts a timer and then prints its ID: |  | ||||||
| ```lua |  | ||||||
| local alarmID = os.setAlarm(os.time() + 0.05) |  | ||||||
| local event, id |  | ||||||
| repeat |  | ||||||
|     event, id = os.pullEvent("alarm") |  | ||||||
| until id == alarmID |  | ||||||
| print("Alarm with ID " .. id .. " was fired") |  | ||||||
| ``` |  | ||||||
| @@ -1,24 +0,0 @@ | |||||||
| --- |  | ||||||
| module: [kind=event] char |  | ||||||
| see: key To listen to any key press. |  | ||||||
| --- |  | ||||||
|  |  | ||||||
| The @{char} event is fired when a character is _typed_ on the keyboard. |  | ||||||
|  |  | ||||||
| The @{char} event is different to a key press. Sometimes multiple key presses may result in one character being |  | ||||||
| typed (for instance, on some European keyboards). Similarly, some keys (e.g. <kbd>Ctrl</kbd>) do not have any |  | ||||||
| corresponding character. The @{key} should be used if you want to listen to key presses themselves. |  | ||||||
|  |  | ||||||
| ## Return values |  | ||||||
| 1. @{string}: The event name. |  | ||||||
| 2. @{string}: The string representing the character that was pressed. |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ## Example |  | ||||||
| Prints each character the user presses: |  | ||||||
| ```lua |  | ||||||
| while true do |  | ||||||
|   local event, character = os.pullEvent("char") |  | ||||||
|   print(character .. " was pressed.") |  | ||||||
| end |  | ||||||
| ``` |  | ||||||
| @@ -1,18 +0,0 @@ | |||||||
| --- |  | ||||||
| module: [kind=event] computer_command |  | ||||||
| --- |  | ||||||
|  |  | ||||||
| The @{computer_command} event is fired when the `/computercraft queue` command is run for the current computer. |  | ||||||
|  |  | ||||||
| ## Return Values |  | ||||||
| 1. @{string}: The event name. |  | ||||||
| ... @{string}: The arguments passed to the command. |  | ||||||
|  |  | ||||||
| ## Example |  | ||||||
| Prints the contents of messages sent: |  | ||||||
| ```lua |  | ||||||
| while true do |  | ||||||
|   local event = {os.pullEvent("computer_command")} |  | ||||||
|   print("Received message:", table.unpack(event, 2)) |  | ||||||
| end |  | ||||||
| ``` |  | ||||||
| @@ -1,19 +0,0 @@ | |||||||
| --- |  | ||||||
| module: [kind=event] disk |  | ||||||
| see: disk_eject For the event sent when a disk is removed. |  | ||||||
| --- |  | ||||||
|  |  | ||||||
| The @{disk} event is fired when a disk is inserted into an adjacent or networked disk drive. |  | ||||||
|  |  | ||||||
| ## Return Values |  | ||||||
| 1. @{string}: The event name. |  | ||||||
| 2. @{string}: The side of the disk drive that had a disk inserted. |  | ||||||
|  |  | ||||||
| ## Example |  | ||||||
| Prints a message when a disk is inserted: |  | ||||||
| ```lua |  | ||||||
| while true do |  | ||||||
|   local event, side = os.pullEvent("disk") |  | ||||||
|   print("Inserted a disk on side " .. side) |  | ||||||
| end |  | ||||||
| ``` |  | ||||||
| @@ -1,19 +0,0 @@ | |||||||
| --- |  | ||||||
| module: [kind=event] disk_eject |  | ||||||
| see: disk For the event sent when a disk is inserted. |  | ||||||
| --- |  | ||||||
|  |  | ||||||
| The @{disk_eject} event is fired when a disk is removed from an adjacent or networked disk drive. |  | ||||||
|  |  | ||||||
| ## Return Values |  | ||||||
| 1. @{string}: The event name. |  | ||||||
| 2. @{string}: The side of the disk drive that had a disk removed. |  | ||||||
|  |  | ||||||
| ## Example |  | ||||||
| Prints a message when a disk is removed: |  | ||||||
| ```lua |  | ||||||
| while true do |  | ||||||
|   local event, side = os.pullEvent("disk_eject") |  | ||||||
|   print("Removed a disk on side " .. side) |  | ||||||
| end |  | ||||||
| ``` |  | ||||||
| @@ -1,14 +0,0 @@ | |||||||
| --- |  | ||||||
| module: [kind=event] http_check |  | ||||||
| see: http.checkURLAsync To check a URL asynchronously. |  | ||||||
| --- |  | ||||||
|  |  | ||||||
| The @{http_check} event is fired when a URL check finishes. |  | ||||||
|  |  | ||||||
| This event is normally handled inside @{http.checkURL}, but it can still be seen when using @{http.checkURLAsync}. |  | ||||||
|  |  | ||||||
| ## Return Values |  | ||||||
| 1. @{string}: The event name. |  | ||||||
| 2. @{string}: The URL requested to be checked. |  | ||||||
| 3. @{boolean}: Whether the check succeeded. |  | ||||||
| 4. @{string|nil}: If the check failed, a reason explaining why the check failed. |  | ||||||
| @@ -1,39 +0,0 @@ | |||||||
| --- |  | ||||||
| module: [kind=event] http_failure |  | ||||||
| see: http.request To send an HTTP request. |  | ||||||
| --- |  | ||||||
|  |  | ||||||
| The @{http_failure} event is fired when an HTTP request fails. |  | ||||||
|  |  | ||||||
| This event is normally handled inside @{http.get} and @{http.post}, but it can still be seen when using @{http.request}. |  | ||||||
|  |  | ||||||
| ## Return Values |  | ||||||
| 1. @{string}: The event name. |  | ||||||
| 2. @{string}: The URL of the site requested. |  | ||||||
| 3. @{string}: An error describing the failure. |  | ||||||
| 4. @{http.Response|nil}: A response handle if the connection succeeded, but the server's response indicated failure. |  | ||||||
|  |  | ||||||
| ## Example |  | ||||||
| Prints an error why the website cannot be contacted: |  | ||||||
| ```lua |  | ||||||
| local myURL = "https://does.not.exist.tweaked.cc" |  | ||||||
| http.request(myURL) |  | ||||||
| local event, url, err |  | ||||||
| repeat |  | ||||||
|     event, url, err = os.pullEvent("http_failure") |  | ||||||
| until url == myURL |  | ||||||
| print("The URL " .. url .. " could not be reached: " .. err) |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| Prints the contents of a webpage that does not exist: |  | ||||||
| ```lua |  | ||||||
| local myURL = "https://tweaked.cc/this/does/not/exist" |  | ||||||
| http.request(myURL) |  | ||||||
| local event, url, err, handle |  | ||||||
| repeat |  | ||||||
|     event, url, err, handle = os.pullEvent("http_failure") |  | ||||||
| until url == myURL |  | ||||||
| print("The URL " .. url .. " could not be reached: " .. err) |  | ||||||
| print(handle.getResponseCode()) |  | ||||||
| handle.close() |  | ||||||
| ``` |  | ||||||
| @@ -1,27 +0,0 @@ | |||||||
| --- |  | ||||||
| module: [kind=event] http_success |  | ||||||
| see: http.request To make an HTTP request. |  | ||||||
| --- |  | ||||||
|  |  | ||||||
| The @{http_success} event is fired when an HTTP request returns successfully. |  | ||||||
|  |  | ||||||
| This event is normally handled inside @{http.get} and @{http.post}, but it can still be seen when using @{http.request}. |  | ||||||
|  |  | ||||||
| ## Return Values |  | ||||||
| 1. @{string}: The event name. |  | ||||||
| 2. @{string}: The URL of the site requested. |  | ||||||
| 3. @{http.Response}: The handle for the response text. |  | ||||||
|  |  | ||||||
| ## Example |  | ||||||
| Prints the content of a website (this may fail if the request fails): |  | ||||||
| ```lua |  | ||||||
| local myURL = "https://tweaked.cc/" |  | ||||||
| http.request(myURL) |  | ||||||
| local event, url, handle |  | ||||||
| repeat |  | ||||||
|     event, url, handle = os.pullEvent("http_success") |  | ||||||
| until url == myURL |  | ||||||
| print("Contents of " .. url .. ":") |  | ||||||
| print(handle.readAll()) |  | ||||||
| handle.close() |  | ||||||
| ``` |  | ||||||
| @@ -1,26 +0,0 @@ | |||||||
| --- |  | ||||||
| module: [kind=event] key |  | ||||||
| --- |  | ||||||
|  |  | ||||||
| This event is fired when any key is pressed while the terminal is focused. |  | ||||||
|  |  | ||||||
| This event returns a numerical "key code" (for instance, <kbd>F1</kbd> is 290). This value may vary between versions and |  | ||||||
| so it is recommended to use the constants in the @{keys} API rather than hard coding numeric values. |  | ||||||
|  |  | ||||||
| If the button pressed represented a printable character, then the @{key} event will be followed immediately by a @{char} |  | ||||||
| event. If you are consuming text input, use a @{char} event instead! |  | ||||||
|  |  | ||||||
| ## Return values |  | ||||||
| 1. @{string}: The event name. |  | ||||||
| 2. @{number}: The numerical key value of the key pressed. |  | ||||||
| 3. @{boolean}: Whether the key event was generated while holding the key (@{true}), rather than pressing it the first time (@{false}). |  | ||||||
|  |  | ||||||
| ## Example |  | ||||||
| Prints each key when the user presses it, and if the key is being held. |  | ||||||
|  |  | ||||||
| ```lua |  | ||||||
| while true do |  | ||||||
|   local event, key, is_held = os.pullEvent("key") |  | ||||||
|   print(("%s held=%s"):format(keys.getName(key), is_held)) |  | ||||||
| end |  | ||||||
| ``` |  | ||||||
| @@ -1,24 +0,0 @@ | |||||||
| --- |  | ||||||
| module: [kind=event] key_up |  | ||||||
| see: keys For a lookup table of the given keys. |  | ||||||
| --- |  | ||||||
|  |  | ||||||
| Fired whenever a key is released (or the terminal is closed while a key was being pressed). |  | ||||||
|  |  | ||||||
| This event returns a numerical "key code" (for instance, <kbd>F1</kbd> is 290). This value may vary between versions and |  | ||||||
| so it is recommended to use the constants in the @{keys} API rather than hard coding numeric values. |  | ||||||
|  |  | ||||||
| ## Return values |  | ||||||
| 1. @{string}: The event name. |  | ||||||
| 2. @{number}: The numerical key value of the key pressed. |  | ||||||
|  |  | ||||||
| ## Example |  | ||||||
| Prints each key released on the keyboard whenever a @{key_up} event is fired. |  | ||||||
|  |  | ||||||
| ```lua |  | ||||||
| while true do |  | ||||||
|   local event, key = os.pullEvent("key_up") |  | ||||||
|   local name = keys.getName(key) or "unknown key" |  | ||||||
|   print(name .. " was released.") |  | ||||||
| end |  | ||||||
| ``` |  | ||||||
| @@ -1,22 +0,0 @@ | |||||||
| --- |  | ||||||
| module: [kind=event] modem_message |  | ||||||
| --- |  | ||||||
|  |  | ||||||
| The @{modem_message} event is fired when a message is received on an open channel on any modem. |  | ||||||
|  |  | ||||||
| ## Return Values |  | ||||||
| 1. @{string}: The event name. |  | ||||||
| 2. @{string}: The side of the modem that received the message. |  | ||||||
| 3. @{number}: The channel that the message was sent on. |  | ||||||
| 4. @{number}: The reply channel set by the sender. |  | ||||||
| 5. @{any}: The message as sent by the sender. |  | ||||||
| 6. @{number}: The distance between the sender and the receiver, in blocks (decimal). |  | ||||||
|  |  | ||||||
| ## Example |  | ||||||
| Prints a message when one is sent: |  | ||||||
| ```lua |  | ||||||
| while true do |  | ||||||
|   local event, side, channel, replyChannel, message, distance = os.pullEvent("modem_message") |  | ||||||
|   print(("Message received on side %s on channel %d (reply to %d) from %f blocks away with message %s"):format(side, channel, replyChannel, distance, tostring(message))) |  | ||||||
| end |  | ||||||
| ``` |  | ||||||
| @@ -1,18 +0,0 @@ | |||||||
| --- |  | ||||||
| module: [kind=event] monitor_resize |  | ||||||
| --- |  | ||||||
|  |  | ||||||
| The @{monitor_resize} event is fired when an adjacent or networked monitor's size is changed. |  | ||||||
|  |  | ||||||
| ## Return Values |  | ||||||
| 1. @{string}: The event name. |  | ||||||
| 2. @{string}: The side or network ID of the monitor that resized. |  | ||||||
|  |  | ||||||
| ## Example |  | ||||||
| Prints a message when a monitor is resized: |  | ||||||
| ```lua |  | ||||||
| while true do |  | ||||||
|   local event, side = os.pullEvent("monitor_resize") |  | ||||||
|   print("The monitor on side " .. side .. " was resized.") |  | ||||||
| end |  | ||||||
| ``` |  | ||||||
| @@ -1,20 +0,0 @@ | |||||||
| --- |  | ||||||
| module: [kind=event] monitor_touch |  | ||||||
| --- |  | ||||||
|  |  | ||||||
| The @{monitor_touch} event is fired when an adjacent or networked Advanced Monitor is right-clicked. |  | ||||||
|  |  | ||||||
| ## Return Values |  | ||||||
| 1. @{string}: The event name. |  | ||||||
| 2. @{string}: The side or network ID of the monitor that was touched. |  | ||||||
| 3. @{number}: The X coordinate of the touch, in characters. |  | ||||||
| 4. @{number}: The Y coordinate of the touch, in characters. |  | ||||||
|  |  | ||||||
| ## Example |  | ||||||
| Prints a message when a monitor is touched: |  | ||||||
| ```lua |  | ||||||
| while true do |  | ||||||
|   local event, side, x, y = os.pullEvent("monitor_touch") |  | ||||||
|   print("The monitor on side " .. side .. " was touched at (" .. x .. ", " .. y .. ")") |  | ||||||
| end |  | ||||||
| ``` |  | ||||||
| @@ -1,34 +0,0 @@ | |||||||
| --- |  | ||||||
| module: [kind=event] mouse_click |  | ||||||
| --- |  | ||||||
|  |  | ||||||
| This event is fired when the terminal is clicked with a mouse. This event is only fired on advanced computers (including |  | ||||||
| advanced turtles and pocket computers). |  | ||||||
|  |  | ||||||
| ## Return values |  | ||||||
| 1. @{string}: The event name. |  | ||||||
| 2. @{number}: The mouse button that was clicked. |  | ||||||
| 3. @{number}: The X-coordinate of the click. |  | ||||||
| 4. @{number}: The Y-coordinate of the click. |  | ||||||
|  |  | ||||||
| ## Mouse buttons |  | ||||||
| Several mouse events (@{mouse_click}, @{mouse_up}, @{mouse_scroll}) contain a "mouse button" code. This takes a |  | ||||||
| numerical value depending on which button on your mouse was last pressed when this event occurred. |  | ||||||
|  |  | ||||||
| <table class="pretty-table"> |  | ||||||
|     <!-- Our markdown parser doesn't work on tables!? Guess I'll have to roll my own soonish :/. --> |  | ||||||
|     <tr><th>Button code</th><th>Mouse button</th></tr> |  | ||||||
|     <tr><td align="right">1</td><td>Left button</td></tr> |  | ||||||
|     <tr><td align="right">2</td><td>Middle button</td></tr> |  | ||||||
|     <tr><td align="right">3</td><td>Right button</td></tr> |  | ||||||
| </table> |  | ||||||
|  |  | ||||||
| ## Example |  | ||||||
| Print the button and the coordinates whenever the mouse is clicked. |  | ||||||
|  |  | ||||||
| ```lua |  | ||||||
| while true do |  | ||||||
|   local event, button, x, y = os.pullEvent("mouse_click") |  | ||||||
|   print(("The mouse button %s was pressed at %d, %d"):format(button, x, y)) |  | ||||||
| end |  | ||||||
| ``` |  | ||||||
| @@ -1,22 +0,0 @@ | |||||||
| --- |  | ||||||
| module: [kind=event] mouse_drag |  | ||||||
| see: mouse_click For when a mouse button is initially pressed. |  | ||||||
| --- |  | ||||||
|  |  | ||||||
| This event is fired every time the mouse is moved while a mouse button is being held. |  | ||||||
|  |  | ||||||
| ## Return values |  | ||||||
| 1. @{string}: The event name. |  | ||||||
| 2. @{number}: The [mouse button](mouse_click.html#Mouse_buttons) that is being pressed. |  | ||||||
| 3. @{number}: The X-coordinate of the mouse. |  | ||||||
| 4. @{number}: The Y-coordinate of the mouse. |  | ||||||
|  |  | ||||||
| ## Example |  | ||||||
| Print the button and the coordinates whenever the mouse is dragged. |  | ||||||
|  |  | ||||||
| ```lua |  | ||||||
| while true do |  | ||||||
|   local event, button, x, y = os.pullEvent("mouse_drag") |  | ||||||
|   print(("The mouse button %s was dragged at %d, %d"):format(button, x, y)) |  | ||||||
| end |  | ||||||
| ``` |  | ||||||
| @@ -1,21 +0,0 @@ | |||||||
| --- |  | ||||||
| module: [kind=event] mouse_scroll |  | ||||||
| --- |  | ||||||
|  |  | ||||||
| This event is fired when a mouse wheel is scrolled in the terminal. |  | ||||||
|  |  | ||||||
| ## Return values |  | ||||||
| 1. @{string}: The event name. |  | ||||||
| 2. @{number}: The direction of the scroll. (-1 = up, 1 = down) |  | ||||||
| 3. @{number}: The X-coordinate of the mouse when scrolling. |  | ||||||
| 4. @{number}: The Y-coordinate of the mouse when scrolling. |  | ||||||
|  |  | ||||||
| ## Example |  | ||||||
| Prints the direction of each scroll, and the position of the mouse at the time. |  | ||||||
|  |  | ||||||
| ```lua |  | ||||||
| while true do |  | ||||||
|   local event, dir, x, y = os.pullEvent("mouse_scroll") |  | ||||||
|   print(("The mouse was scrolled in direction %s at %d, %d"):format(dir, x, y)) |  | ||||||
| end |  | ||||||
| ``` |  | ||||||
| @@ -1,21 +0,0 @@ | |||||||
| --- |  | ||||||
| module: [kind=event] mouse_up |  | ||||||
| --- |  | ||||||
|  |  | ||||||
| This event is fired when a mouse button is released or a held mouse leaves the computer's terminal. |  | ||||||
|  |  | ||||||
| ## Return values |  | ||||||
| 1. @{string}: The event name. |  | ||||||
| 2. @{number}: The [mouse button](mouse_click.html#Mouse_buttons) that was released. |  | ||||||
| 3. @{number}: The X-coordinate of the mouse. |  | ||||||
| 4. @{number}: The Y-coordinate of the mouse. |  | ||||||
|  |  | ||||||
| ## Example |  | ||||||
| Prints the coordinates and button number whenever the mouse is released. |  | ||||||
|  |  | ||||||
| ```lua |  | ||||||
| while true do |  | ||||||
|   local event, button, x, y = os.pullEvent("mouse_up") |  | ||||||
|   print(("The mouse button %s was released at %d, %d"):format(button, x, y)) |  | ||||||
| end |  | ||||||
| ``` |  | ||||||
| @@ -1,18 +0,0 @@ | |||||||
| --- |  | ||||||
| module: [kind=event] paste |  | ||||||
| --- |  | ||||||
|  |  | ||||||
| The @{paste} event is fired when text is pasted into the computer through Ctrl-V (or ⌘V on Mac). |  | ||||||
|  |  | ||||||
| ## Return values |  | ||||||
| 1. @{string}: The event name. |  | ||||||
| 2. @{string} The text that was pasted. |  | ||||||
|  |  | ||||||
| ## Example |  | ||||||
| Prints pasted text: |  | ||||||
| ```lua |  | ||||||
| while true do |  | ||||||
|   local event, text = os.pullEvent("paste") |  | ||||||
|   print('"' .. text .. '" was pasted') |  | ||||||
| end |  | ||||||
| ``` |  | ||||||
| @@ -1,19 +0,0 @@ | |||||||
| --- |  | ||||||
| module: [kind=event] peripheral |  | ||||||
| see: peripheral_detach For the event fired when a peripheral is detached. |  | ||||||
| --- |  | ||||||
|  |  | ||||||
| The @{peripheral} event is fired when a peripheral is attached on a side or to a modem. |  | ||||||
|  |  | ||||||
| ## Return Values |  | ||||||
| 1. @{string}: The event name. |  | ||||||
| 2. @{string}: The side the peripheral was attached to. |  | ||||||
|  |  | ||||||
| ## Example |  | ||||||
| Prints a message when a peripheral is attached: |  | ||||||
| ```lua |  | ||||||
| while true do |  | ||||||
|   local event, side = os.pullEvent("peripheral") |  | ||||||
|   print("A peripheral was attached on side " .. side) |  | ||||||
| end |  | ||||||
| ``` |  | ||||||
| @@ -1,19 +0,0 @@ | |||||||
| --- |  | ||||||
| module: [kind=event] peripheral_detach |  | ||||||
| see: peripheral For the event fired when a peripheral is attached. |  | ||||||
| --- |  | ||||||
|  |  | ||||||
| The @{peripheral_detach} event is fired when a peripheral is detached from a side or from a modem. |  | ||||||
|  |  | ||||||
| ## Return Values |  | ||||||
| 1. @{string}: The event name. |  | ||||||
| 2. @{string}: The side the peripheral was detached from. |  | ||||||
|  |  | ||||||
| ## Example |  | ||||||
| Prints a message when a peripheral is detached: |  | ||||||
| ```lua |  | ||||||
| while true do |  | ||||||
|   local event, side = os.pullEvent("peripheral_detach") |  | ||||||
|   print("A peripheral was detached on side " .. side) |  | ||||||
| end |  | ||||||
| ``` |  | ||||||
| @@ -1,30 +0,0 @@ | |||||||
| --- |  | ||||||
| module: [kind=event] rednet_message |  | ||||||
| see: modem_message For raw modem messages sent outside of Rednet. |  | ||||||
| see: rednet.receive To wait for a Rednet message with an optional timeout and protocol filter. |  | ||||||
| --- |  | ||||||
|  |  | ||||||
| The @{rednet_message} event is fired when a message is sent over Rednet. |  | ||||||
|  |  | ||||||
| This event is usually handled by @{rednet.receive}, but it can also be pulled manually. |  | ||||||
|  |  | ||||||
| @{rednet_message} events are sent by @{rednet.run} in the top-level coroutine in response to @{modem_message} events. A @{rednet_message} event is always preceded by a @{modem_message} event. They are generated inside CraftOS rather than being sent by the ComputerCraft machine. |  | ||||||
|  |  | ||||||
| ## Return Values |  | ||||||
| 1. @{string}: The event name. |  | ||||||
| 2. @{number}: The ID of the sending computer. |  | ||||||
| 3. @{any}: The message sent. |  | ||||||
| 4. @{string|nil}: The protocol of the message, if provided. |  | ||||||
|  |  | ||||||
| ## Example |  | ||||||
| Prints a message when one is sent: |  | ||||||
| ```lua |  | ||||||
| while true do |  | ||||||
|   local event, sender, message, protocol = os.pullEvent("rednet_message") |  | ||||||
|   if protocol ~= nil then |  | ||||||
|     print("Received message from " .. sender .. " with protocol " .. protocol .. " and message " .. tostring(message)) |  | ||||||
|   else |  | ||||||
|     print("Received message from " .. sender .. " with message " .. tostring(message)) |  | ||||||
|   end |  | ||||||
| end |  | ||||||
| ``` |  | ||||||
| @@ -1,14 +0,0 @@ | |||||||
| --- |  | ||||||
| module: [kind=event] redstone |  | ||||||
| --- |  | ||||||
|  |  | ||||||
| The @{redstone} event is fired whenever any redstone inputs on the computer change. |  | ||||||
|  |  | ||||||
| ## Example |  | ||||||
| Prints a message when a redstone input changes: |  | ||||||
| ```lua |  | ||||||
| while true do |  | ||||||
|   os.pullEvent("redstone") |  | ||||||
|   print("A redstone input has changed!") |  | ||||||
| end |  | ||||||
| ``` |  | ||||||
| @@ -1,28 +0,0 @@ | |||||||
| --- |  | ||||||
| module: [kind=event] task_complete |  | ||||||
| see: commands.execAsync To run a command which fires a task_complete event. |  | ||||||
| --- |  | ||||||
|  |  | ||||||
| The @{task_complete} event is fired when an asynchronous task completes. This is usually handled inside the function call that queued the task; however, functions such as @{commands.execAsync} return immediately so the user can wait for completion. |  | ||||||
|  |  | ||||||
| ## Return Values |  | ||||||
| 1. @{string}: The event name. |  | ||||||
| 2. @{number}: The ID of the task that completed. |  | ||||||
| 3. @{boolean}: Whether the command succeeded. |  | ||||||
| 4. @{string}: If the command failed, an error message explaining the failure. (This is not present if the command succeeded.) |  | ||||||
| ...: Any parameters returned from the command. |  | ||||||
|  |  | ||||||
| ## Example |  | ||||||
| Prints the results of an asynchronous command: |  | ||||||
| ```lua |  | ||||||
| local taskID = commands.execAsync("say Hello") |  | ||||||
| local event |  | ||||||
| repeat |  | ||||||
|     event = {os.pullEvent("task_complete")} |  | ||||||
| until event[2] == taskID |  | ||||||
| if event[3] == true then |  | ||||||
|   print("Task " .. event[2] .. " succeeded:", table.unpack(event, 4)) |  | ||||||
| else |  | ||||||
|   print("Task " .. event[2] .. " failed: " .. event[4]) |  | ||||||
| end |  | ||||||
| ``` |  | ||||||
| @@ -1,15 +0,0 @@ | |||||||
| --- |  | ||||||
| module: [kind=event] term_resize |  | ||||||
| --- |  | ||||||
|  |  | ||||||
| The @{term_resize} event is fired when the main terminal is resized, mainly when a new tab is opened or closed in @{multishell}. |  | ||||||
|  |  | ||||||
| ## Example |  | ||||||
| Prints : |  | ||||||
| ```lua |  | ||||||
| while true do |  | ||||||
|   os.pullEvent("term_resize") |  | ||||||
|   local w, h = term.getSize() |  | ||||||
|   print("The term was resized to (" .. w .. ", " .. h .. ")") |  | ||||||
| end |  | ||||||
| ``` |  | ||||||
| @@ -1,25 +0,0 @@ | |||||||
| --- |  | ||||||
| module: [kind=event] terminate |  | ||||||
| --- |  | ||||||
|  |  | ||||||
| The @{terminate} event is fired when <kbd>Ctrl-T</kbd> is held down. |  | ||||||
|  |  | ||||||
| This event is normally handled by @{os.pullEvent}, and will not be returned. However, @{os.pullEventRaw} will return this event when fired. |  | ||||||
|  |  | ||||||
| @{terminate} will be sent even when a filter is provided to @{os.pullEventRaw}. When using @{os.pullEventRaw} with a filter, make sure to check that the event is not @{terminate}. |  | ||||||
|  |  | ||||||
| ## Example |  | ||||||
| Prints a message when Ctrl-T is held: |  | ||||||
| ```lua |  | ||||||
| while true do |  | ||||||
|   local event = os.pullEventRaw("terminate") |  | ||||||
|   if event == "terminate" then print("Terminate requested!") end |  | ||||||
| end |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| Exits when Ctrl-T is held: |  | ||||||
| ```lua |  | ||||||
| while true do |  | ||||||
|   os.pullEvent() |  | ||||||
| end |  | ||||||
| ``` |  | ||||||
| @@ -1,21 +0,0 @@ | |||||||
| --- |  | ||||||
| module: [kind=event] timer |  | ||||||
| see: os.startTimer To start a timer. |  | ||||||
| --- |  | ||||||
|  |  | ||||||
| The @{timer} event is fired when a timer started with @{os.startTimer} completes. |  | ||||||
|  |  | ||||||
| ## Return Values |  | ||||||
| 1. @{string}: The event name. |  | ||||||
| 2. @{number}: The ID of the timer that finished. |  | ||||||
|  |  | ||||||
| ## Example |  | ||||||
| Starts a timer and then prints its ID: |  | ||||||
| ```lua |  | ||||||
| local timerID = os.startTimer(2) |  | ||||||
| local event, id |  | ||||||
| repeat |  | ||||||
|     event, id = os.pullEvent("timer") |  | ||||||
| until id == timerID |  | ||||||
| print("Timer with ID " .. id .. " was fired") |  | ||||||
| ``` |  | ||||||
| @@ -1,14 +0,0 @@ | |||||||
| --- |  | ||||||
| module: [kind=event] turtle_inventory |  | ||||||
| --- |  | ||||||
|  |  | ||||||
| The @{turtle_inventory} event is fired when a turtle's inventory is changed. |  | ||||||
|  |  | ||||||
| ## Example |  | ||||||
| Prints a message when the inventory is changed: |  | ||||||
| ```lua |  | ||||||
| while true do |  | ||||||
|   os.pullEvent("turtle_inventory") |  | ||||||
|   print("The inventory was changed.") |  | ||||||
| end |  | ||||||
| ``` |  | ||||||
| @@ -1,21 +0,0 @@ | |||||||
| --- |  | ||||||
| module: [kind=event] websocket_closed |  | ||||||
| --- |  | ||||||
|  |  | ||||||
| The @{websocket_closed} event is fired when an open WebSocket connection is closed. |  | ||||||
|  |  | ||||||
| ## Return Values |  | ||||||
| 1. @{string}: The event name. |  | ||||||
| 2. @{string}: The URL of the WebSocket that was closed. |  | ||||||
|  |  | ||||||
| ## Example |  | ||||||
| Prints a message when a WebSocket is closed (this may take a minute): |  | ||||||
| ```lua |  | ||||||
| local myURL = "wss://example.tweaked.cc/echo" |  | ||||||
| local ws = http.websocket(myURL) |  | ||||||
| local event, url |  | ||||||
| repeat |  | ||||||
|     event, url = os.pullEvent("websocket_closed") |  | ||||||
| until url == myURL |  | ||||||
| print("The WebSocket at " .. url .. " was closed.") |  | ||||||
| ``` |  | ||||||
| @@ -1,25 +0,0 @@ | |||||||
| --- |  | ||||||
| module: [kind=event] websocket_failure |  | ||||||
| see: http.websocketAsync To send an HTTP request. |  | ||||||
| --- |  | ||||||
|  |  | ||||||
| The @{websocket_failure} event is fired when a WebSocket connection request fails. |  | ||||||
|  |  | ||||||
| This event is normally handled inside @{http.websocket}, but it can still be seen when using @{http.websocketAsync}. |  | ||||||
|  |  | ||||||
| ## Return Values |  | ||||||
| 1. @{string}: The event name. |  | ||||||
| 2. @{string}: The URL of the site requested. |  | ||||||
| 3. @{string}: An error describing the failure. |  | ||||||
|  |  | ||||||
| ## Example |  | ||||||
| Prints an error why the website cannot be contacted: |  | ||||||
| ```lua |  | ||||||
| local myURL = "wss://example.tweaked.cc/not-a-websocket" |  | ||||||
| http.websocketAsync(myURL) |  | ||||||
| local event, url, err |  | ||||||
| repeat |  | ||||||
|     event, url, err = os.pullEvent("websocket_failure") |  | ||||||
| until url == myURL |  | ||||||
| print("The URL " .. url .. " could not be reached: " .. err) |  | ||||||
| ``` |  | ||||||
| @@ -1,26 +0,0 @@ | |||||||
| --- |  | ||||||
| module: [kind=event] websocket_message |  | ||||||
| --- |  | ||||||
|  |  | ||||||
| The @{websocket_message} event is fired when a message is received on an open WebSocket connection. |  | ||||||
|  |  | ||||||
| This event is normally handled by @{http.Websocket.receive}, but it can also be pulled manually. |  | ||||||
|  |  | ||||||
| ## Return Values |  | ||||||
| 1. @{string}: The event name. |  | ||||||
| 2. @{string}: The URL of the WebSocket. |  | ||||||
| 3. @{string}: The contents of the message. |  | ||||||
|  |  | ||||||
| ## Example |  | ||||||
| Prints a message sent by a WebSocket: |  | ||||||
| ```lua |  | ||||||
| local myURL = "wss://example.tweaked.cc/echo" |  | ||||||
| local ws = http.websocket(myURL) |  | ||||||
| ws.send("Hello!") |  | ||||||
| local event, url, message |  | ||||||
| repeat |  | ||||||
|     event, url, message = os.pullEvent("websocket_message") |  | ||||||
| until url == myURL |  | ||||||
| print("Received message from " .. url .. " with contents " .. message) |  | ||||||
| ws.close() |  | ||||||
| ``` |  | ||||||
| @@ -1,28 +0,0 @@ | |||||||
| --- |  | ||||||
| module: [kind=event] websocket_success |  | ||||||
| see: http.websocketAsync To open a WebSocket asynchronously. |  | ||||||
| --- |  | ||||||
|  |  | ||||||
| The @{websocket_success} event is fired when a WebSocket connection request returns successfully. |  | ||||||
|  |  | ||||||
| This event is normally handled inside @{http.websocket}, but it can still be seen when using @{http.websocketAsync}. |  | ||||||
|  |  | ||||||
| ## Return Values |  | ||||||
| 1. @{string}: The event name. |  | ||||||
| 2. @{string}: The URL of the site. |  | ||||||
| 3. @{http.Websocket}: The handle for the WebSocket. |  | ||||||
|  |  | ||||||
| ## Example |  | ||||||
| Prints the content of a website (this may fail if the request fails): |  | ||||||
| ```lua |  | ||||||
| local myURL = "wss://example.tweaked.cc/echo" |  | ||||||
| http.websocketAsync(myURL) |  | ||||||
| local event, url, handle |  | ||||||
| repeat |  | ||||||
|     event, url, handle = os.pullEvent("websocket_success") |  | ||||||
| until url == myURL |  | ||||||
| print("Connected to " .. url) |  | ||||||
| handle.send("Hello!") |  | ||||||
| print(handle.receive()) |  | ||||||
| handle.close() |  | ||||||
| ``` |  | ||||||
| @@ -1 +0,0 @@ | |||||||
| <meta name="theme-color" content="#c8d87c"> |  | ||||||
							
								
								
									
										11
									
								
								doc/index.md
									
									
									
									
									
								
							
							
						
						
									
										11
									
								
								doc/index.md
									
									
									
									
									
								
							| @@ -1,11 +0,0 @@ | |||||||
| #  [](https://minecraft.curseforge.com/projects/cc-tweaked "Download CC: Tweaked on CurseForge") |  | ||||||
|  |  | ||||||
| CC: Tweaked is a fork of [ComputerCraft], adding programmable computers, turtles and more to Minecraft. |  | ||||||
|  |  | ||||||
| This website contains documentation for all Lua libraries and APIs from the latest version of CC: Tweaked. This |  | ||||||
| documentation is still in development, so will most likely be incomplete. If you've found something you think is wrong, |  | ||||||
| or would like to help out [please get in touch on GitHub][gh]. |  | ||||||
|  |  | ||||||
| [bug]: https://github.com/SquidDev-CC/CC-Tweaked/issues/new/choose |  | ||||||
| [computercraft]: https://github.com/dan200/ComputerCraft "ComputerCraft on GitHub" |  | ||||||
| [gh]: https://github.com/SquidDev-CC/CC-Tweaked "CC:Tweaked on GitHub" |  | ||||||
| @@ -1,34 +0,0 @@ | |||||||
| ---  The FS API allows you to manipulate files and the filesystem. |  | ||||||
| -- |  | ||||||
| -- @module fs |  | ||||||
|  |  | ||||||
| --- Returns true if a path is mounted to the parent filesystem. |  | ||||||
| -- |  | ||||||
| -- The root filesystem "/" is considered a mount, along with disk folders and |  | ||||||
| -- the rom folder. Other programs (such as network shares) can exstend this to |  | ||||||
| -- make other mount types by correctly assigning their return value for getDrive. |  | ||||||
| -- |  | ||||||
| -- @tparam string path The path to check. |  | ||||||
| -- @treturn boolean If the path is mounted, rather than a normal file/folder. |  | ||||||
| -- @throws If the path does not exist. |  | ||||||
| -- @see getDrive |  | ||||||
| function isDriveRoot(path) end |  | ||||||
|  |  | ||||||
| --[[- Provides completion for a file or directory name, suitable for use with |  | ||||||
| @{_G.read}. |  | ||||||
|  |  | ||||||
| When a directory is a possible candidate for completion, two entries are |  | ||||||
| included - one with a trailing slash (indicating that entries within this |  | ||||||
| directory exist) and one without it (meaning this entry is an immediate |  | ||||||
| completion candidate). `include_dirs` can be set to @{false} to only include |  | ||||||
| those with a trailing slash. |  | ||||||
|  |  | ||||||
| @tparam string path The path to complete. |  | ||||||
| @tparam string location The location where paths are resolved from. |  | ||||||
| @tparam[opt] boolean include_files When @{false}, only directories will be |  | ||||||
| included in the returned list. |  | ||||||
| @tparam[opt] boolean include_dirs When @{false}, "raw" directories will not be |  | ||||||
| included in the returned list. |  | ||||||
| @treturn { string... } A list of possible completion candidates. |  | ||||||
| ]] |  | ||||||
| function complete(path, location, include_files, include_dirs) end |  | ||||||
| @@ -1,130 +0,0 @@ | |||||||
| --[[- |  | ||||||
| Functions in the global environment, defined in `bios.lua`. This does not |  | ||||||
| include standard Lua functions. |  | ||||||
|  |  | ||||||
| @module _G |  | ||||||
| ]] |  | ||||||
|  |  | ||||||
| --[[- Pauses execution for the specified number of seconds. |  | ||||||
|  |  | ||||||
| As it waits for a fixed amount of world ticks, `time` will automatically be |  | ||||||
| rounded up to the nearest multiple of 0.05 seconds. If you are using coroutines |  | ||||||
| or the @{parallel|parallel API}, it will only pause execution of the current |  | ||||||
| thread, not the whole program. |  | ||||||
|  |  | ||||||
| **Note** Because sleep internally uses timers, it is a function that yields. |  | ||||||
| This means that you can use it to prevent "Too long without yielding" errors, |  | ||||||
| however, as the minimum sleep time is 0.05 seconds, it will slow your program |  | ||||||
| down. |  | ||||||
|  |  | ||||||
| **Warning** Internally, this function queues and waits for a timer event (using |  | ||||||
| @{os.startTimer}), however it does not listen for any other events. This means |  | ||||||
| that any event that occurs while sleeping will be entirely discarded. If you |  | ||||||
| need to receive events while sleeping, consider using @{os.startTimer|timers}, |  | ||||||
| or the @{parallel|parallel API}. |  | ||||||
|  |  | ||||||
| @tparam number time The number of seconds to sleep for, rounded up to the |  | ||||||
| nearest multiple of 0.05. |  | ||||||
|  |  | ||||||
| @see os.startTimer |  | ||||||
| @usage Sleep for three seconds. |  | ||||||
|  |  | ||||||
|     print("Sleeping for three seconds") |  | ||||||
|     sleep(3) |  | ||||||
|     print("Done!") |  | ||||||
| ]] |  | ||||||
| function sleep(time) end |  | ||||||
|  |  | ||||||
| --- Writes a line of text to the screen without a newline at the end, wrapping |  | ||||||
| -- text if necessary. |  | ||||||
| -- |  | ||||||
| -- @tparam string text The text to write to the string |  | ||||||
| -- @treturn number The number of lines written |  | ||||||
| -- @see print A wrapper around write that adds a newline and accepts multiple arguments |  | ||||||
| -- @usage write("Hello, world") |  | ||||||
| function write(text) end |  | ||||||
|  |  | ||||||
| --- Prints the specified values to the screen separated by spaces, wrapping if |  | ||||||
| -- necessary. After printing, the cursor is moved to the next line. |  | ||||||
| -- |  | ||||||
| -- @param ... The values to print on the screen |  | ||||||
| -- @treturn number The number of lines written |  | ||||||
| -- @usage print("Hello, world!") |  | ||||||
| function print(...) end |  | ||||||
|  |  | ||||||
| --- Prints the specified values to the screen in red, separated by spaces, |  | ||||||
| -- wrapping if necessary. After printing, the cursor is moved to the next line. |  | ||||||
| -- |  | ||||||
| -- @param ... The values to print on the screen |  | ||||||
| -- @usage printError("Something went wrong!") |  | ||||||
| function printError(...) end |  | ||||||
|  |  | ||||||
| --[[- Reads user input from the terminal, automatically handling arrow keys, |  | ||||||
| pasting, character replacement, history scrollback, auto-completion, and |  | ||||||
| default values. |  | ||||||
|  |  | ||||||
| @tparam[opt] string replaceChar A character to replace each typed character with. |  | ||||||
| This can be used for hiding passwords, for example. |  | ||||||
| @tparam[opt] table history A table holding history items that can be scrolled |  | ||||||
| back to with the up/down arrow keys. The oldest item is at index 1, while the |  | ||||||
| newest item is at the highest index. |  | ||||||
| @tparam[opt] function(partial: string):({ string... }|nil) completeFn A function |  | ||||||
| to be used for completion. This function should take the partial text typed so |  | ||||||
| far, and returns a list of possible completion options. |  | ||||||
| @tparam[opt] string default Default text which should already be entered into |  | ||||||
| the prompt. |  | ||||||
|  |  | ||||||
| @treturn string The text typed in. |  | ||||||
|  |  | ||||||
| @see cc.completion For functions to help with completion. |  | ||||||
| @usage Read a string and echo it back to the user |  | ||||||
|  |  | ||||||
|     write("> ") |  | ||||||
|     local msg = read() |  | ||||||
|     print(msg) |  | ||||||
|  |  | ||||||
| @usage Prompt a user for a password. |  | ||||||
|  |  | ||||||
|     while true do |  | ||||||
|       write("Password> ") |  | ||||||
|       local pwd = read("*") |  | ||||||
|       if pwd == "let me in" then break end |  | ||||||
|       print("Incorrect password, try again.") |  | ||||||
|     end |  | ||||||
|     print("Logged in!") |  | ||||||
|  |  | ||||||
| @usage A complete example with completion, history and a default value. |  | ||||||
|  |  | ||||||
|     local completion = require "cc.completion" |  | ||||||
|     local history = { "potato", "orange", "apple" } |  | ||||||
|     local choices = { "apple", "orange", "banana", "strawberry" } |  | ||||||
|     write("> ") |  | ||||||
|     local msg = read(nil, history, function(text) return completion.choice(text, choices) end, "app") |  | ||||||
|     print(msg) |  | ||||||
|  |  | ||||||
| @changed 1.74 Added `completeFn` parameter. |  | ||||||
| @changed 1.80pr1 Added `default` parameter. |  | ||||||
| ]] |  | ||||||
| function read(replaceChar, history, completeFn, default) end |  | ||||||
|  |  | ||||||
| --- The ComputerCraft and Minecraft version of the current computer environment. |  | ||||||
| -- |  | ||||||
| -- For example, `ComputerCraft 1.93.0 (Minecraft 1.15.2)`. |  | ||||||
| -- @usage _HOST |  | ||||||
| -- @since 1.76 |  | ||||||
| _HOST = _HOST |  | ||||||
|  |  | ||||||
| --[[- The default computer settings as defined in the ComputerCraft |  | ||||||
| configuration. |  | ||||||
|  |  | ||||||
| This is a comma-separated list of settings pairs defined by the mod |  | ||||||
| configuration or server owner. By default, it is empty. |  | ||||||
|  |  | ||||||
| An example value to disable autocompletion: |  | ||||||
|  |  | ||||||
|     shell.autocomplete=false,lua.autocomplete=false,edit.autocomplete=false |  | ||||||
|  |  | ||||||
| @usage _CC_DEFAULT_SETTINGS |  | ||||||
| @since 1.77 |  | ||||||
| ]] |  | ||||||
| _CC_DEFAULT_SETTINGS = _CC_DEFAULT_SETTINGS |  | ||||||
| @@ -1,157 +0,0 @@ | |||||||
| --- The http library allows communicating with web servers, sending and |  | ||||||
| -- receiving data from them. |  | ||||||
| -- |  | ||||||
| -- @module http |  | ||||||
|  |  | ||||||
| --- Asynchronously make a HTTP request to the given url. |  | ||||||
| -- |  | ||||||
| -- This returns immediately, a [`http_success`](#http-success-event) or |  | ||||||
| -- [`http_failure`](#http-failure-event) will be queued once the request has |  | ||||||
| -- completed. |  | ||||||
| -- |  | ||||||
| -- @tparam      string url   The url to request |  | ||||||
| -- @tparam[opt] string body  An optional string containing the body of the |  | ||||||
| -- request. If specified, a `POST` request will be made instead. |  | ||||||
| -- @tparam[opt] { [string] = string } headers Additional headers to send as part |  | ||||||
| -- of this request. |  | ||||||
| -- @tparam[opt] boolean binary Whether to make a binary HTTP request. If true, |  | ||||||
| -- the body will not be UTF-8 encoded, and the received response will not be |  | ||||||
| -- decoded. |  | ||||||
| -- |  | ||||||
| -- @tparam[2] { |  | ||||||
| --   url = string, body? = string, headers? = { [string] = string }, |  | ||||||
| --   binary? = boolean, method? = string, redirect? = boolean, |  | ||||||
| -- } request Options for the request. |  | ||||||
| -- |  | ||||||
| -- This table form is an expanded version of the previous syntax. All arguments |  | ||||||
| -- from above are passed in as fields instead (for instance, |  | ||||||
| -- `http.request("https://example.com")` becomes `http.request { url = |  | ||||||
| -- "https://example.com" }`). |  | ||||||
| -- |  | ||||||
| -- This table also accepts several additional options: |  | ||||||
| -- |  | ||||||
| --  - `method`: Which HTTP method to use, for instance `"PATCH"` or `"DELETE"`. |  | ||||||
| --  - `redirect`: Whether to follow HTTP redirects. Defaults to true. |  | ||||||
| -- |  | ||||||
| -- @see http.get  For a synchronous way to make GET requests. |  | ||||||
| -- @see http.post For a synchronous way to make POST requests. |  | ||||||
| function request(...) end |  | ||||||
|  |  | ||||||
| --- Make a HTTP GET request to the given url. |  | ||||||
| -- |  | ||||||
| -- @tparam string url   The url to request |  | ||||||
| -- @tparam[opt] { [string] = string } headers Additional headers to send as part |  | ||||||
| -- of this request. |  | ||||||
| -- @tparam[opt] boolean binary Whether to make a binary HTTP request. If true, |  | ||||||
| -- the body will not be UTF-8 encoded, and the received response will not be |  | ||||||
| -- decoded. |  | ||||||
| -- |  | ||||||
| -- @tparam[2] { |  | ||||||
| --   url = string, headers? = { [string] = string }, |  | ||||||
| --   binary? = boolean, method? = string, redirect? = boolean, |  | ||||||
| -- } request Options for the request. See @{http.request} for details on how |  | ||||||
| -- these options behave. |  | ||||||
| -- |  | ||||||
| -- @treturn Response The resulting http response, which can be read from. |  | ||||||
| -- @treturn[2] nil When the http request failed, such as in the event of a 404 |  | ||||||
| -- error or connection timeout. |  | ||||||
| -- @treturn string A message detailing why the request failed. |  | ||||||
| -- @treturn Response|nil The failing http response, if available. |  | ||||||
| -- |  | ||||||
| -- @usage Make a request to [example.tweaked.cc](https://example.tweaked.cc), |  | ||||||
| -- and print the returned page. |  | ||||||
| -- ```lua |  | ||||||
| -- local request = http.get("https://example.tweaked.cc") |  | ||||||
| -- print(request.readAll()) |  | ||||||
| -- -- => HTTP is working! |  | ||||||
| -- request.close() |  | ||||||
| -- ``` |  | ||||||
| function get(...) end |  | ||||||
|  |  | ||||||
| --- Make a HTTP POST request to the given url. |  | ||||||
| -- |  | ||||||
| -- @tparam string url   The url to request |  | ||||||
| -- @tparam string body  The body of the POST request. |  | ||||||
| -- @tparam[opt] { [string] = string } headers Additional headers to send as part |  | ||||||
| -- of this request. |  | ||||||
| -- @tparam[opt] boolean binary Whether to make a binary HTTP request. If true, |  | ||||||
| -- the body will not be UTF-8 encoded, and the received response will not be |  | ||||||
| -- decoded. |  | ||||||
| -- |  | ||||||
| -- @tparam[2] { |  | ||||||
| --   url = string, body? = string, headers? = { [string] = string }, |  | ||||||
| --   binary? = boolean, method? = string, redirect? = boolean, |  | ||||||
| -- } request Options for the request. See @{http.request} for details on how |  | ||||||
| -- these options behave. |  | ||||||
| -- |  | ||||||
| -- @treturn Response The resulting http response, which can be read from. |  | ||||||
| -- @treturn[2] nil When the http request failed, such as in the event of a 404 |  | ||||||
| -- error or connection timeout. |  | ||||||
| -- @treturn string A message detailing why the request failed. |  | ||||||
| -- @treturn Response|nil The failing http response, if available. |  | ||||||
| function post(...) end |  | ||||||
|  |  | ||||||
| --- Asynchronously determine whether a URL can be requested. |  | ||||||
| -- |  | ||||||
| -- If this returns `true`, one should also listen for [`http_check` |  | ||||||
| -- events](#http-check-event) which will container further information about |  | ||||||
| -- whether the URL is allowed or not. |  | ||||||
| -- |  | ||||||
| -- @tparam string url The URL to check. |  | ||||||
| -- @treturn true When this url is not invalid. This does not imply that it is |  | ||||||
| -- allowed - see the comment above. |  | ||||||
| -- @treturn[2] false When this url is invalid. |  | ||||||
| -- @treturn string A reason why this URL is not valid (for instance, if it is |  | ||||||
| -- malformed, or blocked). |  | ||||||
| -- |  | ||||||
| -- @see http.checkURL For a synchronous version. |  | ||||||
| function checkURLAsync(url) end |  | ||||||
|  |  | ||||||
| --- Determine whether a URL can be requested. |  | ||||||
| -- |  | ||||||
| -- If this returns `true`, one should also listen for [`http_check` |  | ||||||
| -- events](#http-check-event) which will container further information about |  | ||||||
| -- whether the URL is allowed or not. |  | ||||||
| -- |  | ||||||
| -- @tparam string url The URL to check. |  | ||||||
| -- @treturn true When this url is valid and can be requested via @{http.request}. |  | ||||||
| -- @treturn[2] false When this url is invalid. |  | ||||||
| -- @treturn string A reason why this URL is not valid (for instance, if it is |  | ||||||
| -- malformed, or blocked). |  | ||||||
| -- |  | ||||||
| -- @see http.checkURLAsync For an asynchronous version. |  | ||||||
| -- |  | ||||||
| -- @usage |  | ||||||
| -- ```lua |  | ||||||
| -- print(http.checkURL("https://example.tweaked.cc/")) |  | ||||||
| -- -- => true |  | ||||||
| -- print(http.checkURL("http://localhost/")) |  | ||||||
| -- -- => false Domain not permitted |  | ||||||
| -- print(http.checkURL("not a url")) |  | ||||||
| -- -- => false URL malformed |  | ||||||
| -- ``` |  | ||||||
| function checkURL(url) end |  | ||||||
|  |  | ||||||
| --- Open a websocket. |  | ||||||
| -- |  | ||||||
| -- @tparam string url The websocket url to connect to. This should have the |  | ||||||
| -- `ws://` or `wss://` protocol. |  | ||||||
| -- @tparam[opt] { [string] = string } headers Additional headers to send as part |  | ||||||
| -- of the initial websocket connection. |  | ||||||
| -- |  | ||||||
| -- @treturn Websocket The websocket connection. |  | ||||||
| -- @treturn[2] false If the websocket connection failed. |  | ||||||
| -- @treturn string An error message describing why the connection failed. |  | ||||||
| function websocket(url, headers) end |  | ||||||
|  |  | ||||||
| --- Asynchronously open a websocket. |  | ||||||
| -- |  | ||||||
| -- This returns immediately, a [`websocket_success`](#websocket-success-event) |  | ||||||
| -- or [`websocket_failure`](#websocket-failure-event) will be queued once the |  | ||||||
| -- request has completed. |  | ||||||
| -- |  | ||||||
| -- @tparam string url The websocket url to connect to. This should have the |  | ||||||
| -- `ws://` or `wss://` protocol. |  | ||||||
| -- @tparam[opt] { [string] = string } headers Additional headers to send as part |  | ||||||
| -- of the initial websocket connection. |  | ||||||
| function websocketAsync(url, headers) end |  | ||||||
							
								
								
									
										125
									
								
								doc/stub/os.lua
									
									
									
									
									
								
							
							
						
						
									
										125
									
								
								doc/stub/os.lua
									
									
									
									
									
								
							| @@ -1,125 +0,0 @@ | |||||||
| -- Defined in bios.lua |  | ||||||
|  |  | ||||||
| --[[- Loads the given API into the global environment. |  | ||||||
|  |  | ||||||
| This function loads and executes the file at the given path, and all global |  | ||||||
| variables and functions exported by it will by available through the use of |  | ||||||
| `myAPI.<function name>`, where `myAPI` is the base name of the API file. |  | ||||||
|  |  | ||||||
| @tparam string path The path of the API to load. |  | ||||||
| @treturn boolean Whether or not the API was successfully loaded. |  | ||||||
|  |  | ||||||
| @deprecated When possible it's best to avoid using this function. It pollutes |  | ||||||
| the global table and can mask errors. |  | ||||||
|  |  | ||||||
| @{require} should be used to load libraries instead. |  | ||||||
| ]] |  | ||||||
| function loadAPI(path) end |  | ||||||
|  |  | ||||||
| --- Unloads an API which was loaded by @{os.loadAPI}. |  | ||||||
| -- |  | ||||||
| -- This effectively removes the specified table from `_G`. |  | ||||||
| -- |  | ||||||
| -- @tparam string name The name of the API to unload. |  | ||||||
| -- @deprecated See @{os.loadAPI} for why. |  | ||||||
| function unloadAPI(name) end |  | ||||||
|  |  | ||||||
| --[[- Pause execution of the current thread and waits for any events matching |  | ||||||
| `filter`. |  | ||||||
|  |  | ||||||
| This function @{coroutine.yield|yields} the current process and waits for it |  | ||||||
| to be resumed with a vararg list where the first element matches `filter`. |  | ||||||
| If no `filter` is supplied, this will match all events. |  | ||||||
|  |  | ||||||
| Unlike @{os.pullEventRaw}, it will stop the application upon a "terminate" |  | ||||||
| event, printing the error "Terminated". |  | ||||||
|  |  | ||||||
| @tparam[opt] string filter Event to filter for. |  | ||||||
| @treturn string event The name of the event that fired. |  | ||||||
| @treturn any param... Optional additional parameters of the event. |  | ||||||
| @usage Listen for `mouse_click` events. |  | ||||||
|  |  | ||||||
|     while true do |  | ||||||
|         local event, button, x, y = os.pullEvent("mouse_click") |  | ||||||
|         print("Button", button, "was clicked at", x, ",", y) |  | ||||||
|     end |  | ||||||
|  |  | ||||||
| @usage Listen for multiple events. |  | ||||||
|  |  | ||||||
|     while true do |  | ||||||
|         local eventData = {os.pullEvent()} |  | ||||||
|         local event = eventData[1] |  | ||||||
|  |  | ||||||
|         if event == "mouse_click" then |  | ||||||
|             print("Button", eventData[2], "was clicked at", eventData[3], ",", eventData[4]) |  | ||||||
|         elseif event == "key" then |  | ||||||
|             print("Key code", eventData[2], "was pressed") |  | ||||||
|         end |  | ||||||
|     end |  | ||||||
|  |  | ||||||
| @see os.pullEventRaw To pull the terminate event. |  | ||||||
| ]] |  | ||||||
| function pullEvent(filter) end |  | ||||||
|  |  | ||||||
| --[[- Pause execution of the current thread and waits for events, including the |  | ||||||
| `terminate` event. |  | ||||||
|  |  | ||||||
| This behaves almost the same as @{os.pullEvent}, except it allows you to handle |  | ||||||
| the `terminate` event yourself - the program will not stop execution when |  | ||||||
| <kbd>Ctrl+T</kbd> is pressed. |  | ||||||
|  |  | ||||||
| @tparam[opt] string filter Event to filter for. |  | ||||||
| @treturn string event The name of the event that fired. |  | ||||||
| @treturn any param... Optional additional parameters of the event. |  | ||||||
| @usage Listen for `terminate` events. |  | ||||||
|  |  | ||||||
|     while true do |  | ||||||
|         local event = os.pullEventRaw() |  | ||||||
|         if event == "terminate" then |  | ||||||
|             print("Caught terminate event!") |  | ||||||
|         end |  | ||||||
|     end |  | ||||||
|  |  | ||||||
| @see os.pullEvent To pull events normally. |  | ||||||
| ]] |  | ||||||
| function pullEventRaw(filter) end |  | ||||||
|  |  | ||||||
| --- Pauses execution for the specified number of seconds, alias of @{_G.sleep}. |  | ||||||
| -- |  | ||||||
| -- @tparam number time The number of seconds to sleep for, rounded up to the |  | ||||||
| -- nearest multiple of 0.05. |  | ||||||
| function sleep(time) end |  | ||||||
|  |  | ||||||
| --- Get the current CraftOS version (for example, `CraftOS 1.8`). |  | ||||||
| -- |  | ||||||
| -- This is defined by `bios.lua`. For the current version of CC:Tweaked, this |  | ||||||
| -- should return `CraftOS 1.8`. |  | ||||||
| -- |  | ||||||
| -- @treturn string The current CraftOS version. |  | ||||||
| -- @usage os.version() |  | ||||||
| function version() end |  | ||||||
|  |  | ||||||
| --[[- Run the program at the given path with the specified environment and |  | ||||||
| arguments. |  | ||||||
|  |  | ||||||
| This function does not resolve program names like the shell does. This means |  | ||||||
| that, for example, `os.run("edit")` will not work. As well as this, it does not |  | ||||||
| provide access to the @{shell} API in the environment. For this behaviour, use |  | ||||||
| @{shell.run} instead. |  | ||||||
|  |  | ||||||
| If the program cannot be found, or failed to run, it will print the error and |  | ||||||
| return `false`. If you want to handle this more gracefully, use an alternative |  | ||||||
| such as @{loadfile}. |  | ||||||
|  |  | ||||||
| @tparam table env The environment to run the program with. |  | ||||||
| @tparam string path The exact path of the program to run. |  | ||||||
| @param ... The arguments to pass to the program. |  | ||||||
| @treturn boolean Whether or not the program ran successfully. |  | ||||||
| @usage Run the default shell from within your program: |  | ||||||
|  |  | ||||||
|     os.run({}, "/rom/programs/shell.lua") |  | ||||||
|  |  | ||||||
| @see shell.run |  | ||||||
| @see loadfile |  | ||||||
| ]] |  | ||||||
| function run(env, path, ...) end |  | ||||||
| @@ -1,13 +0,0 @@ | |||||||
| --[[- Craft a recipe based on the turtle's inventory. |  | ||||||
|  |  | ||||||
| The turtle's inventory should set up like a crafting grid. For instance, to |  | ||||||
| craft sticks, slots 1 and 5 should contain planks. _All_ other slots should be |  | ||||||
| empty, including those outside the crafting "grid". |  | ||||||
|  |  | ||||||
| @tparam[opt=64] number limit The maximum number of crafting steps to run. |  | ||||||
| @throws When limit is less than 1 or greater than 64. |  | ||||||
| @treturn[1] true If crafting succeeds. |  | ||||||
| @treturn[2] false If crafting fails. |  | ||||||
| @treturn string A string describing why crafting failed. |  | ||||||
| ]] |  | ||||||
| function craft(limit) end |  | ||||||
| @@ -1,7 +1,17 @@ | |||||||
| # Mod properties | # Done to increase the memory available to gradle. | ||||||
| mod_version=1.98.1 | org.gradle.jvmargs=-Xmx1G | ||||||
|  |  | ||||||
| # Minecraft properties (update mods.toml when changing) | # Mod properties | ||||||
| mc_version=1.16.5 | mod_version=1.91.1 | ||||||
| forge_version=36.1.0 |  | ||||||
| # NO SERIOUSLY, UPDATE mods.toml WHEN CHANGING | # Minecraft properties | ||||||
|  | mc_version=1.16.2 | ||||||
|  | mappings_version=31 | ||||||
|  |  | ||||||
|  | # Dependencies | ||||||
|  | cloth_config_version=4.8.1 | ||||||
|  | fabric_api_version=0.19.0+build.398-1.16 | ||||||
|  | fabric_loader_version=0.9.2+build.206 | ||||||
|  | jankson_version=1.2.0 | ||||||
|  | modmenu_version=1.14.6+ | ||||||
|  | cloth_api_version=1.4.5 | ||||||
|   | |||||||
							
								
								
									
										
											BIN
										
									
								
								gradle/wrapper/gradle-wrapper.jar
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										
											BIN
										
									
								
								gradle/wrapper/gradle-wrapper.jar
									
									
									
									
										vendored
									
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										5
									
								
								gradle/wrapper/gradle-wrapper.properties
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										5
									
								
								gradle/wrapper/gradle-wrapper.properties
									
									
									
									
										vendored
									
									
								
							| @@ -1,5 +1,6 @@ | |||||||
|  | #Tue Jul 07 13:15:43 EDT 2020 | ||||||
|  | distributionUrl=https\://services.gradle.org/distributions/gradle-6.6.1-all.zip | ||||||
| distributionBase=GRADLE_USER_HOME | distributionBase=GRADLE_USER_HOME | ||||||
| distributionPath=wrapper/dists | distributionPath=wrapper/dists | ||||||
| distributionUrl=https\://services.gradle.org/distributions/gradle-7.1-bin.zip |  | ||||||
| zipStoreBase=GRADLE_USER_HOME |  | ||||||
| zipStorePath=wrapper/dists | zipStorePath=wrapper/dists | ||||||
|  | zipStoreBase=GRADLE_USER_HOME | ||||||
|   | |||||||
							
								
								
									
										53
									
								
								gradlew
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										53
									
								
								gradlew
									
									
									
									
										vendored
									
									
								
							| @@ -1,21 +1,5 @@ | |||||||
| #!/usr/bin/env sh | #!/usr/bin/env sh | ||||||
|  |  | ||||||
| # |  | ||||||
| # Copyright 2015 the original author or authors. |  | ||||||
| # |  | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); |  | ||||||
| # you may not use this file except in compliance with the License. |  | ||||||
| # You may obtain a copy of the License at |  | ||||||
| # |  | ||||||
| #      https://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| # |  | ||||||
| # Unless required by applicable law or agreed to in writing, software |  | ||||||
| # distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| # See the License for the specific language governing permissions and |  | ||||||
| # limitations under the License. |  | ||||||
| # |  | ||||||
|  |  | ||||||
| ############################################################################## | ############################################################################## | ||||||
| ## | ## | ||||||
| ##  Gradle start up script for UN*X | ##  Gradle start up script for UN*X | ||||||
| @@ -44,7 +28,7 @@ APP_NAME="Gradle" | |||||||
| APP_BASE_NAME=`basename "$0"` | APP_BASE_NAME=`basename "$0"` | ||||||
|  |  | ||||||
| # Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. | # Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. | ||||||
| DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"' | DEFAULT_JVM_OPTS="" | ||||||
|  |  | ||||||
| # Use the maximum available, or set MAX_FD != -1 to use that value. | # Use the maximum available, or set MAX_FD != -1 to use that value. | ||||||
| MAX_FD="maximum" | MAX_FD="maximum" | ||||||
| @@ -82,7 +66,6 @@ esac | |||||||
|  |  | ||||||
| CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar | CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar | ||||||
|  |  | ||||||
|  |  | ||||||
| # Determine the Java command to use to start the JVM. | # Determine the Java command to use to start the JVM. | ||||||
| if [ -n "$JAVA_HOME" ] ; then | if [ -n "$JAVA_HOME" ] ; then | ||||||
|     if [ -x "$JAVA_HOME/jre/sh/java" ] ; then |     if [ -x "$JAVA_HOME/jre/sh/java" ] ; then | ||||||
| @@ -126,11 +109,10 @@ if $darwin; then | |||||||
|     GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\"" |     GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\"" | ||||||
| fi | fi | ||||||
|  |  | ||||||
| # For Cygwin or MSYS, switch paths to Windows format before running java | # For Cygwin, switch paths to Windows format before running java | ||||||
| if [ "$cygwin" = "true" -o "$msys" = "true" ] ; then | if $cygwin ; then | ||||||
|     APP_HOME=`cygpath --path --mixed "$APP_HOME"` |     APP_HOME=`cygpath --path --mixed "$APP_HOME"` | ||||||
|     CLASSPATH=`cygpath --path --mixed "$CLASSPATH"` |     CLASSPATH=`cygpath --path --mixed "$CLASSPATH"` | ||||||
|  |  | ||||||
|     JAVACMD=`cygpath --unix "$JAVACMD"` |     JAVACMD=`cygpath --unix "$JAVACMD"` | ||||||
|  |  | ||||||
|     # We build the pattern for arguments to be converted via cygpath |     # We build the pattern for arguments to be converted via cygpath | ||||||
| @@ -156,19 +138,19 @@ if [ "$cygwin" = "true" -o "$msys" = "true" ] ; then | |||||||
|         else |         else | ||||||
|             eval `echo args$i`="\"$arg\"" |             eval `echo args$i`="\"$arg\"" | ||||||
|         fi |         fi | ||||||
|         i=`expr $i + 1` |         i=$((i+1)) | ||||||
|     done |     done | ||||||
|     case $i in |     case $i in | ||||||
|         0) set -- ;; |         (0) set -- ;; | ||||||
|         1) set -- "$args0" ;; |         (1) set -- "$args0" ;; | ||||||
|         2) set -- "$args0" "$args1" ;; |         (2) set -- "$args0" "$args1" ;; | ||||||
|         3) set -- "$args0" "$args1" "$args2" ;; |         (3) set -- "$args0" "$args1" "$args2" ;; | ||||||
|         4) set -- "$args0" "$args1" "$args2" "$args3" ;; |         (4) set -- "$args0" "$args1" "$args2" "$args3" ;; | ||||||
|         5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;; |         (5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;; | ||||||
|         6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;; |         (6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;; | ||||||
|         7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;; |         (7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;; | ||||||
|         8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;; |         (8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;; | ||||||
|         9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;; |         (9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;; | ||||||
|     esac |     esac | ||||||
| fi | fi | ||||||
|  |  | ||||||
| @@ -177,9 +159,14 @@ save () { | |||||||
|     for i do printf %s\\n "$i" | sed "s/'/'\\\\''/g;1s/^/'/;\$s/\$/' \\\\/" ; done |     for i do printf %s\\n "$i" | sed "s/'/'\\\\''/g;1s/^/'/;\$s/\$/' \\\\/" ; done | ||||||
|     echo " " |     echo " " | ||||||
| } | } | ||||||
| APP_ARGS=`save "$@"` | APP_ARGS=$(save "$@") | ||||||
|  |  | ||||||
| # Collect all arguments for the java command, following the shell quoting and substitution rules | # Collect all arguments for the java command, following the shell quoting and substitution rules | ||||||
| eval set -- $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS "\"-Dorg.gradle.appname=$APP_BASE_NAME\"" -classpath "\"$CLASSPATH\"" org.gradle.wrapper.GradleWrapperMain "$APP_ARGS" | eval set -- $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS "\"-Dorg.gradle.appname=$APP_BASE_NAME\"" -classpath "\"$CLASSPATH\"" org.gradle.wrapper.GradleWrapperMain "$APP_ARGS" | ||||||
|  |  | ||||||
|  | # by default we should be in the correct project dir, but when run from Finder on Mac, the cwd is wrong | ||||||
|  | if [ "$(uname)" = "Darwin" ] && [ "$HOME" = "$PWD" ]; then | ||||||
|  |   cd "$(dirname "$0")" | ||||||
|  | fi | ||||||
|  |  | ||||||
| exec "$JAVACMD" "$@" | exec "$JAVACMD" "$@" | ||||||
|   | |||||||
							
								
								
									
										43
									
								
								gradlew.bat
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										43
									
								
								gradlew.bat
									
									
									
									
										vendored
									
									
								
							| @@ -1,19 +1,3 @@ | |||||||
| @rem |  | ||||||
| @rem Copyright 2015 the original author or authors. |  | ||||||
| @rem |  | ||||||
| @rem Licensed under the Apache License, Version 2.0 (the "License"); |  | ||||||
| @rem you may not use this file except in compliance with the License. |  | ||||||
| @rem You may obtain a copy of the License at |  | ||||||
| @rem |  | ||||||
| @rem      https://www.apache.org/licenses/LICENSE-2.0 |  | ||||||
| @rem |  | ||||||
| @rem Unless required by applicable law or agreed to in writing, software |  | ||||||
| @rem distributed under the License is distributed on an "AS IS" BASIS, |  | ||||||
| @rem WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |  | ||||||
| @rem See the License for the specific language governing permissions and |  | ||||||
| @rem limitations under the License. |  | ||||||
| @rem |  | ||||||
|  |  | ||||||
| @if "%DEBUG%" == "" @echo off | @if "%DEBUG%" == "" @echo off | ||||||
| @rem ########################################################################## | @rem ########################################################################## | ||||||
| @rem | @rem | ||||||
| @@ -29,18 +13,15 @@ if "%DIRNAME%" == "" set DIRNAME=. | |||||||
| set APP_BASE_NAME=%~n0 | set APP_BASE_NAME=%~n0 | ||||||
| set APP_HOME=%DIRNAME% | set APP_HOME=%DIRNAME% | ||||||
|  |  | ||||||
| @rem Resolve any "." and ".." in APP_HOME to make it shorter. |  | ||||||
| for %%i in ("%APP_HOME%") do set APP_HOME=%%~fi |  | ||||||
|  |  | ||||||
| @rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. | @rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. | ||||||
| set DEFAULT_JVM_OPTS="-Xmx64m" "-Xms64m" | set DEFAULT_JVM_OPTS= | ||||||
|  |  | ||||||
| @rem Find java.exe | @rem Find java.exe | ||||||
| if defined JAVA_HOME goto findJavaFromJavaHome | if defined JAVA_HOME goto findJavaFromJavaHome | ||||||
|  |  | ||||||
| set JAVA_EXE=java.exe | set JAVA_EXE=java.exe | ||||||
| %JAVA_EXE% -version >NUL 2>&1 | %JAVA_EXE% -version >NUL 2>&1 | ||||||
| if "%ERRORLEVEL%" == "0" goto execute | if "%ERRORLEVEL%" == "0" goto init | ||||||
|  |  | ||||||
| echo. | echo. | ||||||
| echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. | echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. | ||||||
| @@ -54,7 +35,7 @@ goto fail | |||||||
| set JAVA_HOME=%JAVA_HOME:"=% | set JAVA_HOME=%JAVA_HOME:"=% | ||||||
| set JAVA_EXE=%JAVA_HOME%/bin/java.exe | set JAVA_EXE=%JAVA_HOME%/bin/java.exe | ||||||
|  |  | ||||||
| if exist "%JAVA_EXE%" goto execute | if exist "%JAVA_EXE%" goto init | ||||||
|  |  | ||||||
| echo. | echo. | ||||||
| echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% | echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% | ||||||
| @@ -64,14 +45,28 @@ echo location of your Java installation. | |||||||
|  |  | ||||||
| goto fail | goto fail | ||||||
|  |  | ||||||
|  | :init | ||||||
|  | @rem Get command-line arguments, handling Windows variants | ||||||
|  |  | ||||||
|  | if not "%OS%" == "Windows_NT" goto win9xME_args | ||||||
|  |  | ||||||
|  | :win9xME_args | ||||||
|  | @rem Slurp the command line arguments. | ||||||
|  | set CMD_LINE_ARGS= | ||||||
|  | set _SKIP=2 | ||||||
|  |  | ||||||
|  | :win9xME_args_slurp | ||||||
|  | if "x%~1" == "x" goto execute | ||||||
|  |  | ||||||
|  | set CMD_LINE_ARGS=%* | ||||||
|  |  | ||||||
| :execute | :execute | ||||||
| @rem Setup the command line | @rem Setup the command line | ||||||
|  |  | ||||||
| set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar | set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar | ||||||
|  |  | ||||||
|  |  | ||||||
| @rem Execute Gradle | @rem Execute Gradle | ||||||
| "%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %* | "%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %CMD_LINE_ARGS% | ||||||
|  |  | ||||||
| :end | :end | ||||||
| @rem End local scope for the variables with windows NT shell | @rem End local scope for the variables with windows NT shell | ||||||
|   | |||||||
							
								
								
									
										112
									
								
								illuaminate.sexp
									
									
									
									
									
								
							
							
						
						
									
										112
									
								
								illuaminate.sexp
									
									
									
									
									
								
							| @@ -1,112 +0,0 @@ | |||||||
| ; -*- mode: Lisp;-*- |  | ||||||
|  |  | ||||||
| (sources |  | ||||||
|   /doc/stub/ |  | ||||||
|   /doc/events/ |  | ||||||
|   /build/docs/luaJavadoc/ |  | ||||||
|   /src/main/resources/*/computercraft/lua/bios.lua |  | ||||||
|   /src/main/resources/*/computercraft/lua/rom/ |  | ||||||
|   /src/test/resources/test-rom |  | ||||||
|   /src/web/mount) |  | ||||||
|  |  | ||||||
|  |  | ||||||
| (doc |  | ||||||
|   (destination build/docs/lua) |  | ||||||
|   (index doc/index.md) |  | ||||||
|  |  | ||||||
|   (site |  | ||||||
|     (title "CC: Tweaked") |  | ||||||
|     (logo src/main/resources/pack.png) |  | ||||||
|     (url https://tweaked.cc/) |  | ||||||
|     (source-link https://github.com/SquidDev-CC/CC-Tweaked/blob/${commit}/${path}#L${line}) |  | ||||||
|  |  | ||||||
|     (styles src/web/styles.css) |  | ||||||
|     (scripts build/rollup/index.js) |  | ||||||
|     (head doc/head.html)) |  | ||||||
|  |  | ||||||
|   (module-kinds |  | ||||||
|     (peripheral Peripherals) |  | ||||||
|     (generic_peripheral "Generic Peripherals") |  | ||||||
|     (event Events)) |  | ||||||
|  |  | ||||||
|   (library-path |  | ||||||
|     /doc/stub/ |  | ||||||
|     /build/docs/luaJavadoc/ |  | ||||||
|  |  | ||||||
|     /src/main/resources/*/computercraft/lua/rom/apis/ |  | ||||||
|     /src/main/resources/*/computercraft/lua/rom/apis/command/ |  | ||||||
|     /src/main/resources/*/computercraft/lua/rom/apis/turtle/ |  | ||||||
|  |  | ||||||
|     /src/main/resources/*/computercraft/lua/rom/modules/main/ |  | ||||||
|     /src/main/resources/*/computercraft/lua/rom/modules/command/ |  | ||||||
|     /src/main/resources/*/computercraft/lua/rom/modules/turtle/)) |  | ||||||
|  |  | ||||||
| (at / |  | ||||||
|   (linters |  | ||||||
|     syntax:string-index |  | ||||||
|  |  | ||||||
|     ;; It'd be nice to avoid this, but right now there's a lot of instances of |  | ||||||
|     ;; it. |  | ||||||
|     -var:set-loop |  | ||||||
|  |  | ||||||
|     ;; It's useful to name arguments for documentation, so we allow this. It'd |  | ||||||
|     ;; be good to find a compromise in the future, but this works for now. |  | ||||||
|     -var:unused-arg) |  | ||||||
|  |  | ||||||
|   (lint |  | ||||||
|     (bracket-spaces |  | ||||||
|       (call no-space) |  | ||||||
|       (function-args no-space) |  | ||||||
|       (parens no-space) |  | ||||||
|       (table space) |  | ||||||
|       (index no-space)) |  | ||||||
|  |  | ||||||
|     ;; colours imports from colors, and we don't handle that right now. |  | ||||||
|     ;; keys is entirely dynamic, so we skip it. |  | ||||||
|     (dynamic-modules colours keys _G) |  | ||||||
|  |  | ||||||
|     (globals |  | ||||||
|       :max |  | ||||||
|       _CC_DEFAULT_SETTINGS |  | ||||||
|       _CC_DISABLE_LUA51_FEATURES |  | ||||||
|       ;; Ideally we'd pick these up from bios.lua, but illuaminate currently |  | ||||||
|       ;; isn't smart enough. |  | ||||||
|       sleep write printError read rs))) |  | ||||||
|  |  | ||||||
| ;; We disable the unused global linter in bios.lua and the APIs. In the future |  | ||||||
| ;; hopefully we'll get illuaminate to handle this. |  | ||||||
| (at |  | ||||||
|   (/src/main/resources/*/computercraft/lua/bios.lua |  | ||||||
|    /src/main/resources/*/computercraft/lua/rom/apis/) |  | ||||||
|   (linters -var:unused-global) |  | ||||||
|   (lint (allow-toplevel-global true))) |  | ||||||
|  |  | ||||||
| ;; Silence some variable warnings in documentation stubs. |  | ||||||
| (at (/doc/stub/ /build/docs/luaJavadoc/) |  | ||||||
|   (linters -var:unused-global) |  | ||||||
|   (lint (allow-toplevel-global true))) |  | ||||||
|  |  | ||||||
| ;; Suppress warnings for currently undocumented modules. |  | ||||||
| (at |  | ||||||
|   (; Lua APIs |  | ||||||
|    /src/main/resources/*/computercraft/lua/rom/apis/io.lua |  | ||||||
|    /src/main/resources/*/computercraft/lua/rom/apis/window.lua) |  | ||||||
|  |  | ||||||
|   (linters -doc:undocumented -doc:undocumented-arg -doc:undocumented-return)) |  | ||||||
|  |  | ||||||
| ;; Suppress warnings for various APIs using its own deprecated members. |  | ||||||
| (at |  | ||||||
|   (/src/main/resources/*/computercraft/lua/bios.lua |  | ||||||
|    /src/main/resources/*/computercraft/lua/rom/apis/turtle/turtle.lua) |  | ||||||
|   (linters -var:deprecated)) |  | ||||||
|  |  | ||||||
| (at /src/test/resources/test-rom |  | ||||||
|   ; We should still be able to test deprecated members. |  | ||||||
|   (linters -var:deprecated) |  | ||||||
|  |  | ||||||
|   (lint |  | ||||||
|     (globals |  | ||||||
|       :max sleep write |  | ||||||
|       cct_test describe expect howlci fail it pending stub))) |  | ||||||
|  |  | ||||||
| (at /src/web/mount/expr_template.lua (lint (globals :max __expr__))) |  | ||||||
| Before Width: | Height: | Size: 2.2 KiB After Width: | Height: | Size: 2.2 KiB | 
							
								
								
									
										402
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										402
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							| @@ -1,402 +0,0 @@ | |||||||
| { |  | ||||||
|   "name": "tweaked.cc", |  | ||||||
|   "version": "1.0.0", |  | ||||||
|   "lockfileVersion": 2, |  | ||||||
|   "requires": true, |  | ||||||
|   "packages": { |  | ||||||
|     "": { |  | ||||||
|       "name": "tweaked.cc", |  | ||||||
|       "version": "1.0.0", |  | ||||||
|       "license": "BSD-3-Clause", |  | ||||||
|       "dependencies": { |  | ||||||
|         "preact": "^10.5.5", |  | ||||||
|         "tslib": "^2.0.3" |  | ||||||
|       }, |  | ||||||
|       "devDependencies": { |  | ||||||
|         "@rollup/plugin-typescript": "^6.1.0", |  | ||||||
|         "requirejs": "^2.3.6", |  | ||||||
|         "rollup": "^2.33.1", |  | ||||||
|         "terser": "^5.3.8", |  | ||||||
|         "typescript": "^4.0.5" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "node_modules/@rollup/plugin-typescript": { |  | ||||||
|       "version": "6.1.0", |  | ||||||
|       "resolved": "https://registry.npmjs.org/@rollup/plugin-typescript/-/plugin-typescript-6.1.0.tgz", |  | ||||||
|       "integrity": "sha512-hJxaiE6WyNOsK+fZpbFh9CUijZYqPQuAOWO5khaGTUkM8DYNNyA2TDlgamecE+qLOG1G1+CwbWMAx3rbqpp6xQ==", |  | ||||||
|       "dev": true, |  | ||||||
|       "dependencies": { |  | ||||||
|         "@rollup/pluginutils": "^3.1.0", |  | ||||||
|         "resolve": "^1.17.0" |  | ||||||
|       }, |  | ||||||
|       "engines": { |  | ||||||
|         "node": ">=8.0.0" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "node_modules/@rollup/pluginutils": { |  | ||||||
|       "version": "3.1.0", |  | ||||||
|       "resolved": "https://registry.npmjs.org/@rollup/pluginutils/-/pluginutils-3.1.0.tgz", |  | ||||||
|       "integrity": "sha512-GksZ6pr6TpIjHm8h9lSQ8pi8BE9VeubNT0OMJ3B5uZJ8pz73NPiqOtCog/x2/QzM1ENChPKxMDhiQuRHsqc+lg==", |  | ||||||
|       "dev": true, |  | ||||||
|       "dependencies": { |  | ||||||
|         "@types/estree": "0.0.39", |  | ||||||
|         "estree-walker": "^1.0.1", |  | ||||||
|         "picomatch": "^2.2.2" |  | ||||||
|       }, |  | ||||||
|       "engines": { |  | ||||||
|         "node": ">= 8.0.0" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "node_modules/@types/estree": { |  | ||||||
|       "version": "0.0.39", |  | ||||||
|       "resolved": "https://registry.npmjs.org/@types/estree/-/estree-0.0.39.tgz", |  | ||||||
|       "integrity": "sha512-EYNwp3bU+98cpU4lAWYYL7Zz+2gryWH1qbdDTidVd6hkiR6weksdbMadyXKXNPEkQFhXM+hVO9ZygomHXp+AIw==", |  | ||||||
|       "dev": true |  | ||||||
|     }, |  | ||||||
|     "node_modules/buffer-from": { |  | ||||||
|       "version": "1.1.1", |  | ||||||
|       "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.1.tgz", |  | ||||||
|       "integrity": "sha512-MQcXEUbCKtEo7bhqEs6560Hyd4XaovZlO/k9V3hjVUF/zwW7KBVdSK4gIt/bzwS9MbR5qob+F5jusZsb0YQK2A==", |  | ||||||
|       "dev": true |  | ||||||
|     }, |  | ||||||
|     "node_modules/commander": { |  | ||||||
|       "version": "2.20.3", |  | ||||||
|       "resolved": "https://registry.npmjs.org/commander/-/commander-2.20.3.tgz", |  | ||||||
|       "integrity": "sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ==", |  | ||||||
|       "dev": true |  | ||||||
|     }, |  | ||||||
|     "node_modules/estree-walker": { |  | ||||||
|       "version": "1.0.1", |  | ||||||
|       "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-1.0.1.tgz", |  | ||||||
|       "integrity": "sha512-1fMXF3YP4pZZVozF8j/ZLfvnR8NSIljt56UhbZ5PeeDmmGHpgpdwQt7ITlGvYaQukCvuBRMLEiKiYC+oeIg4cg==", |  | ||||||
|       "dev": true |  | ||||||
|     }, |  | ||||||
|     "node_modules/fsevents": { |  | ||||||
|       "version": "2.1.3", |  | ||||||
|       "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.1.3.tgz", |  | ||||||
|       "integrity": "sha512-Auw9a4AxqWpa9GUfj370BMPzzyncfBABW8Mab7BGWBYDj4Isgq+cDKtx0i6u9jcX9pQDnswsaaOTgTmA5pEjuQ==", |  | ||||||
|       "dev": true, |  | ||||||
|       "optional": true, |  | ||||||
|       "os": [ |  | ||||||
|         "darwin" |  | ||||||
|       ], |  | ||||||
|       "engines": { |  | ||||||
|         "node": "^8.16.0 || ^10.6.0 || >=11.0.0" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "node_modules/function-bind": { |  | ||||||
|       "version": "1.1.1", |  | ||||||
|       "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", |  | ||||||
|       "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", |  | ||||||
|       "dev": true |  | ||||||
|     }, |  | ||||||
|     "node_modules/has": { |  | ||||||
|       "version": "1.0.3", |  | ||||||
|       "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", |  | ||||||
|       "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", |  | ||||||
|       "dev": true, |  | ||||||
|       "dependencies": { |  | ||||||
|         "function-bind": "^1.1.1" |  | ||||||
|       }, |  | ||||||
|       "engines": { |  | ||||||
|         "node": ">= 0.4.0" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "node_modules/is-core-module": { |  | ||||||
|       "version": "2.1.0", |  | ||||||
|       "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.1.0.tgz", |  | ||||||
|       "integrity": "sha512-YcV7BgVMRFRua2FqQzKtTDMz8iCuLEyGKjr70q8Zm1yy2qKcurbFEd79PAdHV77oL3NrAaOVQIbMmiHQCHB7ZA==", |  | ||||||
|       "dev": true, |  | ||||||
|       "dependencies": { |  | ||||||
|         "has": "^1.0.3" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "node_modules/path-parse": { |  | ||||||
|       "version": "1.0.6", |  | ||||||
|       "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.6.tgz", |  | ||||||
|       "integrity": "sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==", |  | ||||||
|       "dev": true |  | ||||||
|     }, |  | ||||||
|     "node_modules/picomatch": { |  | ||||||
|       "version": "2.2.2", |  | ||||||
|       "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.2.2.tgz", |  | ||||||
|       "integrity": "sha512-q0M/9eZHzmr0AulXyPwNfZjtwZ/RBZlbN3K3CErVrk50T2ASYI7Bye0EvekFY3IP1Nt2DHu0re+V2ZHIpMkuWg==", |  | ||||||
|       "dev": true, |  | ||||||
|       "engines": { |  | ||||||
|         "node": ">=8.6" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "node_modules/preact": { |  | ||||||
|       "version": "10.5.5", |  | ||||||
|       "resolved": "https://registry.npmjs.org/preact/-/preact-10.5.5.tgz", |  | ||||||
|       "integrity": "sha512-5ONLNH1SXMzzbQoExZX4TELemNt+TEDb622xXFNfZngjjM9qtrzseJt+EfiUu4TZ6EJ95X5sE1ES4yqHFSIdhg==" |  | ||||||
|     }, |  | ||||||
|     "node_modules/requirejs": { |  | ||||||
|       "version": "2.3.6", |  | ||||||
|       "resolved": "https://registry.npmjs.org/requirejs/-/requirejs-2.3.6.tgz", |  | ||||||
|       "integrity": "sha512-ipEzlWQe6RK3jkzikgCupiTbTvm4S0/CAU5GlgptkN5SO6F3u0UD0K18wy6ErDqiCyP4J4YYe1HuAShvsxePLg==", |  | ||||||
|       "dev": true, |  | ||||||
|       "bin": { |  | ||||||
|         "r_js": "bin/r.js", |  | ||||||
|         "r.js": "bin/r.js" |  | ||||||
|       }, |  | ||||||
|       "engines": { |  | ||||||
|         "node": ">=0.4.0" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "node_modules/resolve": { |  | ||||||
|       "version": "1.18.1", |  | ||||||
|       "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.18.1.tgz", |  | ||||||
|       "integrity": "sha512-lDfCPaMKfOJXjy0dPayzPdF1phampNWr3qFCjAu+rw/qbQmr5jWH5xN2hwh9QKfw9E5v4hwV7A+jrCmL8yjjqA==", |  | ||||||
|       "dev": true, |  | ||||||
|       "dependencies": { |  | ||||||
|         "is-core-module": "^2.0.0", |  | ||||||
|         "path-parse": "^1.0.6" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "node_modules/rollup": { |  | ||||||
|       "version": "2.33.1", |  | ||||||
|       "resolved": "https://registry.npmjs.org/rollup/-/rollup-2.33.1.tgz", |  | ||||||
|       "integrity": "sha512-uY4O/IoL9oNW8MMcbA5hcOaz6tZTMIh7qJHx/tzIJm+n1wLoY38BLn6fuy7DhR57oNFLMbDQtDeJoFURt5933w==", |  | ||||||
|       "dev": true, |  | ||||||
|       "bin": { |  | ||||||
|         "rollup": "dist/bin/rollup" |  | ||||||
|       }, |  | ||||||
|       "engines": { |  | ||||||
|         "node": ">=10.0.0" |  | ||||||
|       }, |  | ||||||
|       "optionalDependencies": { |  | ||||||
|         "fsevents": "~2.1.2" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "node_modules/source-map": { |  | ||||||
|       "version": "0.7.3", |  | ||||||
|       "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.7.3.tgz", |  | ||||||
|       "integrity": "sha512-CkCj6giN3S+n9qrYiBTX5gystlENnRW5jZeNLHpe6aue+SrHcG5VYwujhW9s4dY31mEGsxBDrHR6oI69fTXsaQ==", |  | ||||||
|       "dev": true, |  | ||||||
|       "engines": { |  | ||||||
|         "node": ">= 8" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "node_modules/source-map-support": { |  | ||||||
|       "version": "0.5.19", |  | ||||||
|       "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.19.tgz", |  | ||||||
|       "integrity": "sha512-Wonm7zOCIJzBGQdB+thsPar0kYuCIzYvxZwlBa87yi/Mdjv7Tip2cyVbLj5o0cFPN4EVkuTwb3GDDyUx2DGnGw==", |  | ||||||
|       "dev": true, |  | ||||||
|       "dependencies": { |  | ||||||
|         "buffer-from": "^1.0.0", |  | ||||||
|         "source-map": "^0.6.0" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "node_modules/source-map-support/node_modules/source-map": { |  | ||||||
|       "version": "0.6.1", |  | ||||||
|       "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", |  | ||||||
|       "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", |  | ||||||
|       "dev": true, |  | ||||||
|       "engines": { |  | ||||||
|         "node": ">=0.10.0" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "node_modules/terser": { |  | ||||||
|       "version": "5.3.8", |  | ||||||
|       "resolved": "https://registry.npmjs.org/terser/-/terser-5.3.8.tgz", |  | ||||||
|       "integrity": "sha512-zVotuHoIfnYjtlurOouTazciEfL7V38QMAOhGqpXDEg6yT13cF4+fEP9b0rrCEQTn+tT46uxgFsTZzhygk+CzQ==", |  | ||||||
|       "dev": true, |  | ||||||
|       "dependencies": { |  | ||||||
|         "commander": "^2.20.0", |  | ||||||
|         "source-map": "~0.7.2", |  | ||||||
|         "source-map-support": "~0.5.19" |  | ||||||
|       }, |  | ||||||
|       "bin": { |  | ||||||
|         "terser": "bin/terser" |  | ||||||
|       }, |  | ||||||
|       "engines": { |  | ||||||
|         "node": ">=10" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "node_modules/tslib": { |  | ||||||
|       "version": "2.0.3", |  | ||||||
|       "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.0.3.tgz", |  | ||||||
|       "integrity": "sha512-uZtkfKblCEQtZKBF6EBXVZeQNl82yqtDQdv+eck8u7tdPxjLu2/lp5/uPW+um2tpuxINHWy3GhiccY7QgEaVHQ==" |  | ||||||
|     }, |  | ||||||
|     "node_modules/typescript": { |  | ||||||
|       "version": "4.0.5", |  | ||||||
|       "resolved": "https://registry.npmjs.org/typescript/-/typescript-4.0.5.tgz", |  | ||||||
|       "integrity": "sha512-ywmr/VrTVCmNTJ6iV2LwIrfG1P+lv6luD8sUJs+2eI9NLGigaN+nUQc13iHqisq7bra9lnmUSYqbJvegraBOPQ==", |  | ||||||
|       "dev": true, |  | ||||||
|       "bin": { |  | ||||||
|         "tsc": "bin/tsc", |  | ||||||
|         "tsserver": "bin/tsserver" |  | ||||||
|       }, |  | ||||||
|       "engines": { |  | ||||||
|         "node": ">=4.2.0" |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|   }, |  | ||||||
|   "dependencies": { |  | ||||||
|     "@rollup/plugin-typescript": { |  | ||||||
|       "version": "6.1.0", |  | ||||||
|       "resolved": "https://registry.npmjs.org/@rollup/plugin-typescript/-/plugin-typescript-6.1.0.tgz", |  | ||||||
|       "integrity": "sha512-hJxaiE6WyNOsK+fZpbFh9CUijZYqPQuAOWO5khaGTUkM8DYNNyA2TDlgamecE+qLOG1G1+CwbWMAx3rbqpp6xQ==", |  | ||||||
|       "dev": true, |  | ||||||
|       "requires": { |  | ||||||
|         "@rollup/pluginutils": "^3.1.0", |  | ||||||
|         "resolve": "^1.17.0" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "@rollup/pluginutils": { |  | ||||||
|       "version": "3.1.0", |  | ||||||
|       "resolved": "https://registry.npmjs.org/@rollup/pluginutils/-/pluginutils-3.1.0.tgz", |  | ||||||
|       "integrity": "sha512-GksZ6pr6TpIjHm8h9lSQ8pi8BE9VeubNT0OMJ3B5uZJ8pz73NPiqOtCog/x2/QzM1ENChPKxMDhiQuRHsqc+lg==", |  | ||||||
|       "dev": true, |  | ||||||
|       "requires": { |  | ||||||
|         "@types/estree": "0.0.39", |  | ||||||
|         "estree-walker": "^1.0.1", |  | ||||||
|         "picomatch": "^2.2.2" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "@types/estree": { |  | ||||||
|       "version": "0.0.39", |  | ||||||
|       "resolved": "https://registry.npmjs.org/@types/estree/-/estree-0.0.39.tgz", |  | ||||||
|       "integrity": "sha512-EYNwp3bU+98cpU4lAWYYL7Zz+2gryWH1qbdDTidVd6hkiR6weksdbMadyXKXNPEkQFhXM+hVO9ZygomHXp+AIw==", |  | ||||||
|       "dev": true |  | ||||||
|     }, |  | ||||||
|     "buffer-from": { |  | ||||||
|       "version": "1.1.1", |  | ||||||
|       "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.1.tgz", |  | ||||||
|       "integrity": "sha512-MQcXEUbCKtEo7bhqEs6560Hyd4XaovZlO/k9V3hjVUF/zwW7KBVdSK4gIt/bzwS9MbR5qob+F5jusZsb0YQK2A==", |  | ||||||
|       "dev": true |  | ||||||
|     }, |  | ||||||
|     "commander": { |  | ||||||
|       "version": "2.20.3", |  | ||||||
|       "resolved": "https://registry.npmjs.org/commander/-/commander-2.20.3.tgz", |  | ||||||
|       "integrity": "sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ==", |  | ||||||
|       "dev": true |  | ||||||
|     }, |  | ||||||
|     "estree-walker": { |  | ||||||
|       "version": "1.0.1", |  | ||||||
|       "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-1.0.1.tgz", |  | ||||||
|       "integrity": "sha512-1fMXF3YP4pZZVozF8j/ZLfvnR8NSIljt56UhbZ5PeeDmmGHpgpdwQt7ITlGvYaQukCvuBRMLEiKiYC+oeIg4cg==", |  | ||||||
|       "dev": true |  | ||||||
|     }, |  | ||||||
|     "fsevents": { |  | ||||||
|       "version": "2.1.3", |  | ||||||
|       "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.1.3.tgz", |  | ||||||
|       "integrity": "sha512-Auw9a4AxqWpa9GUfj370BMPzzyncfBABW8Mab7BGWBYDj4Isgq+cDKtx0i6u9jcX9pQDnswsaaOTgTmA5pEjuQ==", |  | ||||||
|       "dev": true, |  | ||||||
|       "optional": true |  | ||||||
|     }, |  | ||||||
|     "function-bind": { |  | ||||||
|       "version": "1.1.1", |  | ||||||
|       "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", |  | ||||||
|       "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", |  | ||||||
|       "dev": true |  | ||||||
|     }, |  | ||||||
|     "has": { |  | ||||||
|       "version": "1.0.3", |  | ||||||
|       "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", |  | ||||||
|       "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", |  | ||||||
|       "dev": true, |  | ||||||
|       "requires": { |  | ||||||
|         "function-bind": "^1.1.1" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "is-core-module": { |  | ||||||
|       "version": "2.1.0", |  | ||||||
|       "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.1.0.tgz", |  | ||||||
|       "integrity": "sha512-YcV7BgVMRFRua2FqQzKtTDMz8iCuLEyGKjr70q8Zm1yy2qKcurbFEd79PAdHV77oL3NrAaOVQIbMmiHQCHB7ZA==", |  | ||||||
|       "dev": true, |  | ||||||
|       "requires": { |  | ||||||
|         "has": "^1.0.3" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "path-parse": { |  | ||||||
|       "version": "1.0.6", |  | ||||||
|       "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.6.tgz", |  | ||||||
|       "integrity": "sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==", |  | ||||||
|       "dev": true |  | ||||||
|     }, |  | ||||||
|     "picomatch": { |  | ||||||
|       "version": "2.2.2", |  | ||||||
|       "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.2.2.tgz", |  | ||||||
|       "integrity": "sha512-q0M/9eZHzmr0AulXyPwNfZjtwZ/RBZlbN3K3CErVrk50T2ASYI7Bye0EvekFY3IP1Nt2DHu0re+V2ZHIpMkuWg==", |  | ||||||
|       "dev": true |  | ||||||
|     }, |  | ||||||
|     "preact": { |  | ||||||
|       "version": "10.5.5", |  | ||||||
|       "resolved": "https://registry.npmjs.org/preact/-/preact-10.5.5.tgz", |  | ||||||
|       "integrity": "sha512-5ONLNH1SXMzzbQoExZX4TELemNt+TEDb622xXFNfZngjjM9qtrzseJt+EfiUu4TZ6EJ95X5sE1ES4yqHFSIdhg==" |  | ||||||
|     }, |  | ||||||
|     "requirejs": { |  | ||||||
|       "version": "2.3.6", |  | ||||||
|       "resolved": "https://registry.npmjs.org/requirejs/-/requirejs-2.3.6.tgz", |  | ||||||
|       "integrity": "sha512-ipEzlWQe6RK3jkzikgCupiTbTvm4S0/CAU5GlgptkN5SO6F3u0UD0K18wy6ErDqiCyP4J4YYe1HuAShvsxePLg==", |  | ||||||
|       "dev": true |  | ||||||
|     }, |  | ||||||
|     "resolve": { |  | ||||||
|       "version": "1.18.1", |  | ||||||
|       "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.18.1.tgz", |  | ||||||
|       "integrity": "sha512-lDfCPaMKfOJXjy0dPayzPdF1phampNWr3qFCjAu+rw/qbQmr5jWH5xN2hwh9QKfw9E5v4hwV7A+jrCmL8yjjqA==", |  | ||||||
|       "dev": true, |  | ||||||
|       "requires": { |  | ||||||
|         "is-core-module": "^2.0.0", |  | ||||||
|         "path-parse": "^1.0.6" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "rollup": { |  | ||||||
|       "version": "2.33.1", |  | ||||||
|       "resolved": "https://registry.npmjs.org/rollup/-/rollup-2.33.1.tgz", |  | ||||||
|       "integrity": "sha512-uY4O/IoL9oNW8MMcbA5hcOaz6tZTMIh7qJHx/tzIJm+n1wLoY38BLn6fuy7DhR57oNFLMbDQtDeJoFURt5933w==", |  | ||||||
|       "dev": true, |  | ||||||
|       "requires": { |  | ||||||
|         "fsevents": "~2.1.2" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "source-map": { |  | ||||||
|       "version": "0.7.3", |  | ||||||
|       "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.7.3.tgz", |  | ||||||
|       "integrity": "sha512-CkCj6giN3S+n9qrYiBTX5gystlENnRW5jZeNLHpe6aue+SrHcG5VYwujhW9s4dY31mEGsxBDrHR6oI69fTXsaQ==", |  | ||||||
|       "dev": true |  | ||||||
|     }, |  | ||||||
|     "source-map-support": { |  | ||||||
|       "version": "0.5.19", |  | ||||||
|       "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.19.tgz", |  | ||||||
|       "integrity": "sha512-Wonm7zOCIJzBGQdB+thsPar0kYuCIzYvxZwlBa87yi/Mdjv7Tip2cyVbLj5o0cFPN4EVkuTwb3GDDyUx2DGnGw==", |  | ||||||
|       "dev": true, |  | ||||||
|       "requires": { |  | ||||||
|         "buffer-from": "^1.0.0", |  | ||||||
|         "source-map": "^0.6.0" |  | ||||||
|       }, |  | ||||||
|       "dependencies": { |  | ||||||
|         "source-map": { |  | ||||||
|           "version": "0.6.1", |  | ||||||
|           "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", |  | ||||||
|           "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", |  | ||||||
|           "dev": true |  | ||||||
|         } |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "terser": { |  | ||||||
|       "version": "5.3.8", |  | ||||||
|       "resolved": "https://registry.npmjs.org/terser/-/terser-5.3.8.tgz", |  | ||||||
|       "integrity": "sha512-zVotuHoIfnYjtlurOouTazciEfL7V38QMAOhGqpXDEg6yT13cF4+fEP9b0rrCEQTn+tT46uxgFsTZzhygk+CzQ==", |  | ||||||
|       "dev": true, |  | ||||||
|       "requires": { |  | ||||||
|         "commander": "^2.20.0", |  | ||||||
|         "source-map": "~0.7.2", |  | ||||||
|         "source-map-support": "~0.5.19" |  | ||||||
|       } |  | ||||||
|     }, |  | ||||||
|     "tslib": { |  | ||||||
|       "version": "2.0.3", |  | ||||||
|       "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.0.3.tgz", |  | ||||||
|       "integrity": "sha512-uZtkfKblCEQtZKBF6EBXVZeQNl82yqtDQdv+eck8u7tdPxjLu2/lp5/uPW+um2tpuxINHWy3GhiccY7QgEaVHQ==" |  | ||||||
|     }, |  | ||||||
|     "typescript": { |  | ||||||
|       "version": "4.0.5", |  | ||||||
|       "resolved": "https://registry.npmjs.org/typescript/-/typescript-4.0.5.tgz", |  | ||||||
|       "integrity": "sha512-ywmr/VrTVCmNTJ6iV2LwIrfG1P+lv6luD8sUJs+2eI9NLGigaN+nUQc13iHqisq7bra9lnmUSYqbJvegraBOPQ==", |  | ||||||
|       "dev": true |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| } |  | ||||||
							
								
								
									
										18
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										18
									
								
								package.json
									
									
									
									
									
								
							| @@ -1,18 +0,0 @@ | |||||||
| { |  | ||||||
|   "name": "tweaked.cc", |  | ||||||
|   "version": "1.0.0", |  | ||||||
|   "description": "Website additions for tweaked.cc", |  | ||||||
|   "author": "SquidDev", |  | ||||||
|   "license": "BSD-3-Clause", |  | ||||||
|   "dependencies": { |  | ||||||
|     "preact": "^10.5.5", |  | ||||||
|     "tslib": "^2.0.3" |  | ||||||
|   }, |  | ||||||
|   "devDependencies": { |  | ||||||
|     "@rollup/plugin-typescript": "^6.1.0", |  | ||||||
|     "requirejs": "^2.3.6", |  | ||||||
|     "rollup": "^2.33.1", |  | ||||||
|     "terser": "^5.3.8", |  | ||||||
|     "typescript": "^4.0.5" |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| @@ -1,55 +0,0 @@ | |||||||
| import { readFileSync, promises as fs } from "fs"; |  | ||||||
| import path from "path"; |  | ||||||
|  |  | ||||||
| import typescript from "@rollup/plugin-typescript"; |  | ||||||
|  |  | ||||||
| const input = "src/web"; |  | ||||||
| const requirejs = readFileSync("node_modules/requirejs/require.js"); |  | ||||||
|  |  | ||||||
| export default { |  | ||||||
|     input: [`${input}/index.tsx`], |  | ||||||
|     output: { |  | ||||||
|         file: "build/rollup/index.js", |  | ||||||
|         // We bundle requirejs (and config) into the header. It's rather gross |  | ||||||
|         // but also works reasonably well. |  | ||||||
|         banner: `${requirejs}\nrequire.config({ paths: { copycat: "https://copy-cat.squiddev.cc" } });`, |  | ||||||
|         format: "amd", |  | ||||||
|         preferConst: true, |  | ||||||
|         amd: { |  | ||||||
|             define: "require", |  | ||||||
|         } |  | ||||||
|     }, |  | ||||||
|     context: "window", |  | ||||||
|     external: ["copycat/embed"], |  | ||||||
|  |  | ||||||
|     plugins: [ |  | ||||||
|         typescript(), |  | ||||||
|  |  | ||||||
|         { |  | ||||||
|             name: "cc-tweaked", |  | ||||||
|             async options(options) { |  | ||||||
|                 // Generate .d.ts files for all /mount files. This is the worst way to do it, |  | ||||||
|                 // but we need to run before the TS pass. |  | ||||||
|                 const template = "declare const contents : string;\nexport default contents;\n"; |  | ||||||
|                 const files = await fs.readdir(`${input}/mount`); |  | ||||||
|  |  | ||||||
|                 await Promise.all(files |  | ||||||
|                     .filter(x => path.extname(x) !== ".ts") |  | ||||||
|                     .map(async file => { |  | ||||||
|                         const path = `${input}/mount/${file}.d.ts`; |  | ||||||
|                         const contents = await fs.readFile(path, { encoding: "utf-8" }).catch(() => ""); |  | ||||||
|                         if (contents !== template) await fs.writeFile(path, template); |  | ||||||
|                     }) |  | ||||||
|                 ); |  | ||||||
|                 return options; |  | ||||||
|             }, |  | ||||||
|             async transform(code, file) { |  | ||||||
|                 // Allow loading files in /mount. |  | ||||||
|                 const ext = path.extname(file); |  | ||||||
|                 return ext != '.tsx' && ext != '.ts' && path.dirname(file) === path.resolve(`${input}/mount`) |  | ||||||
|                     ? `export default ${JSON.stringify(code)};\n` |  | ||||||
|                     : null; |  | ||||||
|             }, |  | ||||||
|         } |  | ||||||
|     ], |  | ||||||
| }; |  | ||||||
| @@ -1 +1,12 @@ | |||||||
| rootProject.name = "cc-tweaked-${mc_version}" | pluginManagement { | ||||||
|  |     repositories { | ||||||
|  |         jcenter() | ||||||
|  |         maven { | ||||||
|  |             name = 'Fabric' | ||||||
|  |             url = 'https://maven.fabricmc.net/' | ||||||
|  |         } | ||||||
|  |         gradlePluginPortal() | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | rootProject.name = "cc-tweaked-fabric-${mc_version}" | ||||||
|   | |||||||
| @@ -1,49 +0,0 @@ | |||||||
| { |  | ||||||
|   "variants": { |  | ||||||
|     "facing=north,state=off": { |  | ||||||
|       "model": "computercraft:block/computer_advanced_off" |  | ||||||
|     }, |  | ||||||
|     "facing=south,state=off": { |  | ||||||
|       "model": "computercraft:block/computer_advanced_off", |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,state=off": { |  | ||||||
|       "model": "computercraft:block/computer_advanced_off", |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,state=off": { |  | ||||||
|       "model": "computercraft:block/computer_advanced_off", |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,state=on": { |  | ||||||
|       "model": "computercraft:block/computer_advanced_on" |  | ||||||
|     }, |  | ||||||
|     "facing=south,state=on": { |  | ||||||
|       "model": "computercraft:block/computer_advanced_on", |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,state=on": { |  | ||||||
|       "model": "computercraft:block/computer_advanced_on", |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,state=on": { |  | ||||||
|       "model": "computercraft:block/computer_advanced_on", |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,state=blinking": { |  | ||||||
|       "model": "computercraft:block/computer_advanced_blinking" |  | ||||||
|     }, |  | ||||||
|     "facing=south,state=blinking": { |  | ||||||
|       "model": "computercraft:block/computer_advanced_blinking", |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,state=blinking": { |  | ||||||
|       "model": "computercraft:block/computer_advanced_blinking", |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,state=blinking": { |  | ||||||
|       "model": "computercraft:block/computer_advanced_blinking", |  | ||||||
|       "y": 90 |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| @@ -1,49 +0,0 @@ | |||||||
| { |  | ||||||
|   "variants": { |  | ||||||
|     "facing=north,state=off": { |  | ||||||
|       "model": "computercraft:block/computer_command_off" |  | ||||||
|     }, |  | ||||||
|     "facing=south,state=off": { |  | ||||||
|       "model": "computercraft:block/computer_command_off", |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,state=off": { |  | ||||||
|       "model": "computercraft:block/computer_command_off", |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,state=off": { |  | ||||||
|       "model": "computercraft:block/computer_command_off", |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,state=on": { |  | ||||||
|       "model": "computercraft:block/computer_command_on" |  | ||||||
|     }, |  | ||||||
|     "facing=south,state=on": { |  | ||||||
|       "model": "computercraft:block/computer_command_on", |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,state=on": { |  | ||||||
|       "model": "computercraft:block/computer_command_on", |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,state=on": { |  | ||||||
|       "model": "computercraft:block/computer_command_on", |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,state=blinking": { |  | ||||||
|       "model": "computercraft:block/computer_command_blinking" |  | ||||||
|     }, |  | ||||||
|     "facing=south,state=blinking": { |  | ||||||
|       "model": "computercraft:block/computer_command_blinking", |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,state=blinking": { |  | ||||||
|       "model": "computercraft:block/computer_command_blinking", |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,state=blinking": { |  | ||||||
|       "model": "computercraft:block/computer_command_blinking", |  | ||||||
|       "y": 90 |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| @@ -1,49 +0,0 @@ | |||||||
| { |  | ||||||
|   "variants": { |  | ||||||
|     "facing=north,state=off": { |  | ||||||
|       "model": "computercraft:block/computer_normal_off" |  | ||||||
|     }, |  | ||||||
|     "facing=south,state=off": { |  | ||||||
|       "model": "computercraft:block/computer_normal_off", |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,state=off": { |  | ||||||
|       "model": "computercraft:block/computer_normal_off", |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,state=off": { |  | ||||||
|       "model": "computercraft:block/computer_normal_off", |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,state=on": { |  | ||||||
|       "model": "computercraft:block/computer_normal_on" |  | ||||||
|     }, |  | ||||||
|     "facing=south,state=on": { |  | ||||||
|       "model": "computercraft:block/computer_normal_on", |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,state=on": { |  | ||||||
|       "model": "computercraft:block/computer_normal_on", |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,state=on": { |  | ||||||
|       "model": "computercraft:block/computer_normal_on", |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,state=blinking": { |  | ||||||
|       "model": "computercraft:block/computer_normal_blinking" |  | ||||||
|     }, |  | ||||||
|     "facing=south,state=blinking": { |  | ||||||
|       "model": "computercraft:block/computer_normal_blinking", |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,state=blinking": { |  | ||||||
|       "model": "computercraft:block/computer_normal_blinking", |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,state=blinking": { |  | ||||||
|       "model": "computercraft:block/computer_normal_blinking", |  | ||||||
|       "y": 90 |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| @@ -1,852 +0,0 @@ | |||||||
| { |  | ||||||
|   "variants": { |  | ||||||
|     "facing=north,orientation=down,state=none": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced", |  | ||||||
|       "x": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=down,state=none": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=down,state=none": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=down,state=none": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=up,state=none": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced", |  | ||||||
|       "x": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=up,state=none": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=up,state=none": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=up,state=none": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=north,state=none": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced" |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=north,state=none": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced", |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=north,state=none": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced", |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=north,state=none": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced", |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=down,state=l": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_l", |  | ||||||
|       "x": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=down,state=l": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_l", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=down,state=l": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_l", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=down,state=l": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_l", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=up,state=l": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_l", |  | ||||||
|       "x": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=up,state=l": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_l", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=up,state=l": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_l", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=up,state=l": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_l", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=north,state=l": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_l" |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=north,state=l": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_l", |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=north,state=l": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_l", |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=north,state=l": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_l", |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=down,state=r": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_r", |  | ||||||
|       "x": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=down,state=r": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_r", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=down,state=r": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_r", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=down,state=r": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_r", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=up,state=r": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_r", |  | ||||||
|       "x": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=up,state=r": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_r", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=up,state=r": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_r", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=up,state=r": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_r", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=north,state=r": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_r" |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=north,state=r": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_r", |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=north,state=r": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_r", |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=north,state=r": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_r", |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=down,state=lr": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lr", |  | ||||||
|       "x": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=down,state=lr": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lr", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=down,state=lr": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lr", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=down,state=lr": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lr", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=up,state=lr": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lr", |  | ||||||
|       "x": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=up,state=lr": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lr", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=up,state=lr": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lr", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=up,state=lr": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lr", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=north,state=lr": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lr" |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=north,state=lr": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lr", |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=north,state=lr": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lr", |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=north,state=lr": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lr", |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=down,state=u": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_u", |  | ||||||
|       "x": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=down,state=u": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_u", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=down,state=u": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_u", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=down,state=u": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_u", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=up,state=u": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_u", |  | ||||||
|       "x": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=up,state=u": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_u", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=up,state=u": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_u", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=up,state=u": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_u", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=north,state=u": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_u" |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=north,state=u": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_u", |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=north,state=u": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_u", |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=north,state=u": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_u", |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=down,state=d": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_d", |  | ||||||
|       "x": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=down,state=d": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_d", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=down,state=d": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_d", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=down,state=d": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_d", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=up,state=d": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_d", |  | ||||||
|       "x": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=up,state=d": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_d", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=up,state=d": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_d", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=up,state=d": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_d", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=north,state=d": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_d" |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=north,state=d": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_d", |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=north,state=d": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_d", |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=north,state=d": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_d", |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=down,state=ud": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_ud", |  | ||||||
|       "x": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=down,state=ud": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_ud", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=down,state=ud": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_ud", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=down,state=ud": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_ud", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=up,state=ud": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_ud", |  | ||||||
|       "x": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=up,state=ud": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_ud", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=up,state=ud": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_ud", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=up,state=ud": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_ud", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=north,state=ud": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_ud" |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=north,state=ud": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_ud", |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=north,state=ud": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_ud", |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=north,state=ud": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_ud", |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=down,state=rd": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_rd", |  | ||||||
|       "x": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=down,state=rd": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_rd", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=down,state=rd": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_rd", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=down,state=rd": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_rd", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=up,state=rd": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_rd", |  | ||||||
|       "x": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=up,state=rd": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_rd", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=up,state=rd": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_rd", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=up,state=rd": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_rd", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=north,state=rd": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_rd" |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=north,state=rd": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_rd", |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=north,state=rd": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_rd", |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=north,state=rd": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_rd", |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=down,state=ld": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_ld", |  | ||||||
|       "x": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=down,state=ld": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_ld", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=down,state=ld": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_ld", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=down,state=ld": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_ld", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=up,state=ld": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_ld", |  | ||||||
|       "x": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=up,state=ld": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_ld", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=up,state=ld": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_ld", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=up,state=ld": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_ld", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=north,state=ld": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_ld" |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=north,state=ld": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_ld", |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=north,state=ld": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_ld", |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=north,state=ld": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_ld", |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=down,state=ru": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_ru", |  | ||||||
|       "x": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=down,state=ru": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_ru", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=down,state=ru": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_ru", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=down,state=ru": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_ru", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=up,state=ru": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_ru", |  | ||||||
|       "x": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=up,state=ru": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_ru", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=up,state=ru": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_ru", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=up,state=ru": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_ru", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=north,state=ru": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_ru" |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=north,state=ru": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_ru", |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=north,state=ru": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_ru", |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=north,state=ru": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_ru", |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=down,state=lu": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lu", |  | ||||||
|       "x": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=down,state=lu": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lu", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=down,state=lu": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lu", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=down,state=lu": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lu", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=up,state=lu": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lu", |  | ||||||
|       "x": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=up,state=lu": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lu", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=up,state=lu": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lu", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=up,state=lu": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lu", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=north,state=lu": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lu" |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=north,state=lu": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lu", |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=north,state=lu": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lu", |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=north,state=lu": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lu", |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=down,state=lrd": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lrd", |  | ||||||
|       "x": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=down,state=lrd": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lrd", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=down,state=lrd": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lrd", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=down,state=lrd": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lrd", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=up,state=lrd": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lrd", |  | ||||||
|       "x": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=up,state=lrd": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lrd", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=up,state=lrd": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lrd", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=up,state=lrd": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lrd", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=north,state=lrd": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lrd" |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=north,state=lrd": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lrd", |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=north,state=lrd": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lrd", |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=north,state=lrd": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lrd", |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=down,state=rud": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_rud", |  | ||||||
|       "x": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=down,state=rud": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_rud", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=down,state=rud": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_rud", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=down,state=rud": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_rud", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=up,state=rud": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_rud", |  | ||||||
|       "x": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=up,state=rud": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_rud", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=up,state=rud": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_rud", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=up,state=rud": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_rud", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=north,state=rud": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_rud" |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=north,state=rud": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_rud", |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=north,state=rud": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_rud", |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=north,state=rud": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_rud", |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=down,state=lud": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lud", |  | ||||||
|       "x": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=down,state=lud": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lud", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=down,state=lud": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lud", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=down,state=lud": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lud", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=up,state=lud": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lud", |  | ||||||
|       "x": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=up,state=lud": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lud", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=up,state=lud": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lud", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=up,state=lud": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lud", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=north,state=lud": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lud" |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=north,state=lud": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lud", |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=north,state=lud": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lud", |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=north,state=lud": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lud", |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=down,state=lru": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lru", |  | ||||||
|       "x": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=down,state=lru": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lru", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=down,state=lru": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lru", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=down,state=lru": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lru", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=up,state=lru": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lru", |  | ||||||
|       "x": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=up,state=lru": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lru", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=up,state=lru": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lru", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=up,state=lru": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lru", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=north,state=lru": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lru" |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=north,state=lru": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lru", |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=north,state=lru": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lru", |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=north,state=lru": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lru", |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=down,state=lrud": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lrud", |  | ||||||
|       "x": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=down,state=lrud": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lrud", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=down,state=lrud": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lrud", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=down,state=lrud": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lrud", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=up,state=lrud": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lrud", |  | ||||||
|       "x": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=up,state=lrud": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lrud", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=up,state=lrud": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lrud", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=up,state=lrud": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lrud", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=north,state=lrud": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lrud" |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=north,state=lrud": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lrud", |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=north,state=lrud": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lrud", |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=north,state=lrud": { |  | ||||||
|       "model": "computercraft:block/monitor_advanced_lrud", |  | ||||||
|       "y": 90 |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| @@ -1,852 +0,0 @@ | |||||||
| { |  | ||||||
|   "variants": { |  | ||||||
|     "facing=north,orientation=down,state=none": { |  | ||||||
|       "model": "computercraft:block/monitor_normal", |  | ||||||
|       "x": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=down,state=none": { |  | ||||||
|       "model": "computercraft:block/monitor_normal", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=down,state=none": { |  | ||||||
|       "model": "computercraft:block/monitor_normal", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=down,state=none": { |  | ||||||
|       "model": "computercraft:block/monitor_normal", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=up,state=none": { |  | ||||||
|       "model": "computercraft:block/monitor_normal", |  | ||||||
|       "x": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=up,state=none": { |  | ||||||
|       "model": "computercraft:block/monitor_normal", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=up,state=none": { |  | ||||||
|       "model": "computercraft:block/monitor_normal", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=up,state=none": { |  | ||||||
|       "model": "computercraft:block/monitor_normal", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=north,state=none": { |  | ||||||
|       "model": "computercraft:block/monitor_normal" |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=north,state=none": { |  | ||||||
|       "model": "computercraft:block/monitor_normal", |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=north,state=none": { |  | ||||||
|       "model": "computercraft:block/monitor_normal", |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=north,state=none": { |  | ||||||
|       "model": "computercraft:block/monitor_normal", |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=down,state=l": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_l", |  | ||||||
|       "x": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=down,state=l": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_l", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=down,state=l": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_l", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=down,state=l": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_l", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=up,state=l": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_l", |  | ||||||
|       "x": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=up,state=l": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_l", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=up,state=l": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_l", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=up,state=l": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_l", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=north,state=l": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_l" |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=north,state=l": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_l", |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=north,state=l": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_l", |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=north,state=l": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_l", |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=down,state=r": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_r", |  | ||||||
|       "x": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=down,state=r": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_r", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=down,state=r": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_r", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=down,state=r": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_r", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=up,state=r": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_r", |  | ||||||
|       "x": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=up,state=r": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_r", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=up,state=r": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_r", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=up,state=r": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_r", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=north,state=r": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_r" |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=north,state=r": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_r", |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=north,state=r": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_r", |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=north,state=r": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_r", |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=down,state=lr": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lr", |  | ||||||
|       "x": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=down,state=lr": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lr", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=down,state=lr": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lr", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=down,state=lr": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lr", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=up,state=lr": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lr", |  | ||||||
|       "x": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=up,state=lr": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lr", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=up,state=lr": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lr", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=up,state=lr": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lr", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=north,state=lr": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lr" |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=north,state=lr": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lr", |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=north,state=lr": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lr", |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=north,state=lr": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lr", |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=down,state=u": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_u", |  | ||||||
|       "x": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=down,state=u": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_u", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=down,state=u": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_u", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=down,state=u": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_u", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=up,state=u": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_u", |  | ||||||
|       "x": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=up,state=u": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_u", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=up,state=u": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_u", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=up,state=u": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_u", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=north,state=u": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_u" |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=north,state=u": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_u", |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=north,state=u": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_u", |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=north,state=u": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_u", |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=down,state=d": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_d", |  | ||||||
|       "x": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=down,state=d": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_d", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=down,state=d": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_d", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=down,state=d": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_d", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=up,state=d": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_d", |  | ||||||
|       "x": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=up,state=d": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_d", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=up,state=d": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_d", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=up,state=d": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_d", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=north,state=d": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_d" |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=north,state=d": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_d", |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=north,state=d": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_d", |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=north,state=d": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_d", |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=down,state=ud": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_ud", |  | ||||||
|       "x": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=down,state=ud": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_ud", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=down,state=ud": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_ud", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=down,state=ud": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_ud", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=up,state=ud": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_ud", |  | ||||||
|       "x": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=up,state=ud": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_ud", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=up,state=ud": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_ud", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=up,state=ud": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_ud", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=north,state=ud": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_ud" |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=north,state=ud": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_ud", |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=north,state=ud": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_ud", |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=north,state=ud": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_ud", |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=down,state=rd": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_rd", |  | ||||||
|       "x": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=down,state=rd": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_rd", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=down,state=rd": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_rd", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=down,state=rd": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_rd", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=up,state=rd": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_rd", |  | ||||||
|       "x": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=up,state=rd": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_rd", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=up,state=rd": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_rd", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=up,state=rd": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_rd", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=north,state=rd": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_rd" |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=north,state=rd": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_rd", |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=north,state=rd": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_rd", |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=north,state=rd": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_rd", |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=down,state=ld": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_ld", |  | ||||||
|       "x": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=down,state=ld": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_ld", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=down,state=ld": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_ld", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=down,state=ld": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_ld", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=up,state=ld": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_ld", |  | ||||||
|       "x": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=up,state=ld": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_ld", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=up,state=ld": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_ld", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=up,state=ld": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_ld", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=north,state=ld": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_ld" |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=north,state=ld": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_ld", |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=north,state=ld": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_ld", |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=north,state=ld": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_ld", |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=down,state=ru": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_ru", |  | ||||||
|       "x": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=down,state=ru": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_ru", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=down,state=ru": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_ru", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=down,state=ru": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_ru", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=up,state=ru": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_ru", |  | ||||||
|       "x": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=up,state=ru": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_ru", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=up,state=ru": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_ru", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=up,state=ru": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_ru", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=north,state=ru": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_ru" |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=north,state=ru": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_ru", |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=north,state=ru": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_ru", |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=north,state=ru": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_ru", |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=down,state=lu": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lu", |  | ||||||
|       "x": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=down,state=lu": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lu", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=down,state=lu": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lu", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=down,state=lu": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lu", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=up,state=lu": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lu", |  | ||||||
|       "x": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=up,state=lu": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lu", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=up,state=lu": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lu", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=up,state=lu": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lu", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=north,state=lu": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lu" |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=north,state=lu": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lu", |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=north,state=lu": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lu", |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=north,state=lu": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lu", |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=down,state=lrd": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lrd", |  | ||||||
|       "x": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=down,state=lrd": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lrd", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=down,state=lrd": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lrd", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=down,state=lrd": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lrd", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=up,state=lrd": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lrd", |  | ||||||
|       "x": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=up,state=lrd": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lrd", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=up,state=lrd": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lrd", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=up,state=lrd": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lrd", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=north,state=lrd": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lrd" |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=north,state=lrd": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lrd", |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=north,state=lrd": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lrd", |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=north,state=lrd": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lrd", |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=down,state=rud": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_rud", |  | ||||||
|       "x": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=down,state=rud": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_rud", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=down,state=rud": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_rud", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=down,state=rud": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_rud", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=up,state=rud": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_rud", |  | ||||||
|       "x": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=up,state=rud": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_rud", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=up,state=rud": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_rud", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=up,state=rud": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_rud", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=north,state=rud": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_rud" |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=north,state=rud": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_rud", |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=north,state=rud": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_rud", |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=north,state=rud": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_rud", |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=down,state=lud": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lud", |  | ||||||
|       "x": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=down,state=lud": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lud", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=down,state=lud": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lud", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=down,state=lud": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lud", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=up,state=lud": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lud", |  | ||||||
|       "x": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=up,state=lud": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lud", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=up,state=lud": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lud", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=up,state=lud": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lud", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=north,state=lud": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lud" |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=north,state=lud": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lud", |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=north,state=lud": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lud", |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=north,state=lud": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lud", |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=down,state=lru": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lru", |  | ||||||
|       "x": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=down,state=lru": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lru", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=down,state=lru": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lru", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=down,state=lru": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lru", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=up,state=lru": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lru", |  | ||||||
|       "x": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=up,state=lru": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lru", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=up,state=lru": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lru", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=up,state=lru": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lru", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=north,state=lru": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lru" |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=north,state=lru": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lru", |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=north,state=lru": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lru", |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=north,state=lru": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lru", |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=down,state=lrud": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lrud", |  | ||||||
|       "x": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=down,state=lrud": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lrud", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=down,state=lrud": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lrud", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=down,state=lrud": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lrud", |  | ||||||
|       "x": 90, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=up,state=lrud": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lrud", |  | ||||||
|       "x": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=up,state=lrud": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lrud", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=up,state=lrud": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lrud", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=up,state=lrud": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lrud", |  | ||||||
|       "x": 270, |  | ||||||
|       "y": 90 |  | ||||||
|     }, |  | ||||||
|     "facing=north,orientation=north,state=lrud": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lrud" |  | ||||||
|     }, |  | ||||||
|     "facing=south,orientation=north,state=lrud": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lrud", |  | ||||||
|       "y": 180 |  | ||||||
|     }, |  | ||||||
|     "facing=west,orientation=north,state=lrud": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lrud", |  | ||||||
|       "y": 270 |  | ||||||
|     }, |  | ||||||
|     "facing=east,orientation=north,state=lrud": { |  | ||||||
|       "model": "computercraft:block/monitor_normal_lrud", |  | ||||||
|       "y": 90 |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| @@ -1,8 +0,0 @@ | |||||||
| { |  | ||||||
|   "parent": "block/orientable", |  | ||||||
|   "textures": { |  | ||||||
|     "top": "computercraft:block/computer_advanced_top", |  | ||||||
|     "side": "computercraft:block/computer_advanced_side", |  | ||||||
|     "front": "computercraft:block/computer_advanced_front_blink" |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| @@ -1,8 +0,0 @@ | |||||||
| { |  | ||||||
|   "parent": "block/orientable", |  | ||||||
|   "textures": { |  | ||||||
|     "top": "computercraft:block/computer_advanced_top", |  | ||||||
|     "side": "computercraft:block/computer_advanced_side", |  | ||||||
|     "front": "computercraft:block/computer_advanced_front" |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| @@ -1,8 +0,0 @@ | |||||||
| { |  | ||||||
|   "parent": "block/orientable", |  | ||||||
|   "textures": { |  | ||||||
|     "top": "computercraft:block/computer_advanced_top", |  | ||||||
|     "side": "computercraft:block/computer_advanced_side", |  | ||||||
|     "front": "computercraft:block/computer_advanced_front_on" |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| @@ -1,8 +0,0 @@ | |||||||
| { |  | ||||||
|   "parent": "block/orientable", |  | ||||||
|   "textures": { |  | ||||||
|     "top": "computercraft:block/computer_command_top", |  | ||||||
|     "side": "computercraft:block/computer_command_side", |  | ||||||
|     "front": "computercraft:block/computer_command_front_blink" |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| @@ -1,8 +0,0 @@ | |||||||
| { |  | ||||||
|   "parent": "block/orientable", |  | ||||||
|   "textures": { |  | ||||||
|     "top": "computercraft:block/computer_command_top", |  | ||||||
|     "side": "computercraft:block/computer_command_side", |  | ||||||
|     "front": "computercraft:block/computer_command_front" |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| @@ -1,8 +0,0 @@ | |||||||
| { |  | ||||||
|   "parent": "block/orientable", |  | ||||||
|   "textures": { |  | ||||||
|     "top": "computercraft:block/computer_command_top", |  | ||||||
|     "side": "computercraft:block/computer_command_side", |  | ||||||
|     "front": "computercraft:block/computer_command_front_on" |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| @@ -1,8 +0,0 @@ | |||||||
| { |  | ||||||
|   "parent": "block/orientable", |  | ||||||
|   "textures": { |  | ||||||
|     "top": "computercraft:block/computer_normal_top", |  | ||||||
|     "side": "computercraft:block/computer_normal_side", |  | ||||||
|     "front": "computercraft:block/computer_normal_front_blink" |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| @@ -1,8 +0,0 @@ | |||||||
| { |  | ||||||
|   "parent": "block/orientable", |  | ||||||
|   "textures": { |  | ||||||
|     "top": "computercraft:block/computer_normal_top", |  | ||||||
|     "side": "computercraft:block/computer_normal_side", |  | ||||||
|     "front": "computercraft:block/computer_normal_front" |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| @@ -1,8 +0,0 @@ | |||||||
| { |  | ||||||
|   "parent": "block/orientable", |  | ||||||
|   "textures": { |  | ||||||
|     "top": "computercraft:block/computer_normal_top", |  | ||||||
|     "side": "computercraft:block/computer_normal_side", |  | ||||||
|     "front": "computercraft:block/computer_normal_front_on" |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| @@ -1,9 +0,0 @@ | |||||||
| { |  | ||||||
|   "parent": "computercraft:block/monitor_base", |  | ||||||
|   "textures": { |  | ||||||
|     "front": "computercraft:block/monitor_advanced_16", |  | ||||||
|     "side": "computercraft:block/monitor_advanced_4", |  | ||||||
|     "top": "computercraft:block/monitor_advanced_0", |  | ||||||
|     "back": "computercraft:block/monitor_advanced_32" |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| @@ -1,9 +0,0 @@ | |||||||
| { |  | ||||||
|   "parent": "computercraft:block/monitor_base", |  | ||||||
|   "textures": { |  | ||||||
|     "front": "computercraft:block/monitor_advanced_20", |  | ||||||
|     "side": "computercraft:block/monitor_advanced_7", |  | ||||||
|     "top": "computercraft:block/monitor_advanced_0", |  | ||||||
|     "back": "computercraft:block/monitor_advanced_36" |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| @@ -1,9 +0,0 @@ | |||||||
| { |  | ||||||
|   "parent": "computercraft:block/monitor_base", |  | ||||||
|   "textures": { |  | ||||||
|     "front": "computercraft:block/monitor_advanced_19", |  | ||||||
|     "side": "computercraft:block/monitor_advanced_4", |  | ||||||
|     "top": "computercraft:block/monitor_advanced_1", |  | ||||||
|     "back": "computercraft:block/monitor_advanced_33" |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| @@ -1,9 +0,0 @@ | |||||||
| { |  | ||||||
|   "parent": "computercraft:block/monitor_base", |  | ||||||
|   "textures": { |  | ||||||
|     "front": "computercraft:block/monitor_advanced_31", |  | ||||||
|     "side": "computercraft:block/monitor_advanced_7", |  | ||||||
|     "top": "computercraft:block/monitor_advanced_1", |  | ||||||
|     "back": "computercraft:block/monitor_advanced_45" |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| @@ -1,9 +0,0 @@ | |||||||
| { |  | ||||||
|   "parent": "computercraft:block/monitor_base", |  | ||||||
|   "textures": { |  | ||||||
|     "front": "computercraft:block/monitor_advanced_18", |  | ||||||
|     "side": "computercraft:block/monitor_advanced_4", |  | ||||||
|     "top": "computercraft:block/monitor_advanced_2", |  | ||||||
|     "back": "computercraft:block/monitor_advanced_34" |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| @@ -1,9 +0,0 @@ | |||||||
| { |  | ||||||
|   "parent": "computercraft:block/monitor_base", |  | ||||||
|   "textures": { |  | ||||||
|     "front": "computercraft:block/monitor_advanced_30", |  | ||||||
|     "side": "computercraft:block/monitor_advanced_7", |  | ||||||
|     "top": "computercraft:block/monitor_advanced_2", |  | ||||||
|     "back": "computercraft:block/monitor_advanced_46" |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| @@ -1,9 +0,0 @@ | |||||||
| { |  | ||||||
|   "parent": "computercraft:block/monitor_base", |  | ||||||
|   "textures": { |  | ||||||
|     "front": "computercraft:block/monitor_advanced_24", |  | ||||||
|     "side": "computercraft:block/monitor_advanced_5", |  | ||||||
|     "top": "computercraft:block/monitor_advanced_2", |  | ||||||
|     "back": "computercraft:block/monitor_advanced_40" |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| @@ -1,9 +0,0 @@ | |||||||
| { |  | ||||||
|   "parent": "computercraft:block/monitor_base", |  | ||||||
|   "textures": { |  | ||||||
|     "front": "computercraft:block/monitor_advanced_27", |  | ||||||
|     "side": "computercraft:block/monitor_advanced_6", |  | ||||||
|     "top": "computercraft:block/monitor_advanced_2", |  | ||||||
|     "back": "computercraft:block/monitor_advanced_43" |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| @@ -1,9 +0,0 @@ | |||||||
| { |  | ||||||
|   "parent": "computercraft:block/monitor_base", |  | ||||||
|   "textures": { |  | ||||||
|     "front": "computercraft:block/monitor_advanced_25", |  | ||||||
|     "side": "computercraft:block/monitor_advanced_5", |  | ||||||
|     "top": "computercraft:block/monitor_advanced_1", |  | ||||||
|     "back": "computercraft:block/monitor_advanced_39" |  | ||||||
|   } |  | ||||||
| } |  | ||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user