compileopts: move {root} replacement to compileopts.Emulator()
Этот коммит содержится в:
		
							родитель
							
								
									cc1a95a489
								
							
						
					
					
						коммит
						ca2f25ed48
					
				
					 3 изменённых файлов: 37 добавлений и 30 удалений
				
			
		|  | @ -463,6 +463,15 @@ func (c *Config) WasmAbi() string { | ||||||
| 	return c.Target.WasmAbi | 	return c.Target.WasmAbi | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | // Emulator returns the emulator target config | ||||||
|  | func (c *Config) Emulator() []string { | ||||||
|  | 	var emulator []string | ||||||
|  | 	for _, s := range c.Target.Emulator { | ||||||
|  | 		emulator = append(emulator, strings.ReplaceAll(s, "{root}", goenv.Get("TINYGOROOT"))) | ||||||
|  | 	} | ||||||
|  | 	return emulator | ||||||
|  | } | ||||||
|  | 
 | ||||||
| type TestConfig struct { | type TestConfig struct { | ||||||
| 	CompileTestBinary bool | 	CompileTestBinary bool | ||||||
| 	// TODO: Filter the test functions to run, include verbose flag, etc | 	// TODO: Filter the test functions to run, include verbose flag, etc | ||||||
|  |  | ||||||
|  | @ -232,13 +232,6 @@ func LoadTarget(options *Options) (*TargetSpec, error) { | ||||||
| 		spec.ExtraFiles = append(spec.ExtraFiles, "src/internal/task/task_asyncify_wasm.S") | 		spec.ExtraFiles = append(spec.ExtraFiles, "src/internal/task/task_asyncify_wasm.S") | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	// TODO(dgryski): handle CFLAGS and LDFLAGS here too? |  | ||||||
| 	var emu []string |  | ||||||
| 	for _, s := range spec.Emulator { |  | ||||||
| 		emu = append(emu, strings.ReplaceAll(s, "{root}", goenv.Get("TINYGOROOT"))) |  | ||||||
| 	} |  | ||||||
| 	spec.Emulator = emu |  | ||||||
| 
 |  | ||||||
| 	return spec, nil | 	return spec, nil | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
							
								
								
									
										51
									
								
								main.go
									
										
									
									
									
								
							
							
						
						
									
										51
									
								
								main.go
									
										
									
									
									
								
							|  | @ -251,7 +251,8 @@ func dirsToModuleRoot(maindir, modroot string) []string { | ||||||
| // run the binary. | // run the binary. | ||||||
| func runPackageTest(config *compileopts.Config, stdout, stderr io.Writer, result builder.BuildResult, testVerbose, testShort bool, testRunRegexp string, testBenchRegexp string, testBenchTime string) (bool, error) { | func runPackageTest(config *compileopts.Config, stdout, stderr io.Writer, result builder.BuildResult, testVerbose, testShort bool, testRunRegexp string, testBenchRegexp string, testBenchTime string) (bool, error) { | ||||||
| 	var cmd *exec.Cmd | 	var cmd *exec.Cmd | ||||||
| 	if len(config.Target.Emulator) == 0 { | 	emulator := config.Emulator() | ||||||
|  | 	if len(emulator) == 0 { | ||||||
| 		// Run directly. | 		// Run directly. | ||||||
| 		var flags []string | 		var flags []string | ||||||
| 		if testVerbose { | 		if testVerbose { | ||||||
|  | @ -272,8 +273,8 @@ func runPackageTest(config *compileopts.Config, stdout, stderr io.Writer, result | ||||||
| 		cmd = executeCommand(config.Options, result.Binary, flags...) | 		cmd = executeCommand(config.Options, result.Binary, flags...) | ||||||
| 	} else { | 	} else { | ||||||
| 		// Run in an emulator. | 		// Run in an emulator. | ||||||
| 		args := append(config.Target.Emulator[1:], result.Binary) | 		args := append(emulator[1:], result.Binary) | ||||||
| 		if config.Target.Emulator[0] == "wasmtime" { | 		if emulator[0] == "wasmtime" { | ||||||
| 			// create a new temp directory just for this run, announce it to os.TempDir() via TMPDIR | 			// create a new temp directory just for this run, announce it to os.TempDir() via TMPDIR | ||||||
| 			tmpdir, err := ioutil.TempDir("", "tinygotmp") | 			tmpdir, err := ioutil.TempDir("", "tinygotmp") | ||||||
| 			if err != nil { | 			if err != nil { | ||||||
|  | @ -282,10 +283,12 @@ func runPackageTest(config *compileopts.Config, stdout, stderr io.Writer, result | ||||||
| 			args = append(args, "--dir="+tmpdir, "--env=TMPDIR="+tmpdir) | 			args = append(args, "--dir="+tmpdir, "--env=TMPDIR="+tmpdir) | ||||||
| 			// TODO: add option to not delete temp dir for debugging? | 			// TODO: add option to not delete temp dir for debugging? | ||||||
| 			defer os.RemoveAll(tmpdir) | 			defer os.RemoveAll(tmpdir) | ||||||
|  | 
 | ||||||
| 			// allow reading from directories up to module root | 			// allow reading from directories up to module root | ||||||
| 			for _, d := range dirsToModuleRoot(result.MainDir, result.ModuleRoot) { | 			for _, d := range dirsToModuleRoot(result.MainDir, result.ModuleRoot) { | ||||||
| 				args = append(args, "--dir="+d) | 				args = append(args, "--dir="+d) | ||||||
| 			} | 			} | ||||||
|  | 
 | ||||||
| 			// mark end of wasmtime arguments and start of program ones: -- | 			// mark end of wasmtime arguments and start of program ones: -- | ||||||
| 			args = append(args, "--") | 			args = append(args, "--") | ||||||
| 			if testVerbose { | 			if testVerbose { | ||||||
|  | @ -301,7 +304,7 @@ func runPackageTest(config *compileopts.Config, stdout, stderr io.Writer, result | ||||||
| 				args = append(args, "-test.bench="+testBenchRegexp) | 				args = append(args, "-test.bench="+testBenchRegexp) | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| 		cmd = executeCommand(config.Options, config.Target.Emulator[0], args...) | 		cmd = executeCommand(config.Options, emulator[0], args...) | ||||||
| 	} | 	} | ||||||
| 	cmd.Dir = result.MainDir | 	cmd.Dir = result.MainDir | ||||||
| 	cmd.Stdout = stdout | 	cmd.Stdout = stdout | ||||||
|  | @ -499,12 +502,13 @@ func Debug(debugger, pkgName string, ocdOutput bool, options *compileopts.Option | ||||||
| 		gdbInterface, openocdInterface := config.Programmer() | 		gdbInterface, openocdInterface := config.Programmer() | ||||||
| 		switch gdbInterface { | 		switch gdbInterface { | ||||||
| 		case "msd", "command", "": | 		case "msd", "command", "": | ||||||
| 			if len(config.Target.Emulator) != 0 { | 			emulator := config.Emulator() | ||||||
| 				if config.Target.Emulator[0] == "mgba" { | 			if len(emulator) != 0 { | ||||||
|  | 				if emulator[0] == "mgba" { | ||||||
| 					gdbInterface = "mgba" | 					gdbInterface = "mgba" | ||||||
| 				} else if config.Target.Emulator[0] == "simavr" { | 				} else if emulator[0] == "simavr" { | ||||||
| 					gdbInterface = "simavr" | 					gdbInterface = "simavr" | ||||||
| 				} else if strings.HasPrefix(config.Target.Emulator[0], "qemu-system-") { | 				} else if strings.HasPrefix(emulator[0], "qemu-system-") { | ||||||
| 					gdbInterface = "qemu" | 					gdbInterface = "qemu" | ||||||
| 				} else { | 				} else { | ||||||
| 					// Assume QEMU as an emulator. | 					// Assume QEMU as an emulator. | ||||||
|  | @ -572,34 +576,34 @@ func Debug(debugger, pkgName string, ocdOutput bool, options *compileopts.Option | ||||||
| 			} | 			} | ||||||
| 		case "qemu": | 		case "qemu": | ||||||
| 			port = ":1234" | 			port = ":1234" | ||||||
| 
 | 			emulator := config.Emulator() | ||||||
| 			// Run in an emulator. | 			// Run in an emulator. | ||||||
| 			args := append(config.Target.Emulator[1:], result.Binary, "-s", "-S") | 			args := append(emulator[1:], result.Binary, "-s", "-S") | ||||||
| 			daemon = executeCommand(config.Options, config.Target.Emulator[0], args...) | 			daemon = executeCommand(config.Options, emulator[0], args...) | ||||||
| 			daemon.Stdout = os.Stdout | 			daemon.Stdout = os.Stdout | ||||||
| 			daemon.Stderr = os.Stderr | 			daemon.Stderr = os.Stderr | ||||||
| 		case "qemu-user": | 		case "qemu-user": | ||||||
| 			port = ":1234" | 			port = ":1234" | ||||||
| 
 | 			emulator := config.Emulator() | ||||||
| 			// Run in an emulator. | 			// Run in an emulator. | ||||||
| 			args := append(config.Target.Emulator[1:], "-g", "1234", result.Binary) | 			args := append(emulator[1:], "-g", "1234", result.Binary) | ||||||
| 			daemon = executeCommand(config.Options, config.Target.Emulator[0], args...) | 			daemon = executeCommand(config.Options, emulator[0], args...) | ||||||
| 			daemon.Stdout = os.Stdout | 			daemon.Stdout = os.Stdout | ||||||
| 			daemon.Stderr = os.Stderr | 			daemon.Stderr = os.Stderr | ||||||
| 		case "mgba": | 		case "mgba": | ||||||
| 			port = ":2345" | 			port = ":2345" | ||||||
| 
 | 			emulator := config.Emulator() | ||||||
| 			// Run in an emulator. | 			// Run in an emulator. | ||||||
| 			args := append(config.Target.Emulator[1:], result.Binary, "-g") | 			args := append(emulator[1:], result.Binary, "-g") | ||||||
| 			daemon = executeCommand(config.Options, config.Target.Emulator[0], args...) | 			daemon = executeCommand(config.Options, emulator[0], args...) | ||||||
| 			daemon.Stdout = os.Stdout | 			daemon.Stdout = os.Stdout | ||||||
| 			daemon.Stderr = os.Stderr | 			daemon.Stderr = os.Stderr | ||||||
| 		case "simavr": | 		case "simavr": | ||||||
| 			port = ":1234" | 			port = ":1234" | ||||||
| 
 | 			emulator := config.Emulator() | ||||||
| 			// Run in an emulator. | 			// Run in an emulator. | ||||||
| 			args := append(config.Target.Emulator[1:], "-g", result.Binary) | 			args := append(emulator[1:], "-g", result.Binary) | ||||||
| 			daemon = executeCommand(config.Options, config.Target.Emulator[0], args...) | 			daemon = executeCommand(config.Options, emulator[0], args...) | ||||||
| 			daemon.Stdout = os.Stdout | 			daemon.Stdout = os.Stdout | ||||||
| 			daemon.Stderr = os.Stderr | 			daemon.Stderr = os.Stderr | ||||||
| 		case "msd": | 		case "msd": | ||||||
|  | @ -694,7 +698,8 @@ func Run(pkgName string, options *compileopts.Options) error { | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	return builder.Build(pkgName, ".elf", config, func(result builder.BuildResult) error { | 	return builder.Build(pkgName, ".elf", config, func(result builder.BuildResult) error { | ||||||
| 		if len(config.Target.Emulator) == 0 { | 		emulator := config.Emulator() | ||||||
|  | 		if len(emulator) == 0 { | ||||||
| 			// Run directly. | 			// Run directly. | ||||||
| 			cmd := executeCommand(config.Options, result.Binary) | 			cmd := executeCommand(config.Options, result.Binary) | ||||||
| 			cmd.Stdout = os.Stdout | 			cmd.Stdout = os.Stdout | ||||||
|  | @ -710,8 +715,8 @@ func Run(pkgName string, options *compileopts.Options) error { | ||||||
| 			return nil | 			return nil | ||||||
| 		} else { | 		} else { | ||||||
| 			// Run in an emulator. | 			// Run in an emulator. | ||||||
| 			args := append(config.Target.Emulator[1:], result.Binary) | 			args := append(emulator[1:], result.Binary) | ||||||
| 			cmd := executeCommand(config.Options, config.Target.Emulator[0], args...) | 			cmd := executeCommand(config.Options, emulator[0], args...) | ||||||
| 			cmd.Stdout = os.Stdout | 			cmd.Stdout = os.Stdout | ||||||
| 			cmd.Stderr = os.Stderr | 			cmd.Stderr = os.Stderr | ||||||
| 			err := cmd.Run() | 			err := cmd.Run() | ||||||
|  |  | ||||||
		Загрузка…
	
	Создание таблицы
		
		Сослаться в новой задаче
	
	 Damian Gryski
						Damian Gryski