// Copyright 2012 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.
package reflect
// MakeRO returns a copy of v with the read-only flag set.
func MakeRO(v Value) Value {
	v.flag |= flagStickyRO
	return v
}
// IsRO reports whether v's read-only flag is set.
func IsRO(v Value) bool {
	return v.flag&flagStickyRO != 0
}
var CallGC = &callGC
// FuncLayout calls funcLayout and returns a subset of the results for testing.
//
// Bitmaps like stack, gc, inReg, and outReg are expanded such that each bit
// takes up one byte, so that writing out test cases is a little clearer.
// If ptrs is false, gc will be nil.
func FuncLayout(t Type, rcvr Type) (frametype Type, argSize, retOffset uintptr, stack, gc, inReg, outReg []byte, ptrs bool) {
	return
}
func TypeLinks() []string {
	return nil
}
var GCBits = gcbits
// Will be provided by runtime eventually.
func gcbits(interface{}) []byte {
	return nil
}
func MapBucketOf(x, y Type) Type {
	return nil
}
func CachedBucketOf(m Type) Type {
	return nil
}
type EmbedWithUnexpMeth struct{}
func (EmbedWithUnexpMeth) f() {}
type pinUnexpMeth interface {
	f()
}
var pinUnexpMethI = pinUnexpMeth(EmbedWithUnexpMeth{})
/*
func FirstMethodNameBytes(t Type) *byte {
	_ = pinUnexpMethI
	ut := t.uncommon()
	if ut == nil {
		panic("type has no methods")
	}
	m := ut.methods()[0]
	mname := t.(*rtype).nameOff(m.name)
	if *mname.data(0, "name flag field")&(1<<2) == 0 {
		panic("method name does not have pkgPath *string")
	}
	return mname.bytes
}
*/
type OtherPkgFields struct {
	OtherExported   int
	otherUnexported int
}
func IsExported(t Type) bool {
	return t.PkgPath() == ""
}
/*
func ResolveReflectName(s string) {
	resolveReflectName(newName(s, "", false))
}
*/
type Buffer struct {
	buf []byte
}
var MethodValueCallCodePtr = methodValueCallCodePtr