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
				
			
		
							
								
								
									
										48
									
								
								index.ts
									
										
									
									
									
								
							
							
						
						
									
										48
									
								
								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,10 +12,18 @@ 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"; | ||||||
| 
 | 
 | ||||||
|  | const CLI_NAME = "pcli"; | ||||||
|  | 
 | ||||||
|  | program | ||||||
|  |   .name("project-cli") | ||||||
|  |   .description("A cli for managing projects") | ||||||
|  |   .action(async () => { | ||||||
|     if (!fs.existsSync(configPath + "config.toml")) { |     if (!fs.existsSync(configPath + "config.toml")) { | ||||||
|       const createConfig = await confirm({ |       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) { |       if (createConfig) { | ||||||
|  | @ -36,7 +46,9 @@ if ( | ||||||
|         choices: ["Clone a project with git", "Create a new empty Project"], |         choices: ["Clone a project with git", "Create a new empty Project"], | ||||||
|       }); |       }); | ||||||
|       if (anwser == "Clone a project with git") { |       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({ |         const wantsCustomName = await confirm({ | ||||||
|           message: "Would you like to give this project a custom name?", |           message: "Would you like to give this project a custom name?", | ||||||
|           default: false, |           default: false, | ||||||
|  | @ -72,4 +84,36 @@ if ( | ||||||
|         addProject(newProject); |         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()); |     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(); | ||||||
|  |  | ||||||
							
								
								
									
										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