Compare commits

...

3 commits

Author SHA1 Message Date
semantic-release-bot
18a7d4e156 chore(release): 0.3.0 [skip ci]
## [0.3.0](https://git.kjan.de/jank/project-cli/compare/v0.2.2...v0.3.0) (2025-06-19)

### Features

* Add some compiling ([81ee09b](81ee09b42f))
2025-06-19 14:09:16 +00:00
69fa25bc1d
Merge pull request 'release' (#5) from main into release
Some checks failed
Release / Release (push) Failing after 28s
Reviewed-on: #5
2025-06-19 14:08:50 +00:00
81ee09b42f
feat: Add some compiling
All checks were successful
Label PRs based on size / Check PR size (pull_request) Successful in 5s
2025-06-19 16:07:10 +02:00
4 changed files with 123 additions and 59 deletions

View file

@ -1,3 +1,9 @@
## [0.3.0](https://git.kjan.de/jank/project-cli/compare/v0.2.2...v0.3.0) (2025-06-19)
### Features
* Add some compiling ([81ee09b](https://git.kjan.de/jank/project-cli/commit/81ee09b42fafa5300e384a236602ee22f838da00))
## [0.2.2](https://git.kjan.de/jank/project-cli/compare/v0.2.1...v0.2.2) (2025-06-19)
### Bug Fixes

View file

@ -1,3 +1,5 @@
#!/usr/bin/env node
import fs from "fs";
import { confirm, select, input } from "@inquirer/prompts";
import { exit } from "process";
@ -10,10 +12,18 @@ import {
type Project,
} from "./configuration/configuration";
import { execSync } from "child_process";
import { program } from "commander";
const CLI_NAME = "pcli";
program
.name("project-cli")
.description("A cli for managing projects")
.action(async () => {
if (!fs.existsSync(configPath + "config.toml")) {
const createConfig = await confirm({
message: "No cofig has been found. Would you like to generate a new one?",
message:
"No cofig has been found. Would you like to generate a new one?",
});
if (createConfig) {
@ -36,7 +46,9 @@ if (
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 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,
@ -72,4 +84,36 @@ if (
addProject(newProject);
}
}
const pickedProject = await select({
message: "Which Project would you like to go to?",
choices: getProjects().map((project: Project) => project.name),
});
process.chdir(getConfiguration().projectsDirectory + "/" + pickedProject);
console.log(getProjects());
});
program.command("init").action(() => {
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();

7
package-lock.json generated
View file

@ -1,12 +1,12 @@
{
"name": "proj-cli",
"version": "0.2.2",
"version": "0.3.0",
"lockfileVersion": 3,
"requires": true,
"packages": {
"": {
"name": "proj-cli",
"version": "0.2.2",
"version": "0.3.0",
"dependencies": {
"@saithodev/semantic-release-gitea": "^2.1.0",
"@semantic-release/changelog": "^6.0.3",
@ -21,6 +21,9 @@
"inquirer": "^12.6.3",
"semantic-release": "^24.2.5"
},
"bin": {
"pcli": "dist/index.js"
},
"devDependencies": {
"@types/bun": "latest"
},

View file

@ -1,8 +1,19 @@
{
"name": "proj-cli",
"version": "0.2.2",
"version": "0.3.0",
"module": "index.ts",
"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": {
"@types/bun": "latest"
},