From 636f088ab87d83db28487c55581729cee62e87f0 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?C=C3=A9dric=20Belin?= Date: Fri, 10 Jan 2025 19:12:20 +0100 Subject: [PATCH] Port the build system to Gulp --- Cakefile | 1 - build.coffee | 39 --------------------------------------- gulpfile.coffee | 46 ++++++++++++++++++++++++++++++++++++++++++++++ 3 files changed, 46 insertions(+), 40 deletions(-) delete mode 100644 Cakefile delete mode 100644 build.coffee create mode 100644 gulpfile.coffee diff --git a/Cakefile b/Cakefile deleted file mode 100644 index 99cecde..0000000 --- a/Cakefile +++ /dev/null @@ -1 +0,0 @@ -require "./build.coffee" diff --git a/build.coffee b/build.coffee deleted file mode 100644 index e5d98ac..0000000 --- a/build.coffee +++ /dev/null @@ -1,39 +0,0 @@ -{spawnSync} = require "node:child_process" -{readdirSync, rmSync} = require "node:fs" -{join} = require "node:path" -{env} = require "node:process" -pkg = require "./package.json" - -task "build", "Builds the project.", -> - npx "coffee", "--compile", "--no-header", "--output", "lib", "src" - -task "clean", "Deletes all generated files.", -> - rmSync "lib", force: yes, recursive: yes - rmSync join("var", file), recursive: yes for file from readdirSync "var" when file isnt ".gitkeep" - -task "dist", "Packages the project.", -> - invoke script for script from ["clean", "build"] - -task "lint", "Performs the static analysis of source code.", -> - npx "coffeelint", "--file=etc/coffeelint.json", "build.coffee", "example", "src", "test" - -task "publish", "Publishes the package.", -> - invoke "dist" - run "npm", "publish", "--registry=#{registry}" for registry from ["https://registry.npmjs.org", "https://npm.pkg.github.com"] - run "git", action..., "v#{pkg.version}" for action from [["tag"], ["push", "origin"]] - -task "test", "Runs the test suite.", -> - env.NODE_ENV = "test" - npx "coffee", "--compile", "--map", "--no-header", "--output", "lib", "src", "test" - run "node", "--enable-source-maps", "--test" - -task "watch", "Watches for file changes.", -> - npx "coffee", "--compile", "--no-header", "--output", "lib", "--watch", "src", "test" - -# Executes a command from a local package. -npx = (command, args...) -> run "npm", "exec", "--", command, args... - -# Spawns a new process using the specified command. -run = (command, args...) -> - {status} = spawnSync command, args, shell: on, stdio: "inherit" - throw Error [command, args...].join " " if status isnt 0 diff --git a/gulpfile.coffee b/gulpfile.coffee new file mode 100644 index 0000000..bad132f --- /dev/null +++ b/gulpfile.coffee @@ -0,0 +1,46 @@ +import gulp from "gulp" +import {spawn} from "node:child_process" +import {readdir, rm} from "node:fs/promises" +import {join} from "node:path" +import {env} from "node:process" + +# Builds the project. +export build = -> + await npx "coffee", "--compile", "--no-header", "--output", "lib", "src" + +# Deletes all generated files. +export clean = -> + await rm "lib", force: yes, recursive: yes + await rm join("var", file), recursive: yes for file from await readdir "var" when file isnt ".gitkeep" + +# Performs the static analysis of source code. +export lint = -> + await npx "coffeelint", "--file=etc/coffeelint.json", "gulpfile.coffee", "example", "src", "test" + +# Publishes the package. +export publish = -> + {default: {version}} = await import("./package.json", with: type: "json") + await npx "gulp" + await run "npm", "publish", "--registry=#{registry}" for registry from ["https://registry.npmjs.org", "https://npm.pkg.github.com"] + await run "git", action..., "v#{version}" for action from [["tag"], ["push", "origin"]] + +# Runs the test suite. +export test = -> + env.NODE_ENV = "test" + await npx "coffee", "--compile", "--map", "--no-header", "--output", "lib", "src", "test" + await run "node", "--enable-source-maps", "--test" + +# Watches for file changes. +export watch = -> + npx "coffee", "--compile", "--no-header", "--output", "lib", "--watch", "src", "test" + +# The default task. +export default gulp.series clean, build + +# Executes a command from a local package. +npx = (command, args...) -> run "npm", "exec", "--", command, args... + +# Spawns a new process using the specified command. +run = (command, args...) -> new Promise (resolve, reject) -> + process = spawn command, args, shell: on, stdio: "inherit" + process.on "close", (code) -> if code then reject(Error [command, args...].join(" ")) else resolve()