mirror of
				https://github.com/SquidDev-CC/CC-Tweaked
				synced 2025-10-21 17:07:39 +00:00 
			
		
		
		
	Compare commits
	
		
			468 Commits
		
	
	
		
			v1.97.3
			...
			v1.16.4-1.
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 1edb7288b9 | ||
|   | cc5e972cfc | ||
|   | 92be0126df | ||
|   | dd6f97622e | ||
|   | 2c9f51db89 | ||
|   | 72340defe4 | ||
|   | 542b66c79a | ||
|   | e4b0a5b3ce | ||
|   | f7e3e72a6e | ||
|   | 8b17ec76a8 | ||
|   | b8d5a89446 | ||
|   | 4af5bcc0b0 | ||
|   | 96c577482d | ||
|   | 7f9a707f75 | ||
|   | ed3913c1f4 | ||
|   | 16d74dd2e8 | ||
|   | 24bb92007a | ||
|   | 2f0cae0bc1 | ||
|   | e3a672099c | ||
|   | abf425dfb5 | ||
|   | 663859d2e5 | ||
|   | f5eb6ce03e | ||
|   | 4ae370b9db | ||
|   | b97e950d86 | ||
|   | 5865e9c41a | ||
|   | 85cf2d5ff1 | ||
|   | 61f8e97f6b | ||
|   | c92f06cfd9 | ||
|   | 05c3c8ad32 | ||
|   | bb8f4c624b | ||
|   | ea3a160367 | ||
|   | 737b3cb576 | ||
|   | d83a68f3ff | ||
|   | 24d3777722 | ||
|   | 826797cbd5 | ||
|   | 511eea39a1 | ||
|   | 24af36743d | ||
|   | e2761bb315 | ||
|   | 6734a0e112 | ||
|   | d4199064ae | ||
|   | 04f9644ae7 | ||
|   | 486f41f082 | ||
|   | fff8353451 | ||
|   | 9a749642d2 | ||
|   | c35707725f | ||
|   | b0651082f4 | ||
|   | aab0cd34cd | ||
|   | d2a1a00dc4 | ||
|   | f194f4fa3a | ||
|   | c9f3d315c0 | ||
|   | 7f90f2f7ca | ||
|   | 9f57e77ed3 | ||
|   | ab39cb849d | ||
|   | a4c9e89370 | ||
|   | c8aeddedd4 | ||
|   | 83df64e520 | ||
|   | 74ac5bb3d1 | ||
|   | d13bd2cce8 | ||
|   | ab232bd689 | ||
|   | cc96e41d3e | ||
|   | 741adfa7bb | ||
|   | 666e83cf4f | ||
|   | e2a635b6e5 | ||
|   | c58441b29c | ||
|   | a6fcfb6af2 | ||
|   | 17a9329207 | ||
|   | f6160bdc57 | ||
|   | 6aae4e5766 | ||
|   | 84a6bb1cf3 | ||
|   | c334423d42 | ||
|   | 113b560a20 | ||
|   | 5bf367af9f | ||
|   | 61fb4caaad | ||
|   | 6734af6e4a | ||
|   | bf6053906d | ||
|   | 4766833cf2 | ||
|   | 01d81cb91d | ||
|   | 93068402a2 | ||
|   | 34a2c835d4 | ||
|   | 30d35883b8 | ||
|   | 71563a52ff | ||
|   | 0c6e7b5db5 | ||
|   | 334ca65482 | ||
|   | 8472112fc1 | ||
|   | 84036d97d9 | ||
|   | 0832974725 | ||
|   | 6cee4efcd3 | ||
|   | 6f868849ab | ||
|   | 275ca58a82 | ||
|   | 87393e8aef | ||
|   | 86bf57e3cd | ||
|   | 72c1d451fe | ||
|   | 8b4a01df27 | ||
|   | d0a973fa46 | ||
|   | 748ebbe66b | ||
|   | 59de21eae2 | ||
|   | 50473afea8 | ||
|   | 37f925de0a | ||
|   | cefde3f003 | ||
|   | ae6124d1f4 | ||
|   | 7e121ff72f | ||
|   | 5155e18de2 | ||
|   | 7365741088 | ||
|   | d5368d0719 | ||
|   | 26c12ac1a9 | ||
|   | 2c67849b35 | ||
|   | 04509cefec | ||
|   | 74b9f5dcb0 | ||
|   | 7809a2eddd | ||
|   | 183b342071 | ||
|   | 0bb5515055 | ||
|   | e8e9294fdf | ||
|   | 9acfc0316f | ||
|   | 29fb0baa09 | ||
|   | d5de39ebd4 | ||
|   | 0faf76e4bd | ||
|   | 99581e1f40 | ||
|   | e8e2ed9fe5 | ||
|   | 9f72448ecd | ||
|   | 3da3f16deb | ||
|   | 0e2ce3c634 | ||
|   | fe00e00537 | ||
|   | 29646a7f61 | ||
|   | 50d2712581 | ||
|   | 3093f882d8 | ||
|   | e5cf0d1c61 | ||
|   | cd879b067f | ||
|   | 053cb1b53c | ||
|   | 6b102a8142 | ||
|   | ac7979fb46 | ||
|   | c8a6888a2f | ||
|   | 9ce33f8a3f | ||
|   | d51851e763 | ||
|   | fb70a1a998 | ||
|   | a1dcd59d95 | ||
|   | 2a17585702 | ||
|   | 2f323f23d7 | ||
|   | 087c305b0d | ||
|   | 31764f6d65 | ||
|   | 4efde2b294 | ||
|   | 95554a53d1 | ||
|   | 89c1b2771d | ||
|   | 8f069a9b72 | ||
|   | 2e9d6603e3 | ||
|   | 46595e73df | ||
|   | a6a1b9b8e5 | ||
|   | 3f277a7a7b | ||
|   | 90c5d3f1e8 | ||
|   | a5f7cf8334 | ||
|   | 3075f89797 | ||
|   | 45297665c6 | ||
|   | ddbf3fc111 | ||
|   | da82b89676 | ||
|   | d5f1a2c817 | ||
|   | 6020adef6b | ||
|   | d2a52a8b5d | ||
|   | 9f8774960f | ||
|   | 36bb8b67c9 | ||
|   | 8f3a56dd32 | ||
|   | 113d5d982f | ||
|   | 37a447e745 | ||
|   | 9e2232d240 | ||
|   | 514db30fb1 | ||
|   | 08181f72d4 | ||
|   | 613a28a5af | ||
|   | e4c422d6f9 | ||
|   | 478f992dea | ||
|   | b54519d0e6 | ||
|   | 9499654757 | ||
|   | c5138c535c | ||
|   | 5bd8d84d14 | ||
|   | ab0310e27c | ||
|   | 607751da40 | ||
|   | 1efabccd14 | ||
|   | 029374e9aa | ||
|   | 2a8efb3fd5 | ||
|   | 48edcde4ef | ||
|   | 58a2995bbc | ||
|   | a35dcb28ef | ||
|   | 7b2d482387 | ||
|   | 2b077554f7 | ||
|   | 9134f243c1 | ||
|   | c0f3ca81fb | ||
|   | 190ed4fd20 | ||
|   | b9ff9b7f90 | ||
|   | b9b8121be9 | ||
|   | 014bf55cd4 | ||
|   | 085ae2e74a | ||
|   | 4ff33f165d | ||
|   | d929c02d2a | ||
|   | d50a08a549 | ||
|   | c493d668c8 | ||
|   | 53477fd3a1 | ||
|   | 87aa839b60 | ||
|   | e02ccdcb1a | ||
|   | f36f532c63 | ||
|   | 5a816917d5 | ||
|   | 7af63d052d | ||
|   | 4f8217d1ab | ||
|   | 5409d441b5 | ||
|   | d5f82fa458 | ||
|   | d0deab3519 | ||
|   | d5a8df753a | ||
|   | 13de2c4dd0 | ||
|   | 906280225e | ||
|   | 161a5b4707 | ||
|   | c6b6b4479c | ||
|   | 96e7b60285 | ||
|   | 086fccd997 | ||
|   | 5dfaf6eee9 | ||
|   | e251dd066c | ||
|   | 9abcfe56ea | ||
|   | abbc641fd4 | ||
|   | c60dcb4f5a | ||
|   | 4be0b15afa | ||
|   | a4ae36b6b3 | ||
|   | ac075d9f53 | ||
|   | 05d7be0362 | ||
|   | 9a71dc1a26 | ||
|   | 156023b154 | ||
|   | 6b3773a862 | ||
|   | 376d628cf0 | ||
|   | 44062ebd52 | ||
|   | 5739285fc2 | ||
|   | 70b457ed18 | ||
|   | ca2995ed38 | ||
|   | 6816931659 | ||
|   | 1547ecbeb3 | ||
|   | e918f55b58 | ||
|   | c28b468844 | ||
|   | 052cf8ee7d | ||
|   | 550ada2f9e | ||
|   | 17b7727262 | ||
|   | 4553e404b2 | ||
|   | a565a571f9 | ||
|   | fb64b6017b | ||
|   | ed4229ab70 | ||
|   | 3fb906ef6c | ||
|   | e1663f3df0 | ||
|   | 52c6584c81 | ||
|   | 9f87eda5de | ||
|   | 697e9449cf | ||
|   | 76c3e4c155 | ||
|   | 358289b5f9 | ||
|   | 5eec24676f | ||
|   | f52b8fa2de | ||
|   | 447c3ab125 | ||
|   | 8fac68386e | ||
|   | a3021c4697 | ||
|   | b7c61f9c6d | ||
|   | 08a0342618 | ||
|   | 3d7a81696d | ||
|   | 48cb032ddf | ||
|   | 33260a7747 | ||
|   | a049502d12 | ||
|   | ae7ef66dfa | ||
|   | 9748679484 | ||
|   | da419b24e7 | ||
|   | 7f57a977a1 | ||
|   | 2f42a4e85b | ||
|   | af40f5ae5c | ||
|   | 759d02a249 | ||
|   | d7729337ac | ||
|   | ee391ae9ea | ||
|   | 4ed4a6409b | ||
|   | e5cc345f49 | ||
|   | d847a4d9e0 | ||
|   | f106733d71 | ||
|   | f3de97d67f | ||
|   | 544f276ff0 | ||
|   | 463635a459 | ||
|   | 3b7b845930 | ||
|   | 1fc0214857 | ||
|   | 11bf601db9 | ||
|   | 7c1154ddfc | ||
|   | df557e03fa | ||
|   | 524b6f1d8a | ||
|   | cea8be7efa | ||
|   | c5f918ad95 | ||
|   | b14c7842fc | ||
|   | eead8b5755 | ||
|   | 10a27a7a25 | ||
|   | 865fc239a0 | ||
|   | f9f94b8304 | ||
|   | cb8135a0d1 | ||
|   | ef4b0a5632 | ||
|   | 6a6a87489c | ||
|   | 2360a6e951 | ||
|   | f4f71185ae | ||
|   | 062977336a | ||
|   | e52d98ad8b | ||
|   | ef8da8054f | ||
|   | 1ccd687c00 | ||
|   | a8ce5a5b20 | ||
|   | 68e6bc464b | ||
|   | 68762fe84c | ||
|   | 419f29321a | ||
|   | 00b41d29c1 | ||
|   | 0ffd5fcf85 | ||
|   | 95fee95006 | ||
|   | 239bd769df | ||
|   | b4e0e9984f | ||
|   | 79f42e35ce | ||
|   | be89fc25f9 | ||
|   | 8eae02c037 | ||
|   | 930fd59298 | ||
|   | bf13bac152 | ||
|   | 649acbae1c | ||
|   | 05eada427b | ||
|   | 03caf9d805 | ||
|   | d6ea3aab1c | ||
|   | f3a330e330 | ||
|   | 044d2b2b06 | ||
|   | fb440b0d2e | ||
|   | 0de5969ec1 | ||
|   | 3f98b2785e | ||
|   | 798868427e | ||
|   | c79f643ba7 | ||
|   | 1db3a14c54 | ||
|   | bf6d017ad1 | ||
|   | 8b1773dd60 | ||
|   | a706300598 | ||
|   | 2541c3c5e6 | ||
|   | 41a1b99f7d | ||
|   | 1862a439e2 | ||
|   | 018ecfbaa0 | ||
|   | 4c8fd4fc35 | ||
|   | 35c1b10224 | ||
|   | c1c01bef7c | ||
|   | a48c3d0ba8 | ||
|   | 93a9ebc4f6 | ||
|   | 7cc2bd43c6 | ||
|   | 393e628721 | ||
|   | 0bcd28e58c | ||
|   | 42f5389fb8 | ||
|   | 041cfe91b4 | ||
|   | 0f82a4589b | ||
|   | 4320a4f851 | ||
|   | 037cbabb32 | ||
|   | 0dde859582 | ||
|   | e59c043fb6 | ||
|   | ae928c4397 | ||
|   | da41c65128 | ||
|   | 4d18234714 | ||
|   | d254c6464b | ||
|   | 3a5d50e572 | ||
|   | 03b6d2f1ab | ||
|   | b0397ed3c5 | ||
|   | fa70ebcac2 | ||
|   | 86e0330100 | ||
|   | 92567b4d7e | ||
|   | 0ae70fed13 | ||
|   | 3b7300543a | ||
|   | 642351af1a | ||
|   | 121802a683 | ||
|   | 08cf55e55f | ||
|   | 3c8c0d78ef | ||
|   | c4d18aa9ca | ||
|   | 2d4a87adc9 | ||
|   | bedac71e3d | ||
|   | ee4e42e730 | ||
|   | 0de75f05dd | ||
|   | be6dd21e54 | ||
|   | 927ddb0bde | ||
|   | a8fadabaf1 | ||
|   | 44d0f78c1b | ||
|   | 38f9a015ca | ||
|   | c311cdc6f5 | ||
|   | a93e0f3284 | ||
|   | 14b3065ba4 | ||
|   | 3ea2d6a0a8 | ||
|   | c802290437 | ||
|   | f7781defe5 | ||
|   | 418420523a | ||
|   | d342a1f368 | ||
|   | 81f85361d5 | ||
|   | f1621b30ec | ||
|   | d4f6a594b6 | ||
|   | ff5ba5c131 | ||
|   | 4243f30308 | ||
|   | 813e91073d | ||
|   | 7250f22ff6 | ||
|   | db31a53bba | ||
|   | 3023f235a4 | ||
|   | 79cd8b4da5 | ||
|   | 8e4d311cd9 | ||
|   | 9bd8c86a94 | ||
|   | cbc0c1d0b6 | ||
|   | 49c37857d4 | ||
|   | b1139a4bf6 | ||
|   | 7e8559278e | ||
|   | 1e7f1c98fc | ||
|   | a802f25dd6 | ||
|   | f1d6d21d6d | ||
|   | a80302c513 | ||
|   | 1c46949da7 | ||
|   | 07a56454a0 | ||
|   | a0e72d02c8 | ||
|   | 455a59ca85 | ||
|   | 46d78af068 | ||
|   | 08d22fd3df | ||
|   | e6c691a8f8 | ||
|   | 4b0e5c445c | ||
|   | eb5cff1045 | ||
|   | 35c7792aa2 | ||
|   | 521688d630 | ||
|   | 75e2845c01 | ||
|   | 2f96283286 | ||
|   | cbe6e9b5f5 | ||
|   | 2ab79cf474 | ||
|   | 6ce34aba79 | ||
|   | 5eeb320b60 | ||
|   | 93310850d2 | ||
|   | a2880b12ca | ||
|   | cef2657048 | ||
|   | ccd85eb055 | ||
|   | 303b57779a | ||
|   | 6279816ecc | ||
|   | 4ae77261fa | ||
|   | 4b7d843b78 | ||
|   | 1c28df65c3 | ||
|   | 85b740f484 | ||
|   | f9929cb27d | ||
|   | bafab1ac07 | ||
|   | e05c262468 | ||
|   | acfb72246c | ||
|   | 9d51c4c340 | ||
|   | 18068effec | ||
|   | 7a3f7d3bba | ||
|   | 95aa48c456 | ||
|   | 6ea8ca991b | ||
|   | f1e551b960 | ||
|   | 772c54ec74 | ||
|   | 13cb789c18 | ||
|   | 42220c4268 | ||
|   | 3052506e2e | ||
|   | 0741daa7eb | ||
|   | b4aa554279 | ||
|   | 8fe2abe0ae | ||
|   | 5af789ae11 | ||
|   | 904a168d5c | ||
|   | 724441eddc | ||
|   | f68ab3edd1 | ||
|   | 68542aca3a | ||
|   | 594bc4203c | ||
|   | 57318b022d | ||
|   | 761159aa93 | ||
|   | 29dce26bf6 | ||
|   | 717ab69093 | ||
|   | 138a2cf08f | ||
|   | 81daf82647 | ||
|   | f3798bfb63 | ||
|   | bc07dfad2e | ||
|   | 8dd1c2a6cc | ||
|   | d10b657a54 | ||
|   | f90da739eb | ||
|   | d9cadf64e8 | ||
|   | 15d4a55cd8 | ||
|   | 309cbdb8be | ||
|   | 39a9ad0ce7 | ||
|   | 0f3c44c926 | ||
|   | a0e7c4a74c | ||
|   | 7d428030df | ||
|   | 00c395f689 | ||
|   | d8e1c73d26 | ||
|   | ffa4cc241b | ||
|   | 6f1b740c8f | ||
|   | 3406ba3ebf | 
| @@ -11,5 +11,11 @@ insert_final_newline = true | |||||||
| [*.md] | [*.md] | ||||||
| trim_trailing_whitespace = false | trim_trailing_whitespace = false | ||||||
|  |  | ||||||
|  | [*.sexp] | ||||||
|  | indent_size = 2 | ||||||
|  |  | ||||||
|  | [*.yml] | ||||||
|  | indent_size = 2 | ||||||
|  |  | ||||||
| [*.properties] | [*.properties] | ||||||
| insert_final_newline = false | insert_final_newline = false | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								.gitattributes
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								.gitattributes
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,2 @@ | |||||||
|  | # Ignore changes in generated files | ||||||
|  | src/generated/resources/data/** linguist-generated | ||||||
							
								
								
									
										1
									
								
								.github/ISSUE_TEMPLATE/bug_report.md
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.github/ISSUE_TEMPLATE/bug_report.md
									
									
									
									
										vendored
									
									
								
							| @@ -12,4 +12,5 @@ labels: bug | |||||||
| ## Useful information to include: | ## Useful information to include: | ||||||
|  - Minecraft version |  - Minecraft version | ||||||
|  - CC: Tweaked version |  - CC: Tweaked version | ||||||
|  |  - 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. |  - 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. | ||||||
|   | |||||||
							
								
								
									
										50
									
								
								.github/workflows/main-ci.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										50
									
								
								.github/workflows/main-ci.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,50 @@ | |||||||
|  | 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@v1 | ||||||
|  |       with: | ||||||
|  |         path: ~/.gradle/caches | ||||||
|  |         key: ${{ runner.os }}-gradle-${{ hashFiles('gradle.properties') }} | ||||||
|  |         restore-keys: | | ||||||
|  |           ${{ runner.os }}-gradle- | ||||||
|  |  | ||||||
|  |     - name: Build with Gradle | ||||||
|  |       run: ./gradlew build --no-daemon || ./gradlew build --no-daemon | ||||||
|  |  | ||||||
|  |     - name: Upload Jar | ||||||
|  |       uses: actions/upload-artifact@v1 | ||||||
|  |       with: | ||||||
|  |         name: CC-Tweaked | ||||||
|  |         path: build/libs | ||||||
|  |  | ||||||
|  |     - name: Upload Coverage | ||||||
|  |       run: bash <(curl -s https://codecov.io/bash) | ||||||
|  |       continue-on-error: true | ||||||
|  |  | ||||||
|  |     - name: Generate Java documentation stubs | ||||||
|  |       run: ./gradlew luaJavadoc --no-daemon | ||||||
|  |  | ||||||
|  |     - name: Lint Lua code | ||||||
|  |       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 | ||||||
|  |         bin/illuaminate lint | ||||||
|  |  | ||||||
|  |     - name: Check whitespace | ||||||
|  |       run: python3 tools/check-lines.py | ||||||
							
								
								
									
										19
									
								
								.github/workflows/make-doc.sh
									
									
									
									
										vendored
									
									
										Executable file
									
								
							
							
						
						
									
										19
									
								
								.github/workflows/make-doc.sh
									
									
									
									
										vendored
									
									
										Executable file
									
								
							| @@ -0,0 +1,19 @@ | |||||||
|  | #!/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
									
									
										Normal file
									
								
							
							
						
						
									
										50
									
								
								.github/workflows/make-doc.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,50 @@ | |||||||
|  | name: Build documentation | ||||||
|  |  | ||||||
|  | on: | ||||||
|  |   push: | ||||||
|  |     branches: | ||||||
|  |     - mc-1.15.x | ||||||
|  |  | ||||||
|  | jobs: | ||||||
|  |   make_doc: | ||||||
|  |     name: Build | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |  | ||||||
|  |     steps: | ||||||
|  |     - uses: actions/checkout@v1 | ||||||
|  |  | ||||||
|  |     - name: Set up Java 8 | ||||||
|  |       uses: actions/setup-java@v1 | ||||||
|  |       with: | ||||||
|  |         java-version: 8 | ||||||
|  |  | ||||||
|  |     - name: Cache gradle dependencies | ||||||
|  |       uses: actions/cache@v1 | ||||||
|  |       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,6 +3,8 @@ | |||||||
| /logs | /logs | ||||||
| /build | /build | ||||||
| /out | /out | ||||||
|  | /doc/out/ | ||||||
|  | /node_modules | ||||||
|  |  | ||||||
| # Runtime directories | # Runtime directories | ||||||
| /run | /run | ||||||
| @@ -15,3 +17,13 @@ | |||||||
| .idea | .idea | ||||||
| .gradle | .gradle | ||||||
| *.DS_Store | *.DS_Store | ||||||
|  |  | ||||||
|  | /.classpath | ||||||
|  | /.project | ||||||
|  | /.settings | ||||||
|  | /.vscode | ||||||
|  | bin/ | ||||||
|  | *.launch | ||||||
|  |  | ||||||
|  | /src/generated/resources/.cache | ||||||
|  | /src/web/mount/*.d.ts | ||||||
|   | |||||||
							
								
								
									
										34
									
								
								.luacheckrc
									
									
									
									
									
								
							
							
						
						
									
										34
									
								
								.luacheckrc
									
									
									
									
									
								
							| @@ -1,34 +0,0 @@ | |||||||
| 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
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								.travis.yml
									
									
									
									
									
								
							| @@ -1,14 +0,0 @@ | |||||||
| 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 |  | ||||||
							
								
								
									
										41
									
								
								CONTRIBUTING.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										41
									
								
								CONTRIBUTING.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,41 @@ | |||||||
|  | # 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. | ||||||
|  |  | ||||||
|  | ## 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). | ||||||
|  |  | ||||||
|  | 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. | ||||||
|  |  | ||||||
|  | ### 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. | ||||||
|  |  | ||||||
|  | ## 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! | ||||||
|  |  | ||||||
|  | [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-usage]: https://github.com/SquidDev/illuaminate/blob/master/README.md#usage | ||||||
|  | [weblate]: https://i18n.tweaked.cc/projects/cc-tweaked/minecraft/ | ||||||
							
								
								
									
										33
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										33
									
								
								README.md
									
									
									
									
									
								
							| @@ -1,5 +1,5 @@ | |||||||
| #  | #  | ||||||
| [](https://travis-ci.org/SquidDev-CC/CC-Tweaked "Current build status") [](https://minecraft.curseforge.com/projects/cc-tweaked "Download CC: Tweaked on CurseForge") | [](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, | CC: Tweaked is a fork of [ComputerCraft](https://github.com/dan200/ComputerCraft), adding programmable computers, | ||||||
| turtles and more to Minecraft. | turtles and more to Minecraft. | ||||||
| @@ -37,39 +37,36 @@ several features have been included, such as full block modems, the Cobalt runti | |||||||
| computers. | computers. | ||||||
|  |  | ||||||
| ## Contributing | ## Contributing | ||||||
| Any contribution is welcome, be that using the mod, reporting bugs or contributing code. In order to start helping | Any contribution is welcome, be that using the mod, reporting bugs or contributing code. If you want to get started | ||||||
| develop CC:T, you'll need to follow these steps: | developing the mod, [check out the instructions here](CONTRIBUTING.md#developing). | ||||||
|  |  | ||||||
|  - **Clone the repository:** `git clone https://github.com/SquidDev-CC/CC-Tweaked.git && cd CC-Tweaked` |  | ||||||
|  - **Setup Forge:** `./gradlew setupDecompWorkspace` |  | ||||||
|  - **Test your changes:** `./gradlew runClient` (or run the `GradleStart` class from your IDE). |  | ||||||
|  |  | ||||||
| If you want to run CC:T in a normal Minecraft instance, run `./gradlew build` and copy the `.jar` from `build/libs`. |  | ||||||
|  |  | ||||||
| ## Community | ## Community | ||||||
| If you need help getting started with CC: Tweaked, want to show off your latest project, or just want to chat about | 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.gg/H2UyJXe)! | 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 | There's also a fairly populated, albeit quiet [IRC channel](http://webchat.esper.net/?channels=computercraft), if that's | ||||||
| that's more your cup of tea. | 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 | 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! | report exploits). You'll get a far quicker response if you ask the whole community! | ||||||
|  |  | ||||||
| ## Using | ## Using | ||||||
| If you want to depend on CC: Tweaked, we have a maven repo. However, you should be wary that some functionality is only | 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) | ||||||
| exposed by CC:T's API and not vanilla ComputerCraft. If you wish to support all variations of ComputerCraft, I recommend | dependency in your `mods.toml` file, with the appropriate version bounds, to ensure that API functionality you depend | ||||||
| using [cc.crzd.me's maven](https://cc.crzd.me/maven/) instead. | on is present. | ||||||
|  |  | ||||||
| ```groovy | ```groovy | ||||||
| dependencies { | repositories { | ||||||
|   maven { url 'https://squiddev.cc/maven/' } |   maven { url 'https://squiddev.cc/maven/' } | ||||||
| } | } | ||||||
|  |  | ||||||
| dependencies { | dependencies { | ||||||
|   implementation "org.squiddev:cc-tweaked-${mc_version}:${cct_version}" |   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 | 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 | 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. | 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/). | ||||||
|   | |||||||
							
								
								
									
										247
									
								
								build.gradle
									
									
									
									
									
								
							
							
						
						
									
										247
									
								
								build.gradle
									
									
									
									
									
								
							| @@ -4,19 +4,22 @@ buildscript { | |||||||
|         mavenCentral() |         mavenCentral() | ||||||
|         maven { |         maven { | ||||||
|             name = "forge" |             name = "forge" | ||||||
|             url = "http://files.minecraftforge.net/maven" |             url = "https://files.minecraftforge.net/maven" | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     dependencies { |     dependencies { | ||||||
|         classpath 'com.google.code.gson:gson:2.8.1' |         classpath 'com.google.code.gson:gson:2.8.1' | ||||||
|         classpath 'net.minecraftforge.gradle:ForgeGradle:3.0.117' |         classpath 'net.minecraftforge.gradle:ForgeGradle:3.0.190' | ||||||
|         classpath 'net.sf.proguard:proguard-gradle:6.1.0beta2' |         classpath 'net.sf.proguard:proguard-gradle:6.1.0beta2' | ||||||
|         classpath 'org.ajoberstar.grgit:grgit-gradle:3.0.0' |         classpath 'org.ajoberstar.grgit:grgit-gradle:3.0.0' | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| plugins { | plugins { | ||||||
|     id 'com.matthewprenger.cursegradle' version '1.2.0' |     id "checkstyle" | ||||||
|  |     id "jacoco" | ||||||
|  |     id "com.github.hierynomus.license" version "0.15.0" | ||||||
|  |     id "com.matthewprenger.cursegradle" version "1.3.0" | ||||||
|     id "com.github.breadmoirai.github-release" version "2.2.4" |     id "com.github.breadmoirai.github-release" version "2.2.4" | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -30,6 +33,8 @@ version = mod_version | |||||||
| group = "org.squiddev" | group = "org.squiddev" | ||||||
| archivesBaseName = "cc-tweaked-${mc_version}" | archivesBaseName = "cc-tweaked-${mc_version}" | ||||||
|  |  | ||||||
|  | sourceCompatibility = targetCompatibility = compileJava.sourceCompatibility = compileJava.targetCompatibility = '1.8' | ||||||
|  |  | ||||||
| minecraft { | minecraft { | ||||||
|     runs { |     runs { | ||||||
|         client { |         client { | ||||||
| @@ -45,8 +50,8 @@ minecraft { | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         server { |         server { | ||||||
|             workingDirectory project.file('run') |             workingDirectory project.file("run/server-${mc_version}") | ||||||
|             property 'forge.logging.markers', 'SCAN,REGISTRIES,REGISTRYDUMP' |             property 'forge.logging.markers', 'REGISTRIES,REGISTRYDUMP' | ||||||
|             property 'forge.logging.console.level', 'debug' |             property 'forge.logging.console.level', 'debug' | ||||||
|  |  | ||||||
|             mods { |             mods { | ||||||
| @@ -55,6 +60,19 @@ minecraft { | |||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  |         data { | ||||||
|  |             workingDirectory project.file('run') | ||||||
|  |             property 'forge.logging.markers', 'REGISTRIES,REGISTRYDUMP' | ||||||
|  |             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 | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     mappings channel: 'snapshot', version: "${mappings_version}".toString() |     mappings channel: 'snapshot', version: "${mappings_version}".toString() | ||||||
| @@ -62,68 +80,83 @@ minecraft { | |||||||
|     accessTransformer file('src/main/resources/META-INF/accesstransformer.cfg') |     accessTransformer file('src/main/resources/META-INF/accesstransformer.cfg') | ||||||
| } | } | ||||||
|  |  | ||||||
| repositories { | sourceSets { | ||||||
|     maven { |     main.resources { | ||||||
|         name "JEI" |         srcDir 'src/generated/resources' | ||||||
|         url  "http://dvs1.progwml6.com/files/maven" |  | ||||||
|     } |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | repositories { | ||||||
|  |     mavenCentral() | ||||||
|     maven { |     maven { | ||||||
|         name "SquidDev" |         name "SquidDev" | ||||||
|         url "https://squiddev.cc/maven" |         url "https://squiddev.cc/maven" | ||||||
|     } |     } | ||||||
|     ivy { |  | ||||||
|         name "Charset" |  | ||||||
|         artifactPattern "https://asie.pl/files/mods/Charset/LibOnly/[module]-[revision](-[classifier]).[ext]" |  | ||||||
|     } |  | ||||||
|     maven { |  | ||||||
|         name "Amadornes" |  | ||||||
|         url "http://maven.amadornes.com/" |  | ||||||
|     } |  | ||||||
| } | } | ||||||
|  |  | ||||||
| configurations { | configurations { | ||||||
|     shade |     shade | ||||||
|     compile.extendsFrom shade |     compile.extendsFrom shade | ||||||
|     deployerJars |     deployerJars | ||||||
|  |     cctJavadoc | ||||||
| } | } | ||||||
|  |  | ||||||
| dependencies { | dependencies { | ||||||
|  |     checkstyle "com.puppycrawl.tools:checkstyle:8.25" | ||||||
|  |  | ||||||
|     minecraft "net.minecraftforge:forge:${mc_version}-${forge_version}" |     minecraft "net.minecraftforge:forge:${mc_version}-${forge_version}" | ||||||
|  |  | ||||||
|     compileOnly fg.deobf("mezz.jei:jei-1.13.2:5.0.0.20:api") |     compileOnly fg.deobf("mezz.jei:jei-1.16.4:7.6.0.58:api") | ||||||
|     // deobfProvided "pl.asie:Charset-Lib:0.5.4.6" |     compileOnly fg.deobf("com.blamejared.crafttweaker:CraftTweaker-1.16.4:7.0.0.63") | ||||||
|     // deobfProvided "MCMultiPart2:MCMultiPart:2.5.3" |  | ||||||
|  |  | ||||||
|     runtimeOnly fg.deobf("mezz.jei:jei-1.13.2:5.0.0.20") |     runtimeOnly fg.deobf("mezz.jei:jei-1.16.4:7.6.0.58") | ||||||
|  |  | ||||||
|     shade 'org.squiddev:Cobalt:0.5.0-SNAPSHOT' |     compileOnly 'com.google.auto.service:auto-service:1.0-rc7' | ||||||
|  |     annotationProcessor 'com.google.auto.service:auto-service:1.0-rc7' | ||||||
|  |  | ||||||
|     testImplementation 'org.junit.jupiter:junit-jupiter-api:5.1.0' |     shade 'org.squiddev:Cobalt:0.5.1-SNAPSHOT' | ||||||
|     testRuntimeOnly 'org.junit.jupiter:junit-jupiter-engine:5.1.0' |  | ||||||
|  |     testImplementation 'org.junit.jupiter:junit-jupiter-api:5.7.0' | ||||||
|  |     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' | ||||||
|  |  | ||||||
|     deployerJars "org.apache.maven.wagon:wagon-ssh:3.0.0" |     deployerJars "org.apache.maven.wagon:wagon-ssh:3.0.0" | ||||||
|  |  | ||||||
|  |     cctJavadoc 'cc.tweaked:cct-javadoc:1.3.0' | ||||||
| } | } | ||||||
|  |  | ||||||
| sourceSets { | // Compile tasks | ||||||
|     main { |  | ||||||
|         java { |  | ||||||
|             exclude 'dan200/computercraft/shared/integration/mcmp' |  | ||||||
|             exclude 'dan200/computercraft/shared/integration/charset' |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| javadoc { | javadoc { | ||||||
|     include "dan200/computercraft/api/**/*.java" |     include "dan200/computercraft/api/**/*.java" | ||||||
| } | } | ||||||
|  |  | ||||||
|  | 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" | ||||||
|  |  | ||||||
|  |     // Attempt to run under Java 11 (any Java >= 9 will work though). | ||||||
|  |     if(System.getProperty("java.version").startsWith("1.") | ||||||
|  |         && (System.getenv("JAVA_HOME_11_X64") != null || project.hasProperty("java11Home"))) { | ||||||
|  |         executable = "${System.getenv("JAVA_HOME_11_X64") ?: project.property("java11Home")}/bin/javadoc" | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
| jar { | jar { | ||||||
|     dependsOn javadoc |     dependsOn javadoc | ||||||
|  |  | ||||||
|     manifest { |     manifest { | ||||||
|         attributes(["Specification-Title": "computercraft", |         attributes(["Specification-Title": "computercraft", | ||||||
|                     "Specification-Vendor": "SquidDev", |                     "Specification-Vendor": "SquidDev", | ||||||
|                     "Specification-Version": "25.0", |                     "Specification-Version": "1", | ||||||
|                     "Implementation-Title": "CC: Tweaked", |                     "Implementation-Title": "CC: Tweaked", | ||||||
|                     "Implementation-Version": "${mod_version}", |                     "Implementation-Version": "${mod_version}", | ||||||
|                     "Implementation-Vendor" :"SquidDev", |                     "Implementation-Vendor" :"SquidDev", | ||||||
| @@ -137,12 +170,20 @@ jar { | |||||||
|     from configurations.shade.collect { it.isDirectory() ? it : zipTree(it) } |     from configurations.shade.collect { it.isDirectory() ? it : zipTree(it) } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | [compileJava, compileTestJava].forEach { | ||||||
|  |     it.configure { | ||||||
|  |         options.compilerArgs << "-Xlint" << "-Xlint:-processing" | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
| import java.nio.charset.StandardCharsets | import java.nio.charset.StandardCharsets | ||||||
| import java.nio.file.* | import java.nio.file.* | ||||||
| import java.util.zip.* | import java.util.zip.* | ||||||
|  |  | ||||||
| import com.google.gson.GsonBuilder | import com.google.gson.GsonBuilder | ||||||
| import com.google.gson.JsonElement | import com.google.gson.JsonElement | ||||||
|  | import com.hierynomus.gradle.license.tasks.LicenseCheck | ||||||
|  | import com.hierynomus.gradle.license.tasks.LicenseFormat | ||||||
| import org.ajoberstar.grgit.Grgit | import org.ajoberstar.grgit.Grgit | ||||||
| import proguard.gradle.ProGuardTask | import proguard.gradle.ProGuardTask | ||||||
|  |  | ||||||
| @@ -155,6 +196,7 @@ task proguard(type: ProGuardTask, dependsOn: jar) { | |||||||
|  |  | ||||||
|     // Add the main runtime jar and all non-shadowed dependencies |     // Add the main runtime jar and all non-shadowed dependencies | ||||||
|     libraryjars "${System.getProperty('java.home')}/lib/rt.jar" |     libraryjars "${System.getProperty('java.home')}/lib/rt.jar" | ||||||
|  |     libraryjars "${System.getProperty('java.home')}/lib/jce.jar" | ||||||
|     doFirst { |     doFirst { | ||||||
|         sourceSets.main.compileClasspath |         sourceSets.main.compileClasspath | ||||||
|             .filter { !it.name.contains("Cobalt") } |             .filter { !it.name.contains("Cobalt") } | ||||||
| @@ -170,9 +212,6 @@ task proguard(type: ProGuardTask, dependsOn: jar) { | |||||||
|     // Preserve ComputerCraft classes - we only want to strip shadowed files. |     // Preserve ComputerCraft classes - we only want to strip shadowed files. | ||||||
|     keep 'class dan200.computercraft.** { *; }' |     keep 'class dan200.computercraft.** { *; }' | ||||||
|  |  | ||||||
|     // Preserve the constructors in Cobalt library class, as we init them via reflection |  | ||||||
|     keepclassmembers 'class org.squiddev.cobalt.lib.** { <init>(...); }' |  | ||||||
|  |  | ||||||
|     // LWJGL and Apache bundle Java 9 versions, which is great, but rather breaks Proguard |     // LWJGL and Apache bundle Java 9 versions, which is great, but rather breaks Proguard | ||||||
|     dontwarn 'module-info' |     dontwarn 'module-info' | ||||||
|     dontwarn 'org.apache.**,org.lwjgl.**' |     dontwarn 'org.apache.**,org.lwjgl.**' | ||||||
| @@ -191,8 +230,6 @@ task proguardMove(dependsOn: proguard) { | |||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| processResources { | processResources { | ||||||
|     inputs.property "version", mod_version |     inputs.property "version", mod_version | ||||||
|     inputs.property "mcversion", mc_version |     inputs.property "mcversion", mc_version | ||||||
| @@ -242,6 +279,7 @@ task compressJson(dependsOn: jar) { | |||||||
|         // Copy over all files in the current jar to the new one, running json files from GSON. As pretty printing |         // Copy over all files in the current jar to the new one, running json files from GSON. As pretty printing | ||||||
|         // is turned off, they should be minified. |         // is turned off, they should be minified. | ||||||
|         new ZipFile(jarPath).withCloseable { inJar -> |         new ZipFile(jarPath).withCloseable { inJar -> | ||||||
|  |             tempPath.getParentFile().mkdirs() | ||||||
|             new ZipOutputStream(new BufferedOutputStream(new FileOutputStream(tempPath))).withCloseable { outJar -> |             new ZipOutputStream(new BufferedOutputStream(new FileOutputStream(tempPath))).withCloseable { outJar -> | ||||||
|                 inJar.entries().each { entry -> |                 inJar.entries().each { entry -> | ||||||
|                     if(entry.directory) { |                     if(entry.directory) { | ||||||
| @@ -269,6 +307,117 @@ task compressJson(dependsOn: jar) { | |||||||
|  |  | ||||||
| assemble.dependsOn compressJson | assemble.dependsOn compressJson | ||||||
|  |  | ||||||
|  | // Web tasks | ||||||
|  |  | ||||||
|  | import org.apache.tools.ant.taskdefs.condition.Os | ||||||
|  |  | ||||||
|  | List<String> mkCommand(String command) { | ||||||
|  |     return Os.isFamily(Os.FAMILY_WINDOWS) ? ["cmd", "/c", command] : ["sh", "-c", command] | ||||||
|  | } | ||||||
|  |  | ||||||
|  | task rollup(type: Exec) { | ||||||
|  |     group = "build" | ||||||
|  |     description = "Bundles JS into rollup" | ||||||
|  |  | ||||||
|  |     inputs.files(fileTree("src/web")).withPropertyName("sources") | ||||||
|  |     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 { | ||||||
|  |     reports { | ||||||
|  |         xml.enabled true | ||||||
|  |         html.enabled 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 rootProject.file('config/license/main.txt') | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | [licenseTest, licenseFormatTest].forEach { | ||||||
|  |     it.configure { | ||||||
|  |         include("**/*.java") | ||||||
|  |         header rootProject.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 rootProject.file('config/license/api.txt') | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // Upload tasks | ||||||
|  |  | ||||||
| task checkRelease { | task checkRelease { | ||||||
|     group "upload" |     group "upload" | ||||||
|     description "Verifies that everything is ready for a release" |     description "Verifies that everything is ready for a release" | ||||||
| @@ -307,7 +456,7 @@ task checkRelease { | |||||||
|         if (!ok) throw new IllegalStateException("Could not check release") |         if (!ok) throw new IllegalStateException("Could not check release") | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | check.dependsOn checkRelease | ||||||
|  |  | ||||||
| curseforge { | curseforge { | ||||||
|     apiKey = project.hasProperty('curseForgeApiKey') ? project.curseForgeApiKey : '' |     apiKey = project.hasProperty('curseForgeApiKey') ? project.curseForgeApiKey : '' | ||||||
| @@ -379,7 +528,9 @@ githubRelease { | |||||||
|     token project.hasProperty('githubApiKey') ? project.githubApiKey : '' |     token project.hasProperty('githubApiKey') ? project.githubApiKey : '' | ||||||
|     owner 'SquidDev-CC' |     owner 'SquidDev-CC' | ||||||
|     repo 'CC-Tweaked' |     repo 'CC-Tweaked' | ||||||
|     targetCommitish { Grgit.open(dir: '.').branch.current().name } |     try { | ||||||
|  |         targetCommitish = Grgit.open(dir: '.').branch.current().name | ||||||
|  |     } catch(Exception ignored) { } | ||||||
|  |  | ||||||
|     tagName "v${mc_version}-${mod_version}" |     tagName "v${mc_version}-${mod_version}" | ||||||
|     releaseName "[${mc_version}] ${mod_version}" |     releaseName "[${mc_version}] ${mod_version}" | ||||||
| @@ -399,19 +550,3 @@ task uploadAll(dependsOn: uploadTasks) { | |||||||
|     group "upload" |     group "upload" | ||||||
|     description "Uploads to all repositories (Maven, Curse, GitHub release)" |     description "Uploads to all repositories (Maven, Curse, GitHub release)" | ||||||
| } | } | ||||||
|  |  | ||||||
| test { |  | ||||||
|     useJUnitPlatform() |  | ||||||
|     testLogging { |  | ||||||
|         events "passed", "skipped", "failed" |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| gradle.projectsEvaluated { |  | ||||||
|     reobfJar.dependsOn proguardMove |  | ||||||
|  |  | ||||||
|     tasks.withType(JavaCompile) { |  | ||||||
|         options.compilerArgs << "-Xlint" << "-Xlint:-processing" // Causes Forge build to fail << "-Werror" |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										173
									
								
								config/checkstyle/checkstyle.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										173
									
								
								config/checkstyle/checkstyle.xml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,173 @@ | |||||||
|  | <?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/checkstyle/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" /> | ||||||
|  |         <!-- Allow an optional m_ on private members --> | ||||||
|  |         <module name="MemberName"> | ||||||
|  |             <property name="applyToPrivate" value="false" /> | ||||||
|  |             <property name="applyToPackage" value="false" /> | ||||||
|  |         </module> | ||||||
|  |         <module name="MemberName"> | ||||||
|  |             <property name="format" value="^(m_)?[a-z][a-zA-Z0-9]*$" /> | ||||||
|  |             <property name="applyToPrivate" value="true" /> | ||||||
|  |             <property name="applyToPackage" value="true" /> | ||||||
|  |         </module> | ||||||
|  |         <module name="MethodName" /> | ||||||
|  |         <module name="MethodTypeParameterName" /> | ||||||
|  |         <module name="PackageName"> | ||||||
|  |             <property name="format" value="^dan200\.computercraf(\.[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> | ||||||
							
								
								
									
										15
									
								
								config/checkstyle/suppressions.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								config/checkstyle/suppressions.xml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,15 @@ | |||||||
|  | <?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" /> | ||||||
|  |  | ||||||
|  |     <!-- Do not check for missing package Javadoc. --> | ||||||
|  |     <suppress checks="JavadocStyle" files=".*[\\/]package-info.java" /> | ||||||
|  |  | ||||||
|  |     <!-- The commands API is documented in Lua. --> | ||||||
|  |     <suppress checks="SummaryJavadocCheck" files=".*[\\/]CommandAPI.java" /> | ||||||
|  | </suppressions> | ||||||
							
								
								
									
										3
									
								
								config/license/api.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								config/license/api.txt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,3 @@ | |||||||
|  | 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. | ||||||
							
								
								
									
										3
									
								
								config/license/main.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								config/license/main.txt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,3 @@ | |||||||
|  | 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
									
								
								doc/head.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								doc/head.html
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | <meta name="theme-color" content="#c8d87c"> | ||||||
							
								
								
									
										11
									
								
								doc/index.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								doc/index.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,11 @@ | |||||||
|  | #  [](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" | ||||||
| Before Width: | Height: | Size: 2.2 KiB After Width: | Height: | Size: 2.2 KiB | 
							
								
								
									
										34
									
								
								doc/stub/fs.lua
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										34
									
								
								doc/stub/fs.lua
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,34 @@ | |||||||
|  | ---  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 | ||||||
							
								
								
									
										125
									
								
								doc/stub/global.lua
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										125
									
								
								doc/stub/global.lua
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,125 @@ | |||||||
|  | --[[- | ||||||
|  | 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 an 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) | ||||||
|  | ]] | ||||||
|  | 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 | ||||||
|  | _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 | ||||||
|  | ]] | ||||||
|  | _CC_DEFAULT_SETTINGS = _CC_DEFAULT_SETTINGS | ||||||
							
								
								
									
										157
									
								
								doc/stub/http.lua
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										157
									
								
								doc/stub/http.lua
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,157 @@ | |||||||
|  | --- 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.computercraft.cc](https://example.computercraft.cc), | ||||||
|  | -- and print the returned page. | ||||||
|  | -- ```lua | ||||||
|  | -- local request = http.get("https://example.computercraft.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.computercraft.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
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										125
									
								
								doc/stub/os.lua
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,125 @@ | |||||||
|  | -- Defined in bios.lua | ||||||
|  |  | ||||||
|  | --[[- Loads the given API into the global environment. | ||||||
|  |  | ||||||
|  | **Warning** This function is deprecated. Use of this function will pollute the | ||||||
|  | global table, use @{require} instead. | ||||||
|  |  | ||||||
|  | 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 Use @{require}. | ||||||
|  | ]] | ||||||
|  | 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 Use @{require}. | ||||||
|  | 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
									
								
								doc/stub/turtle.lua
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								doc/stub/turtle.lua
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | function craft(limit) end | ||||||
| @@ -1,7 +1,7 @@ | |||||||
| # Mod properties | # Mod properties | ||||||
| mod_version=1.83.1 | mod_version=1.95.1 | ||||||
|  |  | ||||||
| # Minecraft properties | # Minecraft properties (update mods.toml when changing) | ||||||
| mc_version=1.13.2 | mc_version=1.16.4 | ||||||
| forge_version=25.0.219 | forge_version=35.0.1 | ||||||
| mappings_version=20190530-1.13.2 | mappings_version=20201028-1.16.3 | ||||||
|   | |||||||
							
								
								
									
										121
									
								
								illuaminate.sexp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										121
									
								
								illuaminate.sexp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,121 @@ | |||||||
|  | ; -*- mode: Lisp;-*- | ||||||
|  |  | ||||||
|  | (sources | ||||||
|  |   /doc/stub/ | ||||||
|  |   /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")) | ||||||
|  |  | ||||||
|  |   (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 | ||||||
|  |   (; Java APIs | ||||||
|  |    /doc/stub/http.lua | ||||||
|  |    /doc/stub/os.lua | ||||||
|  |    /doc/stub/turtle.lua | ||||||
|  |    /doc/stub/global.lua | ||||||
|  |    ; Java generated APIs | ||||||
|  |    /build/docs/luaJavadoc/turtle.lua | ||||||
|  |    ; Peripherals | ||||||
|  |    /build/docs/luaJavadoc/drive.lua | ||||||
|  |    /build/docs/luaJavadoc/speaker.lua | ||||||
|  |    /build/docs/luaJavadoc/printer.lua | ||||||
|  |    ; Generic peripherals | ||||||
|  |    /build/docs/luaJavadoc/fluid_storage.lua | ||||||
|  |    ; 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 the BIOS using its own deprecated members for now. | ||||||
|  | (at /src/main/resources/*/computercraft/lua/bios.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__))) | ||||||
							
								
								
									
										172
									
								
								package-lock.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										172
									
								
								package-lock.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,172 @@ | |||||||
|  | { | ||||||
|  |   "name": "tweaked.cc", | ||||||
|  |   "version": "1.0.0", | ||||||
|  |   "lockfileVersion": 1, | ||||||
|  |   "requires": true, | ||||||
|  |   "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
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								package.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,18 @@ | |||||||
|  | { | ||||||
|  |   "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" | ||||||
|  |   } | ||||||
|  | } | ||||||
							
								
								
									
										55
									
								
								rollup.config.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										55
									
								
								rollup.config.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,55 @@ | |||||||
|  | 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; | ||||||
|  |             }, | ||||||
|  |         } | ||||||
|  |     ], | ||||||
|  | }; | ||||||
| @@ -0,0 +1,49 @@ | |||||||
|  | { | ||||||
|  |   "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 | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -0,0 +1,49 @@ | |||||||
|  | { | ||||||
|  |   "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 | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -0,0 +1,49 @@ | |||||||
|  | { | ||||||
|  |   "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 | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -0,0 +1,852 @@ | |||||||
|  | { | ||||||
|  |   "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 | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -0,0 +1,852 @@ | |||||||
|  | { | ||||||
|  |   "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 | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -0,0 +1,8 @@ | |||||||
|  | { | ||||||
|  |   "parent": "block/orientable", | ||||||
|  |   "textures": { | ||||||
|  |     "top": "computercraft:block/computer_advanced_top", | ||||||
|  |     "side": "computercraft:block/computer_advanced_side", | ||||||
|  |     "front": "computercraft:block/computer_advanced_front_blink" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -0,0 +1,8 @@ | |||||||
|  | { | ||||||
|  |   "parent": "block/orientable", | ||||||
|  |   "textures": { | ||||||
|  |     "top": "computercraft:block/computer_advanced_top", | ||||||
|  |     "side": "computercraft:block/computer_advanced_side", | ||||||
|  |     "front": "computercraft:block/computer_advanced_front" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -0,0 +1,8 @@ | |||||||
|  | { | ||||||
|  |   "parent": "block/orientable", | ||||||
|  |   "textures": { | ||||||
|  |     "top": "computercraft:block/computer_advanced_top", | ||||||
|  |     "side": "computercraft:block/computer_advanced_side", | ||||||
|  |     "front": "computercraft:block/computer_advanced_front_on" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -0,0 +1,8 @@ | |||||||
|  | { | ||||||
|  |   "parent": "block/orientable", | ||||||
|  |   "textures": { | ||||||
|  |     "top": "computercraft:block/computer_command_top", | ||||||
|  |     "side": "computercraft:block/computer_command_side", | ||||||
|  |     "front": "computercraft:block/computer_command_front_blink" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -0,0 +1,8 @@ | |||||||
|  | { | ||||||
|  |   "parent": "block/orientable", | ||||||
|  |   "textures": { | ||||||
|  |     "top": "computercraft:block/computer_command_top", | ||||||
|  |     "side": "computercraft:block/computer_command_side", | ||||||
|  |     "front": "computercraft:block/computer_command_front" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -0,0 +1,8 @@ | |||||||
|  | { | ||||||
|  |   "parent": "block/orientable", | ||||||
|  |   "textures": { | ||||||
|  |     "top": "computercraft:block/computer_command_top", | ||||||
|  |     "side": "computercraft:block/computer_command_side", | ||||||
|  |     "front": "computercraft:block/computer_command_front_on" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -0,0 +1,8 @@ | |||||||
|  | { | ||||||
|  |   "parent": "block/orientable", | ||||||
|  |   "textures": { | ||||||
|  |     "top": "computercraft:block/computer_normal_top", | ||||||
|  |     "side": "computercraft:block/computer_normal_side", | ||||||
|  |     "front": "computercraft:block/computer_normal_front_blink" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -0,0 +1,8 @@ | |||||||
|  | { | ||||||
|  |   "parent": "block/orientable", | ||||||
|  |   "textures": { | ||||||
|  |     "top": "computercraft:block/computer_normal_top", | ||||||
|  |     "side": "computercraft:block/computer_normal_side", | ||||||
|  |     "front": "computercraft:block/computer_normal_front" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -0,0 +1,8 @@ | |||||||
|  | { | ||||||
|  |   "parent": "block/orientable", | ||||||
|  |   "textures": { | ||||||
|  |     "top": "computercraft:block/computer_normal_top", | ||||||
|  |     "side": "computercraft:block/computer_normal_side", | ||||||
|  |     "front": "computercraft:block/computer_normal_front_on" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -0,0 +1,9 @@ | |||||||
|  | { | ||||||
|  |   "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" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -0,0 +1,9 @@ | |||||||
|  | { | ||||||
|  |   "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" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -0,0 +1,9 @@ | |||||||
|  | { | ||||||
|  |   "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" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -0,0 +1,9 @@ | |||||||
|  | { | ||||||
|  |   "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" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -0,0 +1,9 @@ | |||||||
|  | { | ||||||
|  |   "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" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -0,0 +1,9 @@ | |||||||
|  | { | ||||||
|  |   "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" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -0,0 +1,9 @@ | |||||||
|  | { | ||||||
|  |   "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" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -0,0 +1,9 @@ | |||||||
|  | { | ||||||
|  |   "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" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -0,0 +1,9 @@ | |||||||
|  | { | ||||||
|  |   "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" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -0,0 +1,9 @@ | |||||||
|  | { | ||||||
|  |   "parent": "computercraft:block/monitor_base", | ||||||
|  |   "textures": { | ||||||
|  |     "front": "computercraft:block/monitor_advanced_28", | ||||||
|  |     "side": "computercraft:block/monitor_advanced_6", | ||||||
|  |     "top": "computercraft:block/monitor_advanced_1", | ||||||
|  |     "back": "computercraft:block/monitor_advanced_42" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -0,0 +1,9 @@ | |||||||
|  | { | ||||||
|  |   "parent": "computercraft:block/monitor_base", | ||||||
|  |   "textures": { | ||||||
|  |     "front": "computercraft:block/monitor_advanced_17", | ||||||
|  |     "side": "computercraft:block/monitor_advanced_4", | ||||||
|  |     "top": "computercraft:block/monitor_advanced_3", | ||||||
|  |     "back": "computercraft:block/monitor_advanced_35" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -0,0 +1,9 @@ | |||||||
|  | { | ||||||
|  |   "parent": "computercraft:block/monitor_base", | ||||||
|  |   "textures": { | ||||||
|  |     "front": "computercraft:block/monitor_advanced_29", | ||||||
|  |     "side": "computercraft:block/monitor_advanced_7", | ||||||
|  |     "top": "computercraft:block/monitor_advanced_3", | ||||||
|  |     "back": "computercraft:block/monitor_advanced_47" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -0,0 +1,9 @@ | |||||||
|  | { | ||||||
|  |   "parent": "computercraft:block/monitor_base", | ||||||
|  |   "textures": { | ||||||
|  |     "front": "computercraft:block/monitor_advanced_23", | ||||||
|  |     "side": "computercraft:block/monitor_advanced_5", | ||||||
|  |     "top": "computercraft:block/monitor_advanced_3", | ||||||
|  |     "back": "computercraft:block/monitor_advanced_41" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -0,0 +1,9 @@ | |||||||
|  | { | ||||||
|  |   "parent": "computercraft:block/monitor_base", | ||||||
|  |   "textures": { | ||||||
|  |     "front": "computercraft:block/monitor_advanced_26", | ||||||
|  |     "side": "computercraft:block/monitor_advanced_6", | ||||||
|  |     "top": "computercraft:block/monitor_advanced_3", | ||||||
|  |     "back": "computercraft:block/monitor_advanced_44" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -0,0 +1,9 @@ | |||||||
|  | { | ||||||
|  |   "parent": "computercraft:block/monitor_base", | ||||||
|  |   "textures": { | ||||||
|  |     "front": "computercraft:block/monitor_advanced_22", | ||||||
|  |     "side": "computercraft:block/monitor_advanced_5", | ||||||
|  |     "top": "computercraft:block/monitor_advanced_0", | ||||||
|  |     "back": "computercraft:block/monitor_advanced_38" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -0,0 +1,9 @@ | |||||||
|  | { | ||||||
|  |   "parent": "computercraft:block/monitor_base", | ||||||
|  |   "textures": { | ||||||
|  |     "front": "computercraft:block/monitor_advanced_21", | ||||||
|  |     "side": "computercraft:block/monitor_advanced_6", | ||||||
|  |     "top": "computercraft:block/monitor_advanced_0", | ||||||
|  |     "back": "computercraft:block/monitor_advanced_37" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -0,0 +1,9 @@ | |||||||
|  | { | ||||||
|  |   "parent": "computercraft:block/monitor_base", | ||||||
|  |   "textures": { | ||||||
|  |     "front": "computercraft:block/monitor_normal_16", | ||||||
|  |     "side": "computercraft:block/monitor_normal_4", | ||||||
|  |     "top": "computercraft:block/monitor_normal_0", | ||||||
|  |     "back": "computercraft:block/monitor_normal_32" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -0,0 +1,9 @@ | |||||||
|  | { | ||||||
|  |   "parent": "computercraft:block/monitor_base", | ||||||
|  |   "textures": { | ||||||
|  |     "front": "computercraft:block/monitor_normal_20", | ||||||
|  |     "side": "computercraft:block/monitor_normal_7", | ||||||
|  |     "top": "computercraft:block/monitor_normal_0", | ||||||
|  |     "back": "computercraft:block/monitor_normal_36" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -0,0 +1,9 @@ | |||||||
|  | { | ||||||
|  |   "parent": "computercraft:block/monitor_base", | ||||||
|  |   "textures": { | ||||||
|  |     "front": "computercraft:block/monitor_normal_19", | ||||||
|  |     "side": "computercraft:block/monitor_normal_4", | ||||||
|  |     "top": "computercraft:block/monitor_normal_1", | ||||||
|  |     "back": "computercraft:block/monitor_normal_33" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -0,0 +1,9 @@ | |||||||
|  | { | ||||||
|  |   "parent": "computercraft:block/monitor_base", | ||||||
|  |   "textures": { | ||||||
|  |     "front": "computercraft:block/monitor_normal_31", | ||||||
|  |     "side": "computercraft:block/monitor_normal_7", | ||||||
|  |     "top": "computercraft:block/monitor_normal_1", | ||||||
|  |     "back": "computercraft:block/monitor_normal_45" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -0,0 +1,9 @@ | |||||||
|  | { | ||||||
|  |   "parent": "computercraft:block/monitor_base", | ||||||
|  |   "textures": { | ||||||
|  |     "front": "computercraft:block/monitor_normal_18", | ||||||
|  |     "side": "computercraft:block/monitor_normal_4", | ||||||
|  |     "top": "computercraft:block/monitor_normal_2", | ||||||
|  |     "back": "computercraft:block/monitor_normal_34" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -0,0 +1,9 @@ | |||||||
|  | { | ||||||
|  |   "parent": "computercraft:block/monitor_base", | ||||||
|  |   "textures": { | ||||||
|  |     "front": "computercraft:block/monitor_normal_30", | ||||||
|  |     "side": "computercraft:block/monitor_normal_7", | ||||||
|  |     "top": "computercraft:block/monitor_normal_2", | ||||||
|  |     "back": "computercraft:block/monitor_normal_46" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -0,0 +1,9 @@ | |||||||
|  | { | ||||||
|  |   "parent": "computercraft:block/monitor_base", | ||||||
|  |   "textures": { | ||||||
|  |     "front": "computercraft:block/monitor_normal_24", | ||||||
|  |     "side": "computercraft:block/monitor_normal_5", | ||||||
|  |     "top": "computercraft:block/monitor_normal_2", | ||||||
|  |     "back": "computercraft:block/monitor_normal_40" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -0,0 +1,9 @@ | |||||||
|  | { | ||||||
|  |   "parent": "computercraft:block/monitor_base", | ||||||
|  |   "textures": { | ||||||
|  |     "front": "computercraft:block/monitor_normal_27", | ||||||
|  |     "side": "computercraft:block/monitor_normal_6", | ||||||
|  |     "top": "computercraft:block/monitor_normal_2", | ||||||
|  |     "back": "computercraft:block/monitor_normal_43" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -0,0 +1,9 @@ | |||||||
|  | { | ||||||
|  |   "parent": "computercraft:block/monitor_base", | ||||||
|  |   "textures": { | ||||||
|  |     "front": "computercraft:block/monitor_normal_25", | ||||||
|  |     "side": "computercraft:block/monitor_normal_5", | ||||||
|  |     "top": "computercraft:block/monitor_normal_1", | ||||||
|  |     "back": "computercraft:block/monitor_normal_39" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -0,0 +1,9 @@ | |||||||
|  | { | ||||||
|  |   "parent": "computercraft:block/monitor_base", | ||||||
|  |   "textures": { | ||||||
|  |     "front": "computercraft:block/monitor_normal_28", | ||||||
|  |     "side": "computercraft:block/monitor_normal_6", | ||||||
|  |     "top": "computercraft:block/monitor_normal_1", | ||||||
|  |     "back": "computercraft:block/monitor_normal_42" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -0,0 +1,9 @@ | |||||||
|  | { | ||||||
|  |   "parent": "computercraft:block/monitor_base", | ||||||
|  |   "textures": { | ||||||
|  |     "front": "computercraft:block/monitor_normal_17", | ||||||
|  |     "side": "computercraft:block/monitor_normal_4", | ||||||
|  |     "top": "computercraft:block/monitor_normal_3", | ||||||
|  |     "back": "computercraft:block/monitor_normal_35" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -0,0 +1,9 @@ | |||||||
|  | { | ||||||
|  |   "parent": "computercraft:block/monitor_base", | ||||||
|  |   "textures": { | ||||||
|  |     "front": "computercraft:block/monitor_normal_29", | ||||||
|  |     "side": "computercraft:block/monitor_normal_7", | ||||||
|  |     "top": "computercraft:block/monitor_normal_3", | ||||||
|  |     "back": "computercraft:block/monitor_normal_47" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -0,0 +1,9 @@ | |||||||
|  | { | ||||||
|  |   "parent": "computercraft:block/monitor_base", | ||||||
|  |   "textures": { | ||||||
|  |     "front": "computercraft:block/monitor_normal_23", | ||||||
|  |     "side": "computercraft:block/monitor_normal_5", | ||||||
|  |     "top": "computercraft:block/monitor_normal_3", | ||||||
|  |     "back": "computercraft:block/monitor_normal_41" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -0,0 +1,9 @@ | |||||||
|  | { | ||||||
|  |   "parent": "computercraft:block/monitor_base", | ||||||
|  |   "textures": { | ||||||
|  |     "front": "computercraft:block/monitor_normal_26", | ||||||
|  |     "side": "computercraft:block/monitor_normal_6", | ||||||
|  |     "top": "computercraft:block/monitor_normal_3", | ||||||
|  |     "back": "computercraft:block/monitor_normal_44" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -0,0 +1,9 @@ | |||||||
|  | { | ||||||
|  |   "parent": "computercraft:block/monitor_base", | ||||||
|  |   "textures": { | ||||||
|  |     "front": "computercraft:block/monitor_normal_22", | ||||||
|  |     "side": "computercraft:block/monitor_normal_5", | ||||||
|  |     "top": "computercraft:block/monitor_normal_0", | ||||||
|  |     "back": "computercraft:block/monitor_normal_38" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @@ -0,0 +1,9 @@ | |||||||
|  | { | ||||||
|  |   "parent": "computercraft:block/monitor_base", | ||||||
|  |   "textures": { | ||||||
|  |     "front": "computercraft:block/monitor_normal_21", | ||||||
|  |     "side": "computercraft:block/monitor_normal_6", | ||||||
|  |     "top": "computercraft:block/monitor_normal_0", | ||||||
|  |     "back": "computercraft:block/monitor_normal_37" | ||||||
|  |   } | ||||||
|  | } | ||||||
							
								
								
									
										43
									
								
								src/generated/resources/data/computercraft/advancements/recipes/computercraft/cable.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										43
									
								
								src/generated/resources/data/computercraft/advancements/recipes/computercraft/cable.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,43 @@ | |||||||
|  | { | ||||||
|  |   "parent": "minecraft:recipes/root", | ||||||
|  |   "rewards": { | ||||||
|  |     "recipes": [ | ||||||
|  |       "computercraft:cable" | ||||||
|  |     ] | ||||||
|  |   }, | ||||||
|  |   "criteria": { | ||||||
|  |     "has_computer": { | ||||||
|  |       "trigger": "minecraft:inventory_changed", | ||||||
|  |       "conditions": { | ||||||
|  |         "items": [ | ||||||
|  |           { | ||||||
|  |             "tag": "computercraft:computer" | ||||||
|  |           } | ||||||
|  |         ] | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "has_modem": { | ||||||
|  |       "trigger": "minecraft:inventory_changed", | ||||||
|  |       "conditions": { | ||||||
|  |         "items": [ | ||||||
|  |           { | ||||||
|  |             "tag": "computercraft:computer" | ||||||
|  |           } | ||||||
|  |         ] | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "has_the_recipe": { | ||||||
|  |       "trigger": "minecraft:recipe_unlocked", | ||||||
|  |       "conditions": { | ||||||
|  |         "recipe": "computercraft:cable" | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   "requirements": [ | ||||||
|  |     [ | ||||||
|  |       "has_computer", | ||||||
|  |       "has_modem", | ||||||
|  |       "has_the_recipe" | ||||||
|  |     ] | ||||||
|  |   ] | ||||||
|  | } | ||||||
							
								
								
									
										35
									
								
								src/generated/resources/data/computercraft/advancements/recipes/computercraft/computer_advanced.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								src/generated/resources/data/computercraft/advancements/recipes/computercraft/computer_advanced.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,35 @@ | |||||||
|  | { | ||||||
|  |   "parent": "minecraft:recipes/root", | ||||||
|  |   "rewards": { | ||||||
|  |     "recipes": [ | ||||||
|  |       "computercraft:computer_advanced" | ||||||
|  |     ] | ||||||
|  |   }, | ||||||
|  |   "criteria": { | ||||||
|  |     "has_components": { | ||||||
|  |       "trigger": "minecraft:inventory_changed", | ||||||
|  |       "conditions": { | ||||||
|  |         "items": [ | ||||||
|  |           { | ||||||
|  |             "item": "minecraft:redstone" | ||||||
|  |           }, | ||||||
|  |           { | ||||||
|  |             "item": "minecraft:gold_ingot" | ||||||
|  |           } | ||||||
|  |         ] | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "has_the_recipe": { | ||||||
|  |       "trigger": "minecraft:recipe_unlocked", | ||||||
|  |       "conditions": { | ||||||
|  |         "recipe": "computercraft:computer_advanced" | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   "requirements": [ | ||||||
|  |     [ | ||||||
|  |       "has_components", | ||||||
|  |       "has_the_recipe" | ||||||
|  |     ] | ||||||
|  |   ] | ||||||
|  | } | ||||||
							
								
								
									
										32
									
								
								src/generated/resources/data/computercraft/advancements/recipes/computercraft/computer_command.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								src/generated/resources/data/computercraft/advancements/recipes/computercraft/computer_command.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | |||||||
|  | { | ||||||
|  |   "parent": "minecraft:recipes/root", | ||||||
|  |   "rewards": { | ||||||
|  |     "recipes": [ | ||||||
|  |       "computercraft:computer_command" | ||||||
|  |     ] | ||||||
|  |   }, | ||||||
|  |   "criteria": { | ||||||
|  |     "has_components": { | ||||||
|  |       "trigger": "minecraft:inventory_changed", | ||||||
|  |       "conditions": { | ||||||
|  |         "items": [ | ||||||
|  |           { | ||||||
|  |             "item": "minecraft:command_block" | ||||||
|  |           } | ||||||
|  |         ] | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "has_the_recipe": { | ||||||
|  |       "trigger": "minecraft:recipe_unlocked", | ||||||
|  |       "conditions": { | ||||||
|  |         "recipe": "computercraft:computer_command" | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   "requirements": [ | ||||||
|  |     [ | ||||||
|  |       "has_components", | ||||||
|  |       "has_the_recipe" | ||||||
|  |     ] | ||||||
|  |   ] | ||||||
|  | } | ||||||
							
								
								
									
										32
									
								
								src/generated/resources/data/computercraft/advancements/recipes/computercraft/computer_normal.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								src/generated/resources/data/computercraft/advancements/recipes/computercraft/computer_normal.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | |||||||
|  | { | ||||||
|  |   "parent": "minecraft:recipes/root", | ||||||
|  |   "rewards": { | ||||||
|  |     "recipes": [ | ||||||
|  |       "computercraft:computer_normal" | ||||||
|  |     ] | ||||||
|  |   }, | ||||||
|  |   "criteria": { | ||||||
|  |     "has_redstone": { | ||||||
|  |       "trigger": "minecraft:inventory_changed", | ||||||
|  |       "conditions": { | ||||||
|  |         "items": [ | ||||||
|  |           { | ||||||
|  |             "tag": "forge:dusts/redstone" | ||||||
|  |           } | ||||||
|  |         ] | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "has_the_recipe": { | ||||||
|  |       "trigger": "minecraft:recipe_unlocked", | ||||||
|  |       "conditions": { | ||||||
|  |         "recipe": "computercraft:computer_normal" | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   "requirements": [ | ||||||
|  |     [ | ||||||
|  |       "has_redstone", | ||||||
|  |       "has_the_recipe" | ||||||
|  |     ] | ||||||
|  |   ] | ||||||
|  | } | ||||||
							
								
								
									
										32
									
								
								src/generated/resources/data/computercraft/advancements/recipes/computercraft/disk_1.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								src/generated/resources/data/computercraft/advancements/recipes/computercraft/disk_1.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | |||||||
|  | { | ||||||
|  |   "parent": "minecraft:recipes/root", | ||||||
|  |   "rewards": { | ||||||
|  |     "recipes": [ | ||||||
|  |       "computercraft:disk_1" | ||||||
|  |     ] | ||||||
|  |   }, | ||||||
|  |   "criteria": { | ||||||
|  |     "has_drive": { | ||||||
|  |       "trigger": "minecraft:inventory_changed", | ||||||
|  |       "conditions": { | ||||||
|  |         "items": [ | ||||||
|  |           { | ||||||
|  |             "item": "computercraft:disk_drive" | ||||||
|  |           } | ||||||
|  |         ] | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "has_the_recipe": { | ||||||
|  |       "trigger": "minecraft:recipe_unlocked", | ||||||
|  |       "conditions": { | ||||||
|  |         "recipe": "computercraft:disk_1" | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   "requirements": [ | ||||||
|  |     [ | ||||||
|  |       "has_drive", | ||||||
|  |       "has_the_recipe" | ||||||
|  |     ] | ||||||
|  |   ] | ||||||
|  | } | ||||||
							
								
								
									
										32
									
								
								src/generated/resources/data/computercraft/advancements/recipes/computercraft/disk_10.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								src/generated/resources/data/computercraft/advancements/recipes/computercraft/disk_10.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | |||||||
|  | { | ||||||
|  |   "parent": "minecraft:recipes/root", | ||||||
|  |   "rewards": { | ||||||
|  |     "recipes": [ | ||||||
|  |       "computercraft:disk_10" | ||||||
|  |     ] | ||||||
|  |   }, | ||||||
|  |   "criteria": { | ||||||
|  |     "has_drive": { | ||||||
|  |       "trigger": "minecraft:inventory_changed", | ||||||
|  |       "conditions": { | ||||||
|  |         "items": [ | ||||||
|  |           { | ||||||
|  |             "item": "computercraft:disk_drive" | ||||||
|  |           } | ||||||
|  |         ] | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "has_the_recipe": { | ||||||
|  |       "trigger": "minecraft:recipe_unlocked", | ||||||
|  |       "conditions": { | ||||||
|  |         "recipe": "computercraft:disk_10" | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   "requirements": [ | ||||||
|  |     [ | ||||||
|  |       "has_drive", | ||||||
|  |       "has_the_recipe" | ||||||
|  |     ] | ||||||
|  |   ] | ||||||
|  | } | ||||||
							
								
								
									
										32
									
								
								src/generated/resources/data/computercraft/advancements/recipes/computercraft/disk_11.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								src/generated/resources/data/computercraft/advancements/recipes/computercraft/disk_11.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | |||||||
|  | { | ||||||
|  |   "parent": "minecraft:recipes/root", | ||||||
|  |   "rewards": { | ||||||
|  |     "recipes": [ | ||||||
|  |       "computercraft:disk_11" | ||||||
|  |     ] | ||||||
|  |   }, | ||||||
|  |   "criteria": { | ||||||
|  |     "has_drive": { | ||||||
|  |       "trigger": "minecraft:inventory_changed", | ||||||
|  |       "conditions": { | ||||||
|  |         "items": [ | ||||||
|  |           { | ||||||
|  |             "item": "computercraft:disk_drive" | ||||||
|  |           } | ||||||
|  |         ] | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "has_the_recipe": { | ||||||
|  |       "trigger": "minecraft:recipe_unlocked", | ||||||
|  |       "conditions": { | ||||||
|  |         "recipe": "computercraft:disk_11" | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   "requirements": [ | ||||||
|  |     [ | ||||||
|  |       "has_drive", | ||||||
|  |       "has_the_recipe" | ||||||
|  |     ] | ||||||
|  |   ] | ||||||
|  | } | ||||||
							
								
								
									
										32
									
								
								src/generated/resources/data/computercraft/advancements/recipes/computercraft/disk_12.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								src/generated/resources/data/computercraft/advancements/recipes/computercraft/disk_12.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | |||||||
|  | { | ||||||
|  |   "parent": "minecraft:recipes/root", | ||||||
|  |   "rewards": { | ||||||
|  |     "recipes": [ | ||||||
|  |       "computercraft:disk_12" | ||||||
|  |     ] | ||||||
|  |   }, | ||||||
|  |   "criteria": { | ||||||
|  |     "has_drive": { | ||||||
|  |       "trigger": "minecraft:inventory_changed", | ||||||
|  |       "conditions": { | ||||||
|  |         "items": [ | ||||||
|  |           { | ||||||
|  |             "item": "computercraft:disk_drive" | ||||||
|  |           } | ||||||
|  |         ] | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "has_the_recipe": { | ||||||
|  |       "trigger": "minecraft:recipe_unlocked", | ||||||
|  |       "conditions": { | ||||||
|  |         "recipe": "computercraft:disk_12" | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   "requirements": [ | ||||||
|  |     [ | ||||||
|  |       "has_drive", | ||||||
|  |       "has_the_recipe" | ||||||
|  |     ] | ||||||
|  |   ] | ||||||
|  | } | ||||||
							
								
								
									
										32
									
								
								src/generated/resources/data/computercraft/advancements/recipes/computercraft/disk_13.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								src/generated/resources/data/computercraft/advancements/recipes/computercraft/disk_13.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | |||||||
|  | { | ||||||
|  |   "parent": "minecraft:recipes/root", | ||||||
|  |   "rewards": { | ||||||
|  |     "recipes": [ | ||||||
|  |       "computercraft:disk_13" | ||||||
|  |     ] | ||||||
|  |   }, | ||||||
|  |   "criteria": { | ||||||
|  |     "has_drive": { | ||||||
|  |       "trigger": "minecraft:inventory_changed", | ||||||
|  |       "conditions": { | ||||||
|  |         "items": [ | ||||||
|  |           { | ||||||
|  |             "item": "computercraft:disk_drive" | ||||||
|  |           } | ||||||
|  |         ] | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "has_the_recipe": { | ||||||
|  |       "trigger": "minecraft:recipe_unlocked", | ||||||
|  |       "conditions": { | ||||||
|  |         "recipe": "computercraft:disk_13" | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   "requirements": [ | ||||||
|  |     [ | ||||||
|  |       "has_drive", | ||||||
|  |       "has_the_recipe" | ||||||
|  |     ] | ||||||
|  |   ] | ||||||
|  | } | ||||||
							
								
								
									
										32
									
								
								src/generated/resources/data/computercraft/advancements/recipes/computercraft/disk_14.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								src/generated/resources/data/computercraft/advancements/recipes/computercraft/disk_14.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | |||||||
|  | { | ||||||
|  |   "parent": "minecraft:recipes/root", | ||||||
|  |   "rewards": { | ||||||
|  |     "recipes": [ | ||||||
|  |       "computercraft:disk_14" | ||||||
|  |     ] | ||||||
|  |   }, | ||||||
|  |   "criteria": { | ||||||
|  |     "has_drive": { | ||||||
|  |       "trigger": "minecraft:inventory_changed", | ||||||
|  |       "conditions": { | ||||||
|  |         "items": [ | ||||||
|  |           { | ||||||
|  |             "item": "computercraft:disk_drive" | ||||||
|  |           } | ||||||
|  |         ] | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "has_the_recipe": { | ||||||
|  |       "trigger": "minecraft:recipe_unlocked", | ||||||
|  |       "conditions": { | ||||||
|  |         "recipe": "computercraft:disk_14" | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   "requirements": [ | ||||||
|  |     [ | ||||||
|  |       "has_drive", | ||||||
|  |       "has_the_recipe" | ||||||
|  |     ] | ||||||
|  |   ] | ||||||
|  | } | ||||||
							
								
								
									
										32
									
								
								src/generated/resources/data/computercraft/advancements/recipes/computercraft/disk_15.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								src/generated/resources/data/computercraft/advancements/recipes/computercraft/disk_15.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | |||||||
|  | { | ||||||
|  |   "parent": "minecraft:recipes/root", | ||||||
|  |   "rewards": { | ||||||
|  |     "recipes": [ | ||||||
|  |       "computercraft:disk_15" | ||||||
|  |     ] | ||||||
|  |   }, | ||||||
|  |   "criteria": { | ||||||
|  |     "has_drive": { | ||||||
|  |       "trigger": "minecraft:inventory_changed", | ||||||
|  |       "conditions": { | ||||||
|  |         "items": [ | ||||||
|  |           { | ||||||
|  |             "item": "computercraft:disk_drive" | ||||||
|  |           } | ||||||
|  |         ] | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "has_the_recipe": { | ||||||
|  |       "trigger": "minecraft:recipe_unlocked", | ||||||
|  |       "conditions": { | ||||||
|  |         "recipe": "computercraft:disk_15" | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   "requirements": [ | ||||||
|  |     [ | ||||||
|  |       "has_drive", | ||||||
|  |       "has_the_recipe" | ||||||
|  |     ] | ||||||
|  |   ] | ||||||
|  | } | ||||||
							
								
								
									
										32
									
								
								src/generated/resources/data/computercraft/advancements/recipes/computercraft/disk_16.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								src/generated/resources/data/computercraft/advancements/recipes/computercraft/disk_16.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | |||||||
|  | { | ||||||
|  |   "parent": "minecraft:recipes/root", | ||||||
|  |   "rewards": { | ||||||
|  |     "recipes": [ | ||||||
|  |       "computercraft:disk_16" | ||||||
|  |     ] | ||||||
|  |   }, | ||||||
|  |   "criteria": { | ||||||
|  |     "has_drive": { | ||||||
|  |       "trigger": "minecraft:inventory_changed", | ||||||
|  |       "conditions": { | ||||||
|  |         "items": [ | ||||||
|  |           { | ||||||
|  |             "item": "computercraft:disk_drive" | ||||||
|  |           } | ||||||
|  |         ] | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "has_the_recipe": { | ||||||
|  |       "trigger": "minecraft:recipe_unlocked", | ||||||
|  |       "conditions": { | ||||||
|  |         "recipe": "computercraft:disk_16" | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   "requirements": [ | ||||||
|  |     [ | ||||||
|  |       "has_drive", | ||||||
|  |       "has_the_recipe" | ||||||
|  |     ] | ||||||
|  |   ] | ||||||
|  | } | ||||||
							
								
								
									
										32
									
								
								src/generated/resources/data/computercraft/advancements/recipes/computercraft/disk_2.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								src/generated/resources/data/computercraft/advancements/recipes/computercraft/disk_2.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | |||||||
|  | { | ||||||
|  |   "parent": "minecraft:recipes/root", | ||||||
|  |   "rewards": { | ||||||
|  |     "recipes": [ | ||||||
|  |       "computercraft:disk_2" | ||||||
|  |     ] | ||||||
|  |   }, | ||||||
|  |   "criteria": { | ||||||
|  |     "has_drive": { | ||||||
|  |       "trigger": "minecraft:inventory_changed", | ||||||
|  |       "conditions": { | ||||||
|  |         "items": [ | ||||||
|  |           { | ||||||
|  |             "item": "computercraft:disk_drive" | ||||||
|  |           } | ||||||
|  |         ] | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "has_the_recipe": { | ||||||
|  |       "trigger": "minecraft:recipe_unlocked", | ||||||
|  |       "conditions": { | ||||||
|  |         "recipe": "computercraft:disk_2" | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   "requirements": [ | ||||||
|  |     [ | ||||||
|  |       "has_drive", | ||||||
|  |       "has_the_recipe" | ||||||
|  |     ] | ||||||
|  |   ] | ||||||
|  | } | ||||||
							
								
								
									
										32
									
								
								src/generated/resources/data/computercraft/advancements/recipes/computercraft/disk_3.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								src/generated/resources/data/computercraft/advancements/recipes/computercraft/disk_3.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | |||||||
|  | { | ||||||
|  |   "parent": "minecraft:recipes/root", | ||||||
|  |   "rewards": { | ||||||
|  |     "recipes": [ | ||||||
|  |       "computercraft:disk_3" | ||||||
|  |     ] | ||||||
|  |   }, | ||||||
|  |   "criteria": { | ||||||
|  |     "has_drive": { | ||||||
|  |       "trigger": "minecraft:inventory_changed", | ||||||
|  |       "conditions": { | ||||||
|  |         "items": [ | ||||||
|  |           { | ||||||
|  |             "item": "computercraft:disk_drive" | ||||||
|  |           } | ||||||
|  |         ] | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "has_the_recipe": { | ||||||
|  |       "trigger": "minecraft:recipe_unlocked", | ||||||
|  |       "conditions": { | ||||||
|  |         "recipe": "computercraft:disk_3" | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   "requirements": [ | ||||||
|  |     [ | ||||||
|  |       "has_drive", | ||||||
|  |       "has_the_recipe" | ||||||
|  |     ] | ||||||
|  |   ] | ||||||
|  | } | ||||||
							
								
								
									
										32
									
								
								src/generated/resources/data/computercraft/advancements/recipes/computercraft/disk_4.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								src/generated/resources/data/computercraft/advancements/recipes/computercraft/disk_4.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | |||||||
|  | { | ||||||
|  |   "parent": "minecraft:recipes/root", | ||||||
|  |   "rewards": { | ||||||
|  |     "recipes": [ | ||||||
|  |       "computercraft:disk_4" | ||||||
|  |     ] | ||||||
|  |   }, | ||||||
|  |   "criteria": { | ||||||
|  |     "has_drive": { | ||||||
|  |       "trigger": "minecraft:inventory_changed", | ||||||
|  |       "conditions": { | ||||||
|  |         "items": [ | ||||||
|  |           { | ||||||
|  |             "item": "computercraft:disk_drive" | ||||||
|  |           } | ||||||
|  |         ] | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "has_the_recipe": { | ||||||
|  |       "trigger": "minecraft:recipe_unlocked", | ||||||
|  |       "conditions": { | ||||||
|  |         "recipe": "computercraft:disk_4" | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   "requirements": [ | ||||||
|  |     [ | ||||||
|  |       "has_drive", | ||||||
|  |       "has_the_recipe" | ||||||
|  |     ] | ||||||
|  |   ] | ||||||
|  | } | ||||||
							
								
								
									
										32
									
								
								src/generated/resources/data/computercraft/advancements/recipes/computercraft/disk_5.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								src/generated/resources/data/computercraft/advancements/recipes/computercraft/disk_5.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | |||||||
|  | { | ||||||
|  |   "parent": "minecraft:recipes/root", | ||||||
|  |   "rewards": { | ||||||
|  |     "recipes": [ | ||||||
|  |       "computercraft:disk_5" | ||||||
|  |     ] | ||||||
|  |   }, | ||||||
|  |   "criteria": { | ||||||
|  |     "has_drive": { | ||||||
|  |       "trigger": "minecraft:inventory_changed", | ||||||
|  |       "conditions": { | ||||||
|  |         "items": [ | ||||||
|  |           { | ||||||
|  |             "item": "computercraft:disk_drive" | ||||||
|  |           } | ||||||
|  |         ] | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "has_the_recipe": { | ||||||
|  |       "trigger": "minecraft:recipe_unlocked", | ||||||
|  |       "conditions": { | ||||||
|  |         "recipe": "computercraft:disk_5" | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   "requirements": [ | ||||||
|  |     [ | ||||||
|  |       "has_drive", | ||||||
|  |       "has_the_recipe" | ||||||
|  |     ] | ||||||
|  |   ] | ||||||
|  | } | ||||||
							
								
								
									
										32
									
								
								src/generated/resources/data/computercraft/advancements/recipes/computercraft/disk_6.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								src/generated/resources/data/computercraft/advancements/recipes/computercraft/disk_6.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | |||||||
|  | { | ||||||
|  |   "parent": "minecraft:recipes/root", | ||||||
|  |   "rewards": { | ||||||
|  |     "recipes": [ | ||||||
|  |       "computercraft:disk_6" | ||||||
|  |     ] | ||||||
|  |   }, | ||||||
|  |   "criteria": { | ||||||
|  |     "has_drive": { | ||||||
|  |       "trigger": "minecraft:inventory_changed", | ||||||
|  |       "conditions": { | ||||||
|  |         "items": [ | ||||||
|  |           { | ||||||
|  |             "item": "computercraft:disk_drive" | ||||||
|  |           } | ||||||
|  |         ] | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "has_the_recipe": { | ||||||
|  |       "trigger": "minecraft:recipe_unlocked", | ||||||
|  |       "conditions": { | ||||||
|  |         "recipe": "computercraft:disk_6" | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   "requirements": [ | ||||||
|  |     [ | ||||||
|  |       "has_drive", | ||||||
|  |       "has_the_recipe" | ||||||
|  |     ] | ||||||
|  |   ] | ||||||
|  | } | ||||||
							
								
								
									
										32
									
								
								src/generated/resources/data/computercraft/advancements/recipes/computercraft/disk_7.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								src/generated/resources/data/computercraft/advancements/recipes/computercraft/disk_7.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | |||||||
|  | { | ||||||
|  |   "parent": "minecraft:recipes/root", | ||||||
|  |   "rewards": { | ||||||
|  |     "recipes": [ | ||||||
|  |       "computercraft:disk_7" | ||||||
|  |     ] | ||||||
|  |   }, | ||||||
|  |   "criteria": { | ||||||
|  |     "has_drive": { | ||||||
|  |       "trigger": "minecraft:inventory_changed", | ||||||
|  |       "conditions": { | ||||||
|  |         "items": [ | ||||||
|  |           { | ||||||
|  |             "item": "computercraft:disk_drive" | ||||||
|  |           } | ||||||
|  |         ] | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "has_the_recipe": { | ||||||
|  |       "trigger": "minecraft:recipe_unlocked", | ||||||
|  |       "conditions": { | ||||||
|  |         "recipe": "computercraft:disk_7" | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   "requirements": [ | ||||||
|  |     [ | ||||||
|  |       "has_drive", | ||||||
|  |       "has_the_recipe" | ||||||
|  |     ] | ||||||
|  |   ] | ||||||
|  | } | ||||||
							
								
								
									
										32
									
								
								src/generated/resources/data/computercraft/advancements/recipes/computercraft/disk_8.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								src/generated/resources/data/computercraft/advancements/recipes/computercraft/disk_8.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | |||||||
|  | { | ||||||
|  |   "parent": "minecraft:recipes/root", | ||||||
|  |   "rewards": { | ||||||
|  |     "recipes": [ | ||||||
|  |       "computercraft:disk_8" | ||||||
|  |     ] | ||||||
|  |   }, | ||||||
|  |   "criteria": { | ||||||
|  |     "has_drive": { | ||||||
|  |       "trigger": "minecraft:inventory_changed", | ||||||
|  |       "conditions": { | ||||||
|  |         "items": [ | ||||||
|  |           { | ||||||
|  |             "item": "computercraft:disk_drive" | ||||||
|  |           } | ||||||
|  |         ] | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "has_the_recipe": { | ||||||
|  |       "trigger": "minecraft:recipe_unlocked", | ||||||
|  |       "conditions": { | ||||||
|  |         "recipe": "computercraft:disk_8" | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   "requirements": [ | ||||||
|  |     [ | ||||||
|  |       "has_drive", | ||||||
|  |       "has_the_recipe" | ||||||
|  |     ] | ||||||
|  |   ] | ||||||
|  | } | ||||||
							
								
								
									
										32
									
								
								src/generated/resources/data/computercraft/advancements/recipes/computercraft/disk_9.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								src/generated/resources/data/computercraft/advancements/recipes/computercraft/disk_9.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | |||||||
|  | { | ||||||
|  |   "parent": "minecraft:recipes/root", | ||||||
|  |   "rewards": { | ||||||
|  |     "recipes": [ | ||||||
|  |       "computercraft:disk_9" | ||||||
|  |     ] | ||||||
|  |   }, | ||||||
|  |   "criteria": { | ||||||
|  |     "has_drive": { | ||||||
|  |       "trigger": "minecraft:inventory_changed", | ||||||
|  |       "conditions": { | ||||||
|  |         "items": [ | ||||||
|  |           { | ||||||
|  |             "item": "computercraft:disk_drive" | ||||||
|  |           } | ||||||
|  |         ] | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "has_the_recipe": { | ||||||
|  |       "trigger": "minecraft:recipe_unlocked", | ||||||
|  |       "conditions": { | ||||||
|  |         "recipe": "computercraft:disk_9" | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   "requirements": [ | ||||||
|  |     [ | ||||||
|  |       "has_drive", | ||||||
|  |       "has_the_recipe" | ||||||
|  |     ] | ||||||
|  |   ] | ||||||
|  | } | ||||||
							
								
								
									
										32
									
								
								src/generated/resources/data/computercraft/advancements/recipes/computercraft/disk_drive.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								src/generated/resources/data/computercraft/advancements/recipes/computercraft/disk_drive.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | |||||||
|  | { | ||||||
|  |   "parent": "minecraft:recipes/root", | ||||||
|  |   "rewards": { | ||||||
|  |     "recipes": [ | ||||||
|  |       "computercraft:disk_drive" | ||||||
|  |     ] | ||||||
|  |   }, | ||||||
|  |   "criteria": { | ||||||
|  |     "has_computer": { | ||||||
|  |       "trigger": "minecraft:inventory_changed", | ||||||
|  |       "conditions": { | ||||||
|  |         "items": [ | ||||||
|  |           { | ||||||
|  |             "tag": "computercraft:computer" | ||||||
|  |           } | ||||||
|  |         ] | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "has_the_recipe": { | ||||||
|  |       "trigger": "minecraft:recipe_unlocked", | ||||||
|  |       "conditions": { | ||||||
|  |         "recipe": "computercraft:disk_drive" | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   "requirements": [ | ||||||
|  |     [ | ||||||
|  |       "has_computer", | ||||||
|  |       "has_the_recipe" | ||||||
|  |     ] | ||||||
|  |   ] | ||||||
|  | } | ||||||
							
								
								
									
										32
									
								
								src/generated/resources/data/computercraft/advancements/recipes/computercraft/monitor_advanced.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								src/generated/resources/data/computercraft/advancements/recipes/computercraft/monitor_advanced.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | |||||||
|  | { | ||||||
|  |   "parent": "minecraft:recipes/root", | ||||||
|  |   "rewards": { | ||||||
|  |     "recipes": [ | ||||||
|  |       "computercraft:monitor_advanced" | ||||||
|  |     ] | ||||||
|  |   }, | ||||||
|  |   "criteria": { | ||||||
|  |     "has_computer": { | ||||||
|  |       "trigger": "minecraft:inventory_changed", | ||||||
|  |       "conditions": { | ||||||
|  |         "items": [ | ||||||
|  |           { | ||||||
|  |             "tag": "computercraft:computer" | ||||||
|  |           } | ||||||
|  |         ] | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "has_the_recipe": { | ||||||
|  |       "trigger": "minecraft:recipe_unlocked", | ||||||
|  |       "conditions": { | ||||||
|  |         "recipe": "computercraft:monitor_advanced" | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   "requirements": [ | ||||||
|  |     [ | ||||||
|  |       "has_computer", | ||||||
|  |       "has_the_recipe" | ||||||
|  |     ] | ||||||
|  |   ] | ||||||
|  | } | ||||||
							
								
								
									
										32
									
								
								src/generated/resources/data/computercraft/advancements/recipes/computercraft/monitor_normal.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								src/generated/resources/data/computercraft/advancements/recipes/computercraft/monitor_normal.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | |||||||
|  | { | ||||||
|  |   "parent": "minecraft:recipes/root", | ||||||
|  |   "rewards": { | ||||||
|  |     "recipes": [ | ||||||
|  |       "computercraft:monitor_normal" | ||||||
|  |     ] | ||||||
|  |   }, | ||||||
|  |   "criteria": { | ||||||
|  |     "has_computer": { | ||||||
|  |       "trigger": "minecraft:inventory_changed", | ||||||
|  |       "conditions": { | ||||||
|  |         "items": [ | ||||||
|  |           { | ||||||
|  |             "tag": "computercraft:computer" | ||||||
|  |           } | ||||||
|  |         ] | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "has_the_recipe": { | ||||||
|  |       "trigger": "minecraft:recipe_unlocked", | ||||||
|  |       "conditions": { | ||||||
|  |         "recipe": "computercraft:monitor_normal" | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   }, | ||||||
|  |   "requirements": [ | ||||||
|  |     [ | ||||||
|  |       "has_computer", | ||||||
|  |       "has_the_recipe" | ||||||
|  |     ] | ||||||
|  |   ] | ||||||
|  | } | ||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user