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