feat: Add some compiling
All checks were successful
Label PRs based on size / Check PR size (pull_request) Successful in 5s
All checks were successful
Label PRs based on size / Check PR size (pull_request) Successful in 5s
This commit is contained in:
parent
8bfcadd11f
commit
81ee09b42f
2 changed files with 111 additions and 56 deletions
156
index.ts
156
index.ts
|
@ -1,3 +1,5 @@
|
||||||
|
#!/usr/bin/env node
|
||||||
|
|
||||||
import fs from "fs";
|
import fs from "fs";
|
||||||
import { confirm, select, input } from "@inquirer/prompts";
|
import { confirm, select, input } from "@inquirer/prompts";
|
||||||
import { exit } from "process";
|
import { exit } from "process";
|
||||||
|
@ -10,66 +12,108 @@ import {
|
||||||
type Project,
|
type Project,
|
||||||
} from "./configuration/configuration";
|
} from "./configuration/configuration";
|
||||||
import { execSync } from "child_process";
|
import { execSync } from "child_process";
|
||||||
|
import { program } from "commander";
|
||||||
|
|
||||||
if (!fs.existsSync(configPath + "config.toml")) {
|
const CLI_NAME = "pcli";
|
||||||
const createConfig = await confirm({
|
|
||||||
message: "No cofig has been found. Would you like to generate a new one?",
|
|
||||||
});
|
|
||||||
|
|
||||||
if (createConfig) {
|
program
|
||||||
generateDefaultConfig();
|
.name("project-cli")
|
||||||
} else {
|
.description("A cli for managing projects")
|
||||||
console.log(
|
.action(async () => {
|
||||||
"This project can not run without the config. Either create it yourself or generate the default.",
|
if (!fs.existsSync(configPath + "config.toml")) {
|
||||||
);
|
const createConfig = await confirm({
|
||||||
exit(1);
|
message:
|
||||||
}
|
"No cofig has been found. Would you like to generate a new one?",
|
||||||
}
|
|
||||||
|
|
||||||
if (
|
|
||||||
!getProjects() ||
|
|
||||||
getProjects().length == 0 ||
|
|
||||||
getProjects().length == undefined
|
|
||||||
) {
|
|
||||||
const anwser = await select({
|
|
||||||
message: "Create a new Project",
|
|
||||||
choices: ["Clone a project with git", "Create a new empty Project"],
|
|
||||||
});
|
|
||||||
if (anwser == "Clone a project with git") {
|
|
||||||
const repoUrl = await input({ message: "What is the url of the repo?" });
|
|
||||||
const wantsCustomName = await confirm({
|
|
||||||
message: "Would you like to give this project a custom name?",
|
|
||||||
default: false,
|
|
||||||
});
|
|
||||||
let customName = "";
|
|
||||||
if (wantsCustomName) {
|
|
||||||
customName = await input({
|
|
||||||
message: "What would you like the custom name to be?",
|
|
||||||
});
|
});
|
||||||
|
|
||||||
|
if (createConfig) {
|
||||||
|
generateDefaultConfig();
|
||||||
|
} else {
|
||||||
|
console.log(
|
||||||
|
"This project can not run without the config. Either create it yourself or generate the default.",
|
||||||
|
);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
execSync(
|
if (
|
||||||
"cd " +
|
!getProjects() ||
|
||||||
getConfiguration().projectsDirectory +
|
getProjects().length == 0 ||
|
||||||
" && " +
|
getProjects().length == undefined
|
||||||
getConfiguration()
|
) {
|
||||||
.cloningCommand.replace("%s", repoUrl)
|
const anwser = await select({
|
||||||
.replace("%n", customName),
|
message: "Create a new Project",
|
||||||
);
|
choices: ["Clone a project with git", "Create a new empty Project"],
|
||||||
|
});
|
||||||
|
if (anwser == "Clone a project with git") {
|
||||||
|
const repoUrl = await input({
|
||||||
|
message: "What is the url of the repo?",
|
||||||
|
});
|
||||||
|
const wantsCustomName = await confirm({
|
||||||
|
message: "Would you like to give this project a custom name?",
|
||||||
|
default: false,
|
||||||
|
});
|
||||||
|
let customName = "";
|
||||||
|
if (wantsCustomName) {
|
||||||
|
customName = await input({
|
||||||
|
message: "What would you like the custom name to be?",
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
const newProject: Project = {
|
execSync(
|
||||||
name: customName,
|
"cd " +
|
||||||
};
|
getConfiguration().projectsDirectory +
|
||||||
addProject(newProject);
|
" && " +
|
||||||
} else if (anwser == "Create a new empty Project") {
|
getConfiguration()
|
||||||
const name = await input({
|
.cloningCommand.replace("%s", repoUrl)
|
||||||
message: "What would you like to call the project?",
|
.replace("%n", customName),
|
||||||
|
);
|
||||||
|
|
||||||
|
const newProject: Project = {
|
||||||
|
name: customName,
|
||||||
|
};
|
||||||
|
addProject(newProject);
|
||||||
|
} else if (anwser == "Create a new empty Project") {
|
||||||
|
const name = await input({
|
||||||
|
message: "What would you like to call the project?",
|
||||||
|
});
|
||||||
|
fs.mkdirSync(getConfiguration().projectsDirectory + "/" + name);
|
||||||
|
const newProject: Project = {
|
||||||
|
name: name,
|
||||||
|
};
|
||||||
|
addProject(newProject);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
const pickedProject = await select({
|
||||||
|
message: "Which Project would you like to go to?",
|
||||||
|
choices: getProjects().map((project: Project) => project.name),
|
||||||
});
|
});
|
||||||
fs.mkdirSync(getConfiguration().projectsDirectory + "/" + name);
|
|
||||||
const newProject: Project = {
|
process.chdir(getConfiguration().projectsDirectory + "/" + pickedProject);
|
||||||
name: name,
|
|
||||||
};
|
console.log(getProjects());
|
||||||
addProject(newProject);
|
});
|
||||||
}
|
|
||||||
}
|
program.command("init").action(() => {
|
||||||
console.log(getProjects());
|
console.log(`${CLI_NAME}() {
|
||||||
|
local output
|
||||||
|
output=$(command ${CLI_NAME} "$@")
|
||||||
|
local exit_code=$?
|
||||||
|
|
||||||
|
if [ $exit_code -eq 0 ]; then
|
||||||
|
echo "$output" | while IFS= read -r line; do
|
||||||
|
if [[ $line == __EXEC__* ]]; then
|
||||||
|
eval "\${line#__EXEC__}"
|
||||||
|
else
|
||||||
|
echo "$line"
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
else
|
||||||
|
echo "$output" >&2
|
||||||
|
return $exit_code
|
||||||
|
fi
|
||||||
|
}`);
|
||||||
|
});
|
||||||
|
|
||||||
|
program.parse();
|
||||||
|
|
11
package.json
11
package.json
|
@ -3,6 +3,17 @@
|
||||||
"version": "0.2.1",
|
"version": "0.2.1",
|
||||||
"module": "index.ts",
|
"module": "index.ts",
|
||||||
"type": "module",
|
"type": "module",
|
||||||
|
"bin": {
|
||||||
|
"pcli": "./dist/index.js"
|
||||||
|
},
|
||||||
|
"scripts": {
|
||||||
|
"build": "bun build index.ts --outfile dist/index.js --target node",
|
||||||
|
"dev": "bun run index.ts",
|
||||||
|
"prepublishOnly": "bun run build"
|
||||||
|
},
|
||||||
|
"files": [
|
||||||
|
"dist/"
|
||||||
|
],
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@types/bun": "latest"
|
"@types/bun": "latest"
|
||||||
},
|
},
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue