- make token.Position.String more robust
TBR=rsc
DELTA=20 (10 added, 6 deleted, 4 changed)
OCL=32564
CL=32564
// Convert x, whatever it is, to text form.
func toText(x interface{}) []byte {
- type String interface { String() string }
+ type Stringer interface { String() string }
switch v := x.(type) {
case []byte:
return v;
case string:
return strings.Bytes(v);
- case String:
- return strings.Bytes(v.String());
case ast.Decl:
return nodeText(v);
case ast.Expr:
return nodeText(v);
+ case Stringer:
+ // last resort (AST nodes get a String method
+ // from token.Position - don't call that one)
+ return strings.Bytes(v.String());
}
var buf bytes.Buffer;
fmt.Fprint(&buf, x);
func (pos *Position) String() string {
- s := pos.Filename;
- if pos.IsValid() {
+ if pos != nil {
+ s := pos.Filename;
+ if pos.IsValid() {
+ if s != "" {
+ s += ":";
+ }
+ s += fmt.Sprintf("%d:%d", pos.Line, pos.Column);
+ }
if s != "" {
- s += ":";
+ return s;
}
- s += fmt.Sprintf("%d:%d", pos.Line, pos.Column);
- }
- if s != "" {
- return s;
}
return "<unknown position>";
}