feat: add serve
This commit is contained in:
		
							parent
							
								
									4629cb17c5
								
							
						
					
					
						commit
						1f1e99e690
					
				
					 1 changed files with 36 additions and 15 deletions
				
			
		
							
								
								
									
										51
									
								
								cli.py
									
										
									
									
									
								
							
							
						
						
									
										51
									
								
								cli.py
									
										
									
									
									
								
							| 
						 | 
				
			
			@ -5,6 +5,20 @@ import subprocess
 | 
			
		|||
import sys
 | 
			
		||||
import os
 | 
			
		||||
 | 
			
		||||
def updateIssue(issuePath: str, verbose = False):
 | 
			
		||||
    if verbose:
 | 
			
		||||
        print("get issues")
 | 
			
		||||
    p = subprocess.run(["deno", "run", "-A","tools/getIssue.ts", "--path",issuePath])
 | 
			
		||||
    p.check_returncode()
 | 
			
		||||
 | 
			
		||||
def printDocument(issuePath:str, outDir:str, watch = False, verbose = False):
 | 
			
		||||
    if verbose:
 | 
			
		||||
        print("build document")
 | 
			
		||||
    cmd = ["deno", "run", "-A","tools/printDocument.ts", "--issue_path", issuePath, "--outDir", outDir]
 | 
			
		||||
    if watch:
 | 
			
		||||
        cmd.append("--watch")
 | 
			
		||||
    p = subprocess.run(cmd)
 | 
			
		||||
    p.check_returncode()
 | 
			
		||||
 | 
			
		||||
def build(args):
 | 
			
		||||
    parser = argparse.ArgumentParser(description='Compiling the documentation', prog="cli.py build")
 | 
			
		||||
| 
						 | 
				
			
			@ -19,17 +33,26 @@ def build(args):
 | 
			
		|||
 | 
			
		||||
    issuePath = os.path.join(args.outDir,"issues.json")
 | 
			
		||||
    if args.update_issues:
 | 
			
		||||
        updateIssue(issuePath, args.verbose)
 | 
			
		||||
    printDocument(issuePath, args.outDir, args.watch, args.verbose)
 | 
			
		||||
 | 
			
		||||
def serve(args):
 | 
			
		||||
    """serve the documentation and reload on changes"""
 | 
			
		||||
    parser = argparse.ArgumentParser(description='Serve the documentation and reload changes', prog="cli.py serve")
 | 
			
		||||
    parser.add_argument('-v', '--verbose', action='store_true', help='verbose mode')
 | 
			
		||||
    parser.add_argument('-p', '--port', default=8000, help='port')
 | 
			
		||||
    parser.add_argument('--update_issues', action='store_true', help='update issues')
 | 
			
		||||
    outDir = "build"
 | 
			
		||||
    issuePath = os.path.join(outDir,"issues.json")
 | 
			
		||||
    args = parser.parse_args(args)
 | 
			
		||||
    if args.verbose:
 | 
			
		||||
            print("get issues")
 | 
			
		||||
        p = subprocess.run(["deno", "run", "-A","tools/getIssue.ts", "--path",issuePath])
 | 
			
		||||
        p.check_returncode()
 | 
			
		||||
    if args.verbose:
 | 
			
		||||
        print("build issues")
 | 
			
		||||
    cmd = ["deno", "run", "-A","tools/printDocument.ts", "--issue_path", issuePath, "--outDir", args.outDir]
 | 
			
		||||
    if args.watch:
 | 
			
		||||
        cmd.append("--watch")
 | 
			
		||||
    p = subprocess.run(cmd)
 | 
			
		||||
    p.check_returncode()
 | 
			
		||||
        print("serve start")
 | 
			
		||||
    cmd = ["mdbook", "serve", "--port", str(args.port)]
 | 
			
		||||
    p = subprocess.Popen(cmd)
 | 
			
		||||
    printDocument(issuePath, outDir, True, args.verbose)
 | 
			
		||||
    p.wait()
 | 
			
		||||
    if p.returncode != 0:
 | 
			
		||||
        sys.exit(p.returncode)
 | 
			
		||||
 | 
			
		||||
def help(_args):
 | 
			
		||||
    global commandList
 | 
			
		||||
| 
						 | 
				
			
			@ -42,16 +65,14 @@ def issueUpdate(args):
 | 
			
		|||
    parser.add_argument('-v', '--verbose', action='store_true', help='verbose mode')
 | 
			
		||||
    parser.add_argument('--outDir', default="build", help='output directory')
 | 
			
		||||
    args = parser.parse_args(args)
 | 
			
		||||
    if args.verbose:
 | 
			
		||||
        print("update issues")
 | 
			
		||||
    issuePath = os.path.join(args.outDir,"issues.json")
 | 
			
		||||
    p = subprocess.run(["deno", "run", "-A","tools/getIssue.ts", "--path",issuePath])
 | 
			
		||||
    p.check_returncode()
 | 
			
		||||
    updateIssue(issuePath, args.verbose)
 | 
			
		||||
 | 
			
		||||
commandList = {
 | 
			
		||||
    'build': build,
 | 
			
		||||
    'help': help,
 | 
			
		||||
    'issueUpdate': issueUpdate
 | 
			
		||||
    'issueUpdate': issueUpdate,
 | 
			
		||||
    'serve': serve
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
def main():
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		
		Reference in a new issue