fix: Add stubs for more missing reflect methods
With these methods stubbed out, the text/template package can be imported. These changes also allow code generated by protoc to compile.
Этот коммит содержится в:
		
							родитель
							
								
									d75e14245b
								
							
						
					
					
						коммит
						cfed3f0213
					
				
					 2 изменённых файлов: 117 добавлений и 27 удалений
				
			
		|  | @ -126,6 +126,35 @@ func (k Kind) basicType() rawType { | ||||||
| 	return rawType(k << 1) | 	return rawType(k << 1) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | // Copied from reflect/type.go | ||||||
|  | // https://go.dev/src/reflect/type.go?#L348 | ||||||
|  | 
 | ||||||
|  | // ChanDir represents a channel type's direction. | ||||||
|  | type ChanDir int | ||||||
|  | 
 | ||||||
|  | const ( | ||||||
|  | 	RecvDir ChanDir             = 1 << iota // <-chan | ||||||
|  | 	SendDir                                 // chan<- | ||||||
|  | 	BothDir = RecvDir | SendDir             // chan | ||||||
|  | ) | ||||||
|  | 
 | ||||||
|  | // Method represents a single method. | ||||||
|  | type Method struct { | ||||||
|  | 	// Name is the method name. | ||||||
|  | 	Name string | ||||||
|  | 
 | ||||||
|  | 	// PkgPath is the package path that qualifies a lower case (unexported) | ||||||
|  | 	// method name. It is empty for upper case (exported) method names. | ||||||
|  | 	// The combination of PkgPath and Name uniquely identifies a method | ||||||
|  | 	// in a method set. | ||||||
|  | 	// See https://golang.org/ref/spec#Uniqueness_of_identifiers | ||||||
|  | 	PkgPath string | ||||||
|  | 
 | ||||||
|  | 	Type  Type  // method type | ||||||
|  | 	Func  Value // func with receiver as first argument | ||||||
|  | 	Index int   // index for Type.Method | ||||||
|  | } | ||||||
|  | 
 | ||||||
| // The following Type type has been copied almost entirely from | // The following Type type has been copied almost entirely from | ||||||
| // https://github.com/golang/go/blob/go1.15/src/reflect/type.go#L27-L212. | // https://github.com/golang/go/blob/go1.15/src/reflect/type.go#L27-L212. | ||||||
| // Some methods have been commented out as they haven't yet been implemented. | // Some methods have been commented out as they haven't yet been implemented. | ||||||
|  | @ -173,7 +202,7 @@ type Type interface { | ||||||
| 	// | 	// | ||||||
| 	// For an interface type, the returned Method's Type field gives the | 	// For an interface type, the returned Method's Type field gives the | ||||||
| 	// method signature, without a receiver, and the Func field is nil. | 	// method signature, without a receiver, and the Func field is nil. | ||||||
| 	//MethodByName(string) (Method, bool) | 	MethodByName(string) (Method, bool) | ||||||
| 
 | 
 | ||||||
| 	// NumMethod returns the number of exported methods in the type's method set. | 	// NumMethod returns the number of exported methods in the type's method set. | ||||||
| 	NumMethod() int | 	NumMethod() int | ||||||
|  | @ -187,7 +216,7 @@ type Type interface { | ||||||
| 	// If the type was predeclared (string, error) or not defined (*T, struct{}, | 	// If the type was predeclared (string, error) or not defined (*T, struct{}, | ||||||
| 	// []int, or A where A is an alias for a non-defined type), the package path | 	// []int, or A where A is an alias for a non-defined type), the package path | ||||||
| 	// will be the empty string. | 	// will be the empty string. | ||||||
| 	//PkgPath() string | 	PkgPath() string | ||||||
| 
 | 
 | ||||||
| 	// Size returns the number of bytes needed to store | 	// Size returns the number of bytes needed to store | ||||||
| 	// a value of the given type; it is analogous to unsafe.Sizeof. | 	// a value of the given type; it is analogous to unsafe.Sizeof. | ||||||
|  | @ -234,7 +263,7 @@ type Type interface { | ||||||
| 
 | 
 | ||||||
| 	// ChanDir returns a channel type's direction. | 	// ChanDir returns a channel type's direction. | ||||||
| 	// It panics if the type's Kind is not Chan. | 	// It panics if the type's Kind is not Chan. | ||||||
| 	//ChanDir() ChanDir | 	ChanDir() ChanDir | ||||||
| 
 | 
 | ||||||
| 	// IsVariadic reports whether a function type's final input parameter | 	// IsVariadic reports whether a function type's final input parameter | ||||||
| 	// is a "..." parameter. If so, t.In(t.NumIn() - 1) returns the parameter's | 	// is a "..." parameter. If so, t.In(t.NumIn() - 1) returns the parameter's | ||||||
|  | @ -248,7 +277,7 @@ type Type interface { | ||||||
| 	//	t.IsVariadic() == true | 	//	t.IsVariadic() == true | ||||||
| 	// | 	// | ||||||
| 	// IsVariadic panics if the type's Kind is not Func. | 	// IsVariadic panics if the type's Kind is not Func. | ||||||
| 	//IsVariadic() bool | 	IsVariadic() bool | ||||||
| 
 | 
 | ||||||
| 	// Elem returns a type's element type. | 	// Elem returns a type's element type. | ||||||
| 	// It panics if the type's Kind is not Array, Chan, Map, Ptr, or Slice. | 	// It panics if the type's Kind is not Array, Chan, Map, Ptr, or Slice. | ||||||
|  | @ -267,7 +296,7 @@ type Type interface { | ||||||
| 
 | 
 | ||||||
| 	// FieldByName returns the struct field with the given name | 	// FieldByName returns the struct field with the given name | ||||||
| 	// and a boolean indicating if the field was found. | 	// and a boolean indicating if the field was found. | ||||||
| 	//FieldByName(name string) (StructField, bool) | 	FieldByName(name string) (StructField, bool) | ||||||
| 
 | 
 | ||||||
| 	// FieldByNameFunc returns the struct field with a name | 	// FieldByNameFunc returns the struct field with a name | ||||||
| 	// that satisfies the match function and a boolean indicating if | 	// that satisfies the match function and a boolean indicating if | ||||||
|  | @ -286,7 +315,7 @@ type Type interface { | ||||||
| 	// In returns the type of a function type's i'th input parameter. | 	// In returns the type of a function type's i'th input parameter. | ||||||
| 	// It panics if the type's Kind is not Func. | 	// It panics if the type's Kind is not Func. | ||||||
| 	// It panics if i is not in the range [0, NumIn()). | 	// It panics if i is not in the range [0, NumIn()). | ||||||
| 	//In(i int) Type | 	In(i int) Type | ||||||
| 
 | 
 | ||||||
| 	// Key returns a map type's key type. | 	// Key returns a map type's key type. | ||||||
| 	// It panics if the type's Kind is not Map. | 	// It panics if the type's Kind is not Map. | ||||||
|  | @ -302,16 +331,16 @@ type Type interface { | ||||||
| 
 | 
 | ||||||
| 	// NumIn returns a function type's input parameter count. | 	// NumIn returns a function type's input parameter count. | ||||||
| 	// It panics if the type's Kind is not Func. | 	// It panics if the type's Kind is not Func. | ||||||
| 	//NumIn() int | 	NumIn() int | ||||||
| 
 | 
 | ||||||
| 	// NumOut returns a function type's output parameter count. | 	// NumOut returns a function type's output parameter count. | ||||||
| 	// It panics if the type's Kind is not Func. | 	// It panics if the type's Kind is not Func. | ||||||
| 	//NumOut() int | 	NumOut() int | ||||||
| 
 | 
 | ||||||
| 	// Out returns the type of a function type's i'th output parameter. | 	// Out returns the type of a function type's i'th output parameter. | ||||||
| 	// It panics if the type's Kind is not Func. | 	// It panics if the type's Kind is not Func. | ||||||
| 	// It panics if i is not in the range [0, NumOut()). | 	// It panics if i is not in the range [0, NumOut()). | ||||||
| 	//Out(i int) Type | 	Out(i int) Type | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // The typecode as used in an interface{}. | // The typecode as used in an interface{}. | ||||||
|  | @ -675,10 +704,26 @@ func (t rawType) Comparable() bool { | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | func (t rawType) ChanDir() ChanDir { | ||||||
|  | 	panic("unimplemented: (reflect.Type).ChanDir()") | ||||||
|  | } | ||||||
|  | 
 | ||||||
| func (t rawType) ConvertibleTo(u Type) bool { | func (t rawType) ConvertibleTo(u Type) bool { | ||||||
| 	panic("unimplemented: (reflect.Type).ConvertibleTo()") | 	panic("unimplemented: (reflect.Type).ConvertibleTo()") | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | func (t rawType) IsVariadic() bool { | ||||||
|  | 	panic("unimplemented: (reflect.Type).IsVariadic()") | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | func (t rawType) NumIn() int { | ||||||
|  | 	panic("unimplemented: (reflect.Type).NumIn()") | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | func (t rawType) NumOut() int { | ||||||
|  | 	panic("unimplemented: (reflect.Type).NumOut()") | ||||||
|  | } | ||||||
|  | 
 | ||||||
| func (t rawType) NumMethod() int { | func (t rawType) NumMethod() int { | ||||||
| 	panic("unimplemented: (reflect.Type).NumMethod()") | 	panic("unimplemented: (reflect.Type).NumMethod()") | ||||||
| } | } | ||||||
|  | @ -691,6 +736,26 @@ func (t rawType) Key() Type { | ||||||
| 	panic("unimplemented: (reflect.Type).Key()") | 	panic("unimplemented: (reflect.Type).Key()") | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | func (t rawType) In(i int) Type { | ||||||
|  | 	panic("unimplemented: (reflect.Type).In()") | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | func (t rawType) Out(i int) Type { | ||||||
|  | 	panic("unimplemented: (reflect.Type).Out()") | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | func (t rawType) MethodByName(name string) (Method, bool) { | ||||||
|  | 	panic("unimplemented: (reflect.Type).MethodByName()") | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | func (t rawType) PkgPath() string { | ||||||
|  | 	panic("unimplemented: (reflect.Type).PkgPath()") | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | func (t rawType) FieldByName(name string) (StructField, bool) { | ||||||
|  | 	panic("unimplemented: (reflect.Type).FieldByName()") | ||||||
|  | } | ||||||
|  | 
 | ||||||
| // A StructField describes a single field in a struct. | // A StructField describes a single field in a struct. | ||||||
| type StructField struct { | type StructField struct { | ||||||
| 	// Name indicates the field name. | 	// Name indicates the field name. | ||||||
|  | @ -704,6 +769,7 @@ type StructField struct { | ||||||
| 	Tag       StructTag // field tag string | 	Tag       StructTag // field tag string | ||||||
| 	Anonymous bool | 	Anonymous bool | ||||||
| 	Offset    uintptr | 	Offset    uintptr | ||||||
|  | 	Index     []int // index sequence for Type.FieldByIndex | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // IsExported reports whether the field is exported. | // IsExported reports whether the field is exported. | ||||||
|  | @ -800,3 +866,7 @@ func (e *TypeError) Error() string { | ||||||
| func align(offset uintptr, alignment uintptr) uintptr { | func align(offset uintptr, alignment uintptr) uintptr { | ||||||
| 	return (offset + alignment - 1) &^ (alignment - 1) | 	return (offset + alignment - 1) &^ (alignment - 1) | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | func SliceOf(t Type) Type { | ||||||
|  | 	panic("unimplemented: reflect.SliceOf()") | ||||||
|  | } | ||||||
|  |  | ||||||
|  | @ -128,7 +128,7 @@ func (v Value) IsNil() bool { | ||||||
| 		_, val := decomposeInterface(*(*interface{})(v.value)) | 		_, val := decomposeInterface(*(*interface{})(v.value)) | ||||||
| 		return val == nil | 		return val == nil | ||||||
| 	default: | 	default: | ||||||
| 		panic(&ValueError{"IsNil"}) | 		panic(&ValueError{Method: "IsNil"}) | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | @ -144,7 +144,7 @@ func (v Value) Pointer() uintptr { | ||||||
| 	case Func: | 	case Func: | ||||||
| 		panic("unimplemented: (reflect.Value).Pointer()") | 		panic("unimplemented: (reflect.Value).Pointer()") | ||||||
| 	default: // not implemented: Func | 	default: // not implemented: Func | ||||||
| 		panic(&ValueError{"Pointer"}) | 		panic(&ValueError{Method: "Pointer"}) | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | @ -187,7 +187,7 @@ func (v Value) Bool() bool { | ||||||
| 			return uintptr(v.value) != 0 | 			return uintptr(v.value) != 0 | ||||||
| 		} | 		} | ||||||
| 	default: | 	default: | ||||||
| 		panic(&ValueError{"Bool"}) | 		panic(&ValueError{Method: "Bool"}) | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | @ -224,7 +224,7 @@ func (v Value) Int() int64 { | ||||||
| 			return int64(int64(uintptr(v.value))) | 			return int64(int64(uintptr(v.value))) | ||||||
| 		} | 		} | ||||||
| 	default: | 	default: | ||||||
| 		panic(&ValueError{"Int"}) | 		panic(&ValueError{Method: "Int"}) | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | @ -267,7 +267,7 @@ func (v Value) Uint() uint64 { | ||||||
| 			return uint64(uintptr(v.value)) | 			return uint64(uintptr(v.value)) | ||||||
| 		} | 		} | ||||||
| 	default: | 	default: | ||||||
| 		panic(&ValueError{"Uint"}) | 		panic(&ValueError{Method: "Uint"}) | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | @ -293,7 +293,7 @@ func (v Value) Float() float64 { | ||||||
| 			return *(*float64)(unsafe.Pointer(&v.value)) | 			return *(*float64)(unsafe.Pointer(&v.value)) | ||||||
| 		} | 		} | ||||||
| 	default: | 	default: | ||||||
| 		panic(&ValueError{"Float"}) | 		panic(&ValueError{Method: "Float"}) | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | @ -315,7 +315,7 @@ func (v Value) Complex() complex128 { | ||||||
| 		// architectures with 128-bit pointers, however. | 		// architectures with 128-bit pointers, however. | ||||||
| 		return *(*complex128)(v.value) | 		return *(*complex128)(v.value) | ||||||
| 	default: | 	default: | ||||||
| 		panic(&ValueError{"Complex"}) | 		panic(&ValueError{Method: "Complex"}) | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | @ -339,6 +339,10 @@ func (v Value) Slice(i, j int) Value { | ||||||
| 	panic("unimplemented: (reflect.Value).Slice()") | 	panic("unimplemented: (reflect.Value).Slice()") | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | func (v Value) Slice3(i, j, k int) Value { | ||||||
|  | 	panic("unimplemented: (reflect.Value).Slice3()") | ||||||
|  | } | ||||||
|  | 
 | ||||||
| //go:linkname maplen runtime.hashmapLenUnsafePointer | //go:linkname maplen runtime.hashmapLenUnsafePointer | ||||||
| func maplen(p unsafe.Pointer) int | func maplen(p unsafe.Pointer) int | ||||||
| 
 | 
 | ||||||
|  | @ -360,7 +364,7 @@ func (v Value) Len() int { | ||||||
| 	case String: | 	case String: | ||||||
| 		return int((*stringHeader)(v.value).len) | 		return int((*stringHeader)(v.value).len) | ||||||
| 	default: | 	default: | ||||||
| 		panic(&ValueError{"Len"}) | 		panic(&ValueError{Method: "Len"}) | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | @ -378,7 +382,7 @@ func (v Value) Cap() int { | ||||||
| 	case Slice: | 	case Slice: | ||||||
| 		return int((*sliceHeader)(v.value).cap) | 		return int((*sliceHeader)(v.value).cap) | ||||||
| 	default: | 	default: | ||||||
| 		panic(&ValueError{"Cap"}) | 		panic(&ValueError{Method: "Cap"}) | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | @ -408,7 +412,7 @@ func (v Value) Elem() Value { | ||||||
| 			flags:    v.flags &^ valueFlagIndirect, | 			flags:    v.flags &^ valueFlagIndirect, | ||||||
| 		} | 		} | ||||||
| 	default: | 	default: | ||||||
| 		panic(&ValueError{"Elem"}) | 		panic(&ValueError{Method: "Elem"}) | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | @ -552,7 +556,7 @@ func (v Value) Index(i int) Value { | ||||||
| 			value:    unsafe.Pointer(value), | 			value:    unsafe.Pointer(value), | ||||||
| 		} | 		} | ||||||
| 	default: | 	default: | ||||||
| 		panic(&ValueError{"Index"}) | 		panic(&ValueError{Method: "Index"}) | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | @ -631,7 +635,7 @@ func (v Value) SetBool(x bool) { | ||||||
| 	case Bool: | 	case Bool: | ||||||
| 		*(*bool)(v.value) = x | 		*(*bool)(v.value) = x | ||||||
| 	default: | 	default: | ||||||
| 		panic(&ValueError{"SetBool"}) | 		panic(&ValueError{Method: "SetBool"}) | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | @ -649,7 +653,7 @@ func (v Value) SetInt(x int64) { | ||||||
| 	case Int64: | 	case Int64: | ||||||
| 		*(*int64)(v.value) = x | 		*(*int64)(v.value) = x | ||||||
| 	default: | 	default: | ||||||
| 		panic(&ValueError{"SetInt"}) | 		panic(&ValueError{Method: "SetInt"}) | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | @ -669,7 +673,7 @@ func (v Value) SetUint(x uint64) { | ||||||
| 	case Uintptr: | 	case Uintptr: | ||||||
| 		*(*uintptr)(v.value) = uintptr(x) | 		*(*uintptr)(v.value) = uintptr(x) | ||||||
| 	default: | 	default: | ||||||
| 		panic(&ValueError{"SetUint"}) | 		panic(&ValueError{Method: "SetUint"}) | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | @ -681,7 +685,7 @@ func (v Value) SetFloat(x float64) { | ||||||
| 	case Float64: | 	case Float64: | ||||||
| 		*(*float64)(v.value) = x | 		*(*float64)(v.value) = x | ||||||
| 	default: | 	default: | ||||||
| 		panic(&ValueError{"SetFloat"}) | 		panic(&ValueError{Method: "SetFloat"}) | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | @ -693,7 +697,7 @@ func (v Value) SetComplex(x complex128) { | ||||||
| 	case Complex128: | 	case Complex128: | ||||||
| 		*(*complex128)(v.value) = x | 		*(*complex128)(v.value) = x | ||||||
| 	default: | 	default: | ||||||
| 		panic(&ValueError{"SetComplex"}) | 		panic(&ValueError{Method: "SetComplex"}) | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | @ -703,7 +707,7 @@ func (v Value) SetString(x string) { | ||||||
| 	case String: | 	case String: | ||||||
| 		*(*string)(v.value) = x | 		*(*string)(v.value) = x | ||||||
| 	default: | 	default: | ||||||
| 		panic(&ValueError{"SetString"}) | 		panic(&ValueError{Method: "SetString"}) | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | @ -788,10 +792,14 @@ type stringHeader struct { | ||||||
| 
 | 
 | ||||||
| type ValueError struct { | type ValueError struct { | ||||||
| 	Method string | 	Method string | ||||||
|  | 	Kind   Kind | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func (e *ValueError) Error() string { | func (e *ValueError) Error() string { | ||||||
| 	return "reflect: call of reflect.Value." + e.Method + " on invalid type" | 	if e.Kind == 0 { | ||||||
|  | 		return "reflect: call of " + e.Method + " on zero Value" | ||||||
|  | 	} | ||||||
|  | 	return "reflect: call of " + e.Method + " on " + e.Kind.String() + " Value" | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // Calls to this function are converted to LLVM intrinsic calls such as | // Calls to this function are converted to LLVM intrinsic calls such as | ||||||
|  | @ -865,3 +873,15 @@ func MakeMap(typ Type) Value { | ||||||
| func (v Value) Call(in []Value) []Value { | func (v Value) Call(in []Value) []Value { | ||||||
| 	panic("unimplemented: (reflect.Value).Call()") | 	panic("unimplemented: (reflect.Value).Call()") | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | func (v Value) MethodByName(name string) Value { | ||||||
|  | 	panic("unimplemented: (reflect.Value).MethodByName()") | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | func (v Value) Recv() (x Value, ok bool) { | ||||||
|  | 	panic("unimplemented: (reflect.Value).Recv()") | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | func NewAt(typ Type, p unsafe.Pointer) Value { | ||||||
|  | 	panic("unimplemented: reflect.New()") | ||||||
|  | } | ||||||
|  |  | ||||||
		Загрузка…
	
	Создание таблицы
		
		Сослаться в новой задаче
	
	 Kyle Conroy
						Kyle Conroy