github.com/zach-klippenstein/go@v0.0.0-20150108044943-fcfbeb3adf58/test/fixedbugs/bug260.go (about)

     1  // run
     2  
     3  // Copyright 2010 The Go Authors. All rights reserved.
     4  // Use of this source code is governed by a BSD-style
     5  // license that can be found in the LICENSE file
     6  
     7  // Test that structures pack densely, according to the alignment of the largest field.
     8  
     9  package main
    10  
    11  import (
    12  	"fmt"
    13  	"os"
    14  	"strconv"
    15  )
    16  
    17  type T1 struct {
    18  	x uint8
    19  }
    20  type T2 struct {
    21  	x uint16
    22  }
    23  type T4 struct {
    24  	x uint32
    25  }
    26  
    27  func main() {
    28  	report := len(os.Args) > 1
    29  	status := 0
    30  	var b1 [10]T1
    31  	a0, _ := strconv.ParseUint(fmt.Sprintf("%p", &b1[0])[2:], 16, 64)
    32  	a1, _ := strconv.ParseUint(fmt.Sprintf("%p", &b1[1])[2:], 16, 64)
    33  	if a1 != a0+1 {
    34  		fmt.Println("FAIL")
    35  		if report {
    36  			fmt.Println("alignment should be 1, is", a1-a0)
    37  		}
    38  		status = 1
    39  	}
    40  	var b2 [10]T2
    41  	a0, _ = strconv.ParseUint(fmt.Sprintf("%p", &b2[0])[2:], 16, 64)
    42  	a1, _ = strconv.ParseUint(fmt.Sprintf("%p", &b2[1])[2:], 16, 64)
    43  	if a1 != a0+2 {
    44  		if status == 0 {
    45  			fmt.Println("FAIL")
    46  			status = 1
    47  		}
    48  		if report {
    49  			fmt.Println("alignment should be 2, is", a1-a0)
    50  		}
    51  	}
    52  	var b4 [10]T4
    53  	a0, _ = strconv.ParseUint(fmt.Sprintf("%p", &b4[0])[2:], 16, 64)
    54  	a1, _ = strconv.ParseUint(fmt.Sprintf("%p", &b4[1])[2:], 16, 64)
    55  	if a1 != a0+4 {
    56  		if status == 0 {
    57  			fmt.Println("FAIL")
    58  			status = 1
    59  		}
    60  		if report {
    61  			fmt.Println("alignment should be 4, is", a1-a0)
    62  		}
    63  	}
    64  	os.Exit(status)
    65  }