Source file
src/cmd/cgo/util.go
1
2
3
4
5 package main
6
7 import (
8 "bytes"
9 "fmt"
10 "go/token"
11 "os"
12 "os/exec"
13 "slices"
14 )
15
16
17
18
19 func run(stdin []byte, argv []string) (stdout, stderr []byte, ok bool) {
20 if i := slices.Index(argv, "-xc"); i >= 0 && argv[len(argv)-1] == "-" {
21
22
23
24 f, err := os.CreateTemp("", "cgo-gcc-input-")
25 if err != nil {
26 fatalf("%s", err)
27 }
28 name := f.Name()
29 f.Close()
30 if err := os.WriteFile(name+".c", stdin, 0666); err != nil {
31 os.Remove(name)
32 fatalf("%s", err)
33 }
34 defer os.Remove(name)
35 defer os.Remove(name + ".c")
36
37
38 new := append(argv[:i:i], argv[i+1:len(argv)-1]...)
39
40
41
42
43
44
45
46
47
48 new = append(new, "-I", ".")
49
50
51 new = append(new, name+".c")
52
53 argv = new
54 stdin = nil
55 }
56
57 p := exec.Command(argv[0], argv[1:]...)
58 p.Stdin = bytes.NewReader(stdin)
59 var bout, berr bytes.Buffer
60 p.Stdout = &bout
61 p.Stderr = &berr
62
63 p.Env = append(os.Environ(), "TERM=dumb")
64 err := p.Run()
65 if _, ok := err.(*exec.ExitError); err != nil && !ok {
66 fatalf("exec %s: %s", argv[0], err)
67 }
68 ok = p.ProcessState.Success()
69 stdout, stderr = bout.Bytes(), berr.Bytes()
70 return
71 }
72
73 func lineno(pos token.Pos) string {
74 return fset.Position(pos).String()
75 }
76
77
78 func fatalf(msg string, args ...interface{}) {
79
80
81 if nerrors == 0 {
82 fmt.Fprintf(os.Stderr, "cgo: "+msg+"\n", args...)
83 }
84 os.Exit(2)
85 }
86
87 var nerrors int
88
89 func error_(pos token.Pos, msg string, args ...interface{}) {
90 nerrors++
91 if pos.IsValid() {
92 fmt.Fprintf(os.Stderr, "%s: ", fset.Position(pos).String())
93 } else {
94 fmt.Fprintf(os.Stderr, "cgo: ")
95 }
96 fmt.Fprintf(os.Stderr, msg, args...)
97 fmt.Fprintf(os.Stderr, "\n")
98 }
99
100 func creat(name string) *os.File {
101 f, err := os.Create(name)
102 if err != nil {
103 fatalf("%s", err)
104 }
105 return f
106 }
107
View as plain text