mirror of
https://github.com/golang/go
synced 2024-11-14 08:10:22 -07:00
50 lines
1.2 KiB
Go
50 lines
1.2 KiB
Go
|
// run
|
||
|
|
||
|
// Copyright 2014 The Go Authors. All rights reserved.
|
||
|
// Use of this source code is governed by a BSD-style
|
||
|
// license that can be found in the LICENSE file.
|
||
|
|
||
|
// issue 7690 - Stack and other routines did not back up initial PC
|
||
|
// into CALL instruction, instead reporting line number of next instruction,
|
||
|
// which might be on a different line.
|
||
|
|
||
|
package main
|
||
|
|
||
|
import (
|
||
|
"bytes"
|
||
|
"regexp"
|
||
|
"runtime"
|
||
|
"strconv"
|
||
|
)
|
||
|
|
||
|
func main() {
|
||
|
buf1 := make([]byte, 1000)
|
||
|
buf2 := make([]byte, 1000)
|
||
|
|
||
|
runtime.Stack(buf1, false) // CALL is last instruction on this line
|
||
|
n := runtime.Stack(buf2, false) // CALL is followed by load of result from stack
|
||
|
|
||
|
buf1 = buf1[:bytes.IndexByte(buf1, 0)]
|
||
|
buf2 = buf2[:n]
|
||
|
|
||
|
re := regexp.MustCompile(`(?m)^main\.main\(\)\n.*/issue7690.go:([0-9]+)`)
|
||
|
m1 := re.FindStringSubmatch(string(buf1))
|
||
|
if m1 == nil {
|
||
|
println("BUG: cannot find main.main in first trace")
|
||
|
return
|
||
|
}
|
||
|
m2 := re.FindStringSubmatch(string(buf2))
|
||
|
if m2 == nil {
|
||
|
println("BUG: cannot find main.main in second trace")
|
||
|
return
|
||
|
}
|
||
|
|
||
|
n1, _ := strconv.Atoi(m1[1])
|
||
|
n2, _ := strconv.Atoi(m2[1])
|
||
|
if n1+1 != n2 {
|
||
|
println("BUG: expect runtime.Stack on back to back lines, have", n1, n2)
|
||
|
println(string(buf1))
|
||
|
println(string(buf2))
|
||
|
}
|
||
|
}
|