mirror of
				https://github.com/SquidDev-CC/CC-Tweaked
				synced 2025-10-25 10:57:57 +00:00 
			
		
		
		
	Move website source/build logic to projects/web
Mostly useful as it moves some of our build logic out of the main project, as that's already pretty noisy!
This commit is contained in:
		
							
								
								
									
										2
									
								
								.github/workflows/make-doc.sh
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/make-doc.sh
									
									
									
									
										vendored
									
									
								
							| @@ -12,7 +12,7 @@ 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/site/" \ | ||||
|       "$GITHUB_WORKSPACE/projects/web/build/site/" \ | ||||
|       "$SSH_USER@$SSH_HOST:/$DEST" | ||||
| rsync -avc -e "ssh -i $HOME/.ssh/key -o StrictHostKeyChecking=no -p $SSH_PORT" \ | ||||
|       "$GITHUB_WORKSPACE/build/docs/javadoc/" \ | ||||
|   | ||||
							
								
								
									
										3
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -11,7 +11,6 @@ | ||||
|  | ||||
| # Runtime directories | ||||
| /run | ||||
| /run-* | ||||
|  | ||||
| *.ipr | ||||
| *.iws | ||||
| @@ -24,8 +23,6 @@ | ||||
| /.project | ||||
| /.settings | ||||
| /.vscode | ||||
| bin/ | ||||
| *.launch | ||||
|  | ||||
| /src/generated/resources/.cache | ||||
| /src/web/mount/*.d.ts | ||||
|   | ||||
| @@ -52,7 +52,7 @@ complexity is hidden by Gradle, but you will need to perform some initial setup: | ||||
|  - Run `npm ci` to install our Node dependencies. | ||||
| 
 | ||||
| You can now run `./gradlew docWebsite`. This generates documentation from our Lua and Java code, writing the resulting | ||||
| HTML into `./build/docs/site`. | ||||
| HTML into `./projects/web/build/site`. | ||||
| 
 | ||||
| #### Writing documentation | ||||
| illuaminate's documentation system is not currently documented (somewhat ironic), but is _largely_ the same as | ||||
|   | ||||
| @@ -19,7 +19,6 @@ plugins { | ||||
|     alias(libs.plugins.ideaExt) | ||||
|  | ||||
|     id("cc-tweaked.illuaminate") | ||||
|     id("cc-tweaked.node") | ||||
|     id("cc-tweaked.gametest") | ||||
|     id("cc-tweaked.publishing") | ||||
|     id("cc-tweaked") | ||||
| @@ -247,78 +246,6 @@ tasks.shadowJar { | ||||
|  | ||||
| tasks.assemble { dependsOn("shadowJar") } | ||||
|  | ||||
| // Web tasks | ||||
|  | ||||
| val rollup by tasks.registering(NpxExecToDir::class) { | ||||
|     group = LifecycleBasePlugin.BUILD_GROUP | ||||
|     description = "Bundles JS into rollup" | ||||
|  | ||||
|     // Sources | ||||
|     inputs.files(fileTree("src/web")).withPropertyName("sources") | ||||
|     // Config files | ||||
|     inputs.file("tsconfig.json").withPropertyName("Typescript config") | ||||
|     inputs.file("rollup.config.js").withPropertyName("Rollup config") | ||||
|  | ||||
|     // Output directory. Also defined in illuaminate.sexp and rollup.config.js | ||||
|     output.set(buildDir.resolve("rollup")) | ||||
|  | ||||
|     args = listOf("rollup", "--config", "rollup.config.js") | ||||
| } | ||||
|  | ||||
| val illuaminateDocs by tasks.registering(IlluaminateExecToDir::class) { | ||||
|     group = JavaBasePlugin.DOCUMENTATION_GROUP | ||||
|     description = "Generates docs using Illuaminate" | ||||
|  | ||||
|     // Config files | ||||
|     inputs.file("illuaminate.sexp").withPropertyName("illuaminate.sexp") | ||||
|     // Sources | ||||
|     inputs.files(fileTree("doc")).withPropertyName("docs") | ||||
|     inputs.files(fileTree("src/main/resources/data/computercraft/lua")).withPropertyName("lua rom") | ||||
|     inputs.files(luaJavadoc) | ||||
|     // Additional assets | ||||
|     inputs.files(rollup) | ||||
|     inputs.file("src/web/styles.css").withPropertyName("styles") | ||||
|  | ||||
|     // Output directory. Also defined in illuaminate.sexp and transform.tsx | ||||
|     output.set(buildDir.resolve("illuaminate")) | ||||
|  | ||||
|     args = listOf("doc-gen") | ||||
| } | ||||
|  | ||||
| val jsxDocs by tasks.registering(NpxExecToDir::class) { | ||||
|     group = JavaBasePlugin.DOCUMENTATION_GROUP | ||||
|     description = "Post-processes documentation to statically render some dynamic content." | ||||
|  | ||||
|     // Config files | ||||
|     inputs.file("tsconfig.json").withPropertyName("Typescript config") | ||||
|     // Sources | ||||
|     inputs.files(fileTree("src/web")).withPropertyName("sources") | ||||
|     inputs.file("src/generated/export/index.json").withPropertyName("export") | ||||
|     inputs.files(illuaminateDocs) | ||||
|  | ||||
|     // Output directory. Also defined in src/web/transform.tsx | ||||
|     output.set(buildDir.resolve("jsxDocs")) | ||||
|  | ||||
|     args = listOf("ts-node", "-T", "--esm", "src/web/transform.tsx") | ||||
| } | ||||
|  | ||||
| val docWebsite by tasks.registering(Copy::class) { | ||||
|     group = JavaBasePlugin.DOCUMENTATION_GROUP | ||||
|     description = "Assemble docs and assets together into the documentation website." | ||||
|  | ||||
|     from(jsxDocs) | ||||
|  | ||||
|     from("doc") { | ||||
|         include("logo.png") | ||||
|         include("images/**") | ||||
|     } | ||||
|     from(rollup) { exclude("index.js") } | ||||
|     from(illuaminateDocs) { exclude("**/*.html") } | ||||
|     from("src/generated/export/items") { into("images/items") } | ||||
|  | ||||
|     into(buildDir.resolve("docs/site")) | ||||
| } | ||||
|  | ||||
| // Check tasks | ||||
|  | ||||
| tasks.test { | ||||
|   | ||||
| @@ -6,11 +6,12 @@ | ||||
|   /projects/core/src/main/resources/data/computercraft/lua/bios.lua | ||||
|   /projects/core/src/main/resources/data/computercraft/lua/rom/ | ||||
|   /projects/core/src/test/resources/test-rom | ||||
|   /src/web/mount) | ||||
|   /projects/web/src/mount) | ||||
|  | ||||
|  | ||||
| (doc | ||||
|   (destination build/illuaminate) | ||||
|   ; Also defined in projects/web/build.gradle.kts | ||||
|   (destination /projects/web/build/illuaminate) | ||||
|   (index doc/index.md) | ||||
|  | ||||
|   (site | ||||
| @@ -19,8 +20,8 @@ | ||||
|     (url https://tweaked.cc/) | ||||
|     (source-link https://github.com/cc-tweaked/CC-Tweaked/blob/${commit}/${path}#L${line}) | ||||
|  | ||||
|     (styles src/web/styles.css) | ||||
|     (scripts build/rollup/index.js) | ||||
|     (styles /projects/web/src/styles.css) | ||||
|     (scripts /projects/web/build/rollup/index.js) | ||||
|     (head doc/head.html)) | ||||
|  | ||||
|   (module-kinds | ||||
| @@ -113,4 +114,4 @@ | ||||
|       :max sleep write | ||||
|       cct_test describe expect howlci fail it pending stub))) | ||||
|  | ||||
| (at /src/web/mount/expr_template.lua (lint (globals :max __expr__))) | ||||
| (at /projects/web/src/mount/expr_template.lua (lint (globals :max __expr__))) | ||||
|   | ||||
							
								
								
									
										91
									
								
								projects/web/build.gradle.kts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										91
									
								
								projects/web/build.gradle.kts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,91 @@ | ||||
| plugins { | ||||
|     `lifecycle-base` | ||||
|     id("cc-tweaked.node") | ||||
|     id("cc-tweaked.illuaminate") | ||||
| } | ||||
|  | ||||
| node { | ||||
|     projectRoot.set(rootProject.projectDir) | ||||
| } | ||||
|  | ||||
| illuaminate { | ||||
|     version.set(libs.versions.illuaminate) | ||||
| } | ||||
|  | ||||
| val rollup by tasks.registering(cc.tweaked.gradle.NpxExecToDir::class) { | ||||
|     group = LifecycleBasePlugin.BUILD_GROUP | ||||
|     description = "Bundles JS into rollup" | ||||
|  | ||||
|     // Sources | ||||
|     inputs.files(fileTree("src")).withPropertyName("sources") | ||||
|     // Config files | ||||
|     inputs.file("tsconfig.json").withPropertyName("Typescript config") | ||||
|     inputs.file("rollup.config.js").withPropertyName("Rollup config") | ||||
|  | ||||
|     // Output directory. Also defined in illuaminate.sexp and rollup.config.js | ||||
|     output.set(buildDir.resolve("rollup")) | ||||
|  | ||||
|     args = listOf("rollup", "--config", "rollup.config.js") | ||||
| } | ||||
|  | ||||
| val illuaminateDocs by tasks.registering(cc.tweaked.gradle.IlluaminateExecToDir::class) { | ||||
|     group = JavaBasePlugin.DOCUMENTATION_GROUP | ||||
|     description = "Generates docs using Illuaminate" | ||||
|  | ||||
|     // Config files | ||||
|     inputs.file(rootProject.file("illuaminate.sexp")).withPropertyName("illuaminate config") | ||||
|     // Sources | ||||
|     inputs.files(fileTree("doc")).withPropertyName("docs") | ||||
|     inputs.files(fileTree("src/main/resources/data/computercraft/lua")).withPropertyName("lua rom") | ||||
|     inputs.files(rootProject.tasks.named("luaJavadoc")) | ||||
|     // Additional assets | ||||
|     inputs.files(rollup) | ||||
|     inputs.file("src/styles.css").withPropertyName("styles") | ||||
|  | ||||
|     // Output directory. Also defined in illuaminate.sexp and transform.tsx | ||||
|     output.set(buildDir.resolve("illuaminate")) | ||||
|  | ||||
|     args = listOf("doc-gen") | ||||
|     workingDir = rootProject.projectDir | ||||
| } | ||||
|  | ||||
| val jsxDocs by tasks.registering(cc.tweaked.gradle.NpxExecToDir::class) { | ||||
|     group = JavaBasePlugin.DOCUMENTATION_GROUP | ||||
|     description = "Post-processes documentation to statically render some dynamic content." | ||||
|  | ||||
|     // Config files | ||||
|     inputs.file("tsconfig.json").withPropertyName("Typescript config") | ||||
|     // Sources | ||||
|     inputs.files(fileTree("src")).withPropertyName("sources") | ||||
|     inputs.file(rootProject.file("src/generated/export/index.json")).withPropertyName("export") | ||||
|     inputs.files(illuaminateDocs) | ||||
|  | ||||
|     // Output directory. Also defined in src/transform.tsx | ||||
|     output.set(buildDir.resolve("jsxDocs")) | ||||
|  | ||||
|     args = listOf("ts-node", "-T", "--esm", "src/transform.tsx") | ||||
| } | ||||
|  | ||||
| val docWebsite by tasks.registering(Copy::class) { | ||||
|     group = JavaBasePlugin.DOCUMENTATION_GROUP | ||||
|     description = "Assemble docs and assets together into the documentation website." | ||||
|     duplicatesStrategy = DuplicatesStrategy.FAIL | ||||
|  | ||||
|     from(jsxDocs) | ||||
|  | ||||
|     // Pick up assets from the /docs folder | ||||
|     from(rootProject.file("doc")) { | ||||
|         include("logo.png") | ||||
|         include("images/**") | ||||
|     } | ||||
|     // index.js is provided by illuaminate, but rollup outputs some other chunks | ||||
|     from(rollup) { exclude("index.js") } | ||||
|     // Grab illuaminate's assets. HTML files are provided by jsxDocs | ||||
|     from(illuaminateDocs) { exclude("**/*.html") } | ||||
|     // And item/block images from the data export | ||||
|     from(rootProject.file("src/generated/export/items")) { into("images/items") } | ||||
|  | ||||
|     into(buildDir.resolve("site")) | ||||
| } | ||||
|  | ||||
| tasks.assemble { dependsOn(docWebsite) } | ||||
| @@ -5,13 +5,15 @@ import typescript from "@rollup/plugin-typescript"; | ||||
| import url from '@rollup/plugin-url'; | ||||
| import { terser } from "rollup-plugin-terser"; | ||||
| 
 | ||||
| const input = "src/web"; | ||||
| const requirejs = readFileSync("node_modules/requirejs/require.js"); | ||||
| const input = "src"; | ||||
| const requirejs = readFileSync("../../node_modules/requirejs/require.js"); | ||||
| 
 | ||||
| export default { | ||||
|     input: [`${input}/index.tsx`], | ||||
|     output: { | ||||
|         // Also defined in build.gradle.kts
 | ||||
|         dir: "build/rollup/", | ||||
| 
 | ||||
|         // We bundle requirejs (and config) into the header. It's rather gross
 | ||||
|         // but also works reasonably well.
 | ||||
|         // Also suffix a ?v=${date} onto the end in the event we need to require a specific copy-cat version.
 | ||||
| @@ -39,7 +39,7 @@ const glob = promisify(globModule); | ||||
|             } as any | ||||
|         }); | ||||
| 
 | ||||
|     const dataExport = JSON.parse(await fs.readFile("src/generated/export/index.json", "utf-8")) as DataExport; | ||||
|     const dataExport = JSON.parse(await fs.readFile("../../src/generated/export/index.json", "utf-8")) as DataExport; | ||||
| 
 | ||||
|     for (const file of await glob(base + "/**/*.html")) { | ||||
|         const contents = await fs.readFile(file, "utf-8"); | ||||
| @@ -27,6 +27,6 @@ | ||||
|         "allowSyntheticDefaultImports": true, | ||||
|     }, | ||||
|     "include": [ | ||||
|         "src/web", | ||||
|         "src", | ||||
|     ] | ||||
| } | ||||
| @@ -19,6 +19,7 @@ rootProject.name = "cc-tweaked-$mcVersion" | ||||
| include(":mc-stubs") | ||||
| include(":core-api") | ||||
| include(":core") | ||||
| include(":web") | ||||
|  | ||||
| for (project in rootProject.children) { | ||||
|     project.projectDir = file("projects/${project.name}") | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Jonathan Coates
					Jonathan Coates