liyujie
2025-08-29 87c7c0d90966d729ca3d39cbfca77a39a43960eb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
// Copyright 2015 Google Inc. All rights reserved
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
//      http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
 
// make-c is simple program to measure time to parse Makefiles in android.
package main
 
import (
   "bufio"
   "bytes"
   "fmt"
   "os/exec"
   "time"
)
 
func main() {
   parseDone := make(chan bool)
   cmd := exec.Command("make", "-n")
   r, err := cmd.StdoutPipe()
   if err != nil {
       panic(err)
   }
   t := time.Now()
   go func() {
       s := bufio.NewScanner(r)
       for s.Scan() {
           if bytes.HasPrefix(s.Bytes(), []byte("echo ")) {
               parseDone <- true
               return
           }
           fmt.Println(s.Text())
       }
       if err := s.Err(); err != nil {
           panic(err)
       }
       panic("unexpected end of make?")
   }()
   err = cmd.Start()
   if err != nil {
       panic(err)
   }
   select {
   case <-parseDone:
       fmt.Printf("make -c: %v\n", time.Since(t))
   }
   cmd.Process.Kill()
   cmd.Wait()
}