1
0
mirror of https://github.com/golang/go synced 2024-11-22 07:34:40 -07:00

- method names in method sets/interfaces must be all different

- specify evaluation order of floating-point expressions as
  discussed
- specify floating point conversion rounding as discussed
- slightly reformatted section on conversions to make it
  more readable (hopefully)
- fixed production for interpreted_string_lit - components
  were not properly tagged before because of """ instead of `"`

R=go-dev
DELTA=83  (41 added, 11 deleted, 31 changed)
OCL=35864
CL=35885
This commit is contained in:
Robert Griesemer 2009-10-19 13:13:59 -07:00
parent b4896b496e
commit d4d4ff0d83

View File

@ -362,7 +362,7 @@ A sequence of string literals is concatenated to form a single string.
StringLit = string_lit { string_lit } . StringLit = string_lit { string_lit } .
string_lit = raw_string_lit | interpreted_string_lit . string_lit = raw_string_lit | interpreted_string_lit .
raw_string_lit = "`" { unicode_char } "`" . raw_string_lit = "`" { unicode_char } "`" .
interpreted_string_lit = """ { unicode_value | byte_value } """ . interpreted_string_lit = `"` { unicode_value | byte_value } `"` .
</pre> </pre>
<pre> <pre>
@ -490,6 +490,7 @@ The method set of the corresponding pointer type <code>*T</code>
is the set of all methods with receiver <code>*T</code> or <code>T</code> is the set of all methods with receiver <code>*T</code> or <code>T</code>
(that is, it also contains the method set of <code>T</code>). (that is, it also contains the method set of <code>T</code>).
Any other type has an empty method set. Any other type has an empty method set.
In a method set, each method must have a unique name.
</p> </p>
<p> <p>
The <i>static type</i> (or just <i>type</i>) of a variable is the The <i>static type</i> (or just <i>type</i>) of a variable is the
@ -855,7 +856,7 @@ func (n int) (func (p* T))
<h3 id="Interface_types">Interface types</h3> <h3 id="Interface_types">Interface types</h3>
<p> <p>
An interface type specifies a method set called its <i>interface</i>. An interface type specifies a <a href="#Types">method set</a> called its <i>interface</i>.
A variable of interface type can store a value of any type with a method set A variable of interface type can store a value of any type with a method set
that is any superset of the interface. Such a type is said to that is any superset of the interface. Such a type is said to
<i>implement the interface</i>. An interface value may be <code>nil</code>. <i>implement the interface</i>. An interface value may be <code>nil</code>.
@ -864,10 +865,15 @@ that is any superset of the interface. Such a type is said to
<pre class="ebnf"> <pre class="ebnf">
InterfaceType = "interface" "{" [ MethodSpecList ] "}" . InterfaceType = "interface" "{" [ MethodSpecList ] "}" .
MethodSpecList = MethodSpec { ";" MethodSpec } [ ";" ] . MethodSpecList = MethodSpec { ";" MethodSpec } [ ";" ] .
MethodSpec = identifier Signature | InterfaceTypeName . MethodSpec = MethodName Signature | InterfaceTypeName .
MethodName = identifier .
InterfaceTypeName = TypeName . InterfaceTypeName = TypeName .
</pre> </pre>
<p>
As with all method sets, in an interface type, each method must have a unique name.
</p>
<pre> <pre>
// A simple File interface // A simple File interface
interface { interface {
@ -935,8 +941,7 @@ as the <code>File</code> interface.
<p> <p>
An interface may contain an interface type name <code>T</code> An interface may contain an interface type name <code>T</code>
in place of a method specification. in place of a method specification.
In this notation, <code>T</code> must denote a different interface type The effect is equivalent to enumerating the methods of <code>T</code> explicitly
and the effect is equivalent to enumerating the methods of <code>T</code> explicitly
in the interface. in the interface.
</p> </p>
@ -1766,7 +1771,6 @@ which is a function with a <i>receiver</i>.
<pre class="ebnf"> <pre class="ebnf">
MethodDecl = "func" Receiver MethodName Signature [ Body ] . MethodDecl = "func" Receiver MethodName Signature [ Body ] .
Receiver = "(" [ identifier ] [ "*" ] BaseTypeName ")" . Receiver = "(" [ identifier ] [ "*" ] BaseTypeName ")" .
MethodName = identifier .
BaseTypeName = identifier . BaseTypeName = identifier .
</pre> </pre>
@ -3010,55 +3014,73 @@ Conversion = LiteralType "(" Expression ")" .
</pre> </pre>
<p> <p>
The following conversion rules apply: In general, a conversion succeeds if the value of <code>x</code> is
<a href="#Assignment_compatibility">assignment compatible</a> with type <code>T</code>,
or if the value would be assignment compatible with type <code>T</code> if the
value's type, or <code>T</code>, or any of their component types were unnamed.
Usually, such a conversion changes the type but not the representation of the value
of <code>x</code> and thus has no run-time cost.
</p> </p>
<ul>
<li> <p>
1) The conversion succeeds if the value is <a href="#Assignment_compatibility">assignment compatible</a> Specific rules apply to conversions where <code>T</code> is a numeric or string type.
with type <code>T</code>. These conversions may change the representation of a value and incur a run-time cost.
</li> </p>
<li>
2) The conversion succeeds if the value would be assignment compatible <h4>Conversions between integer types</h4>
with type <code>T</code> if the value's type, or <code>T</code>, or any of their component <p>
types were unnamed. If the value is a signed quantity, it is
</li>
<li>
3) Between integer types: If the value is a signed quantity, it is
sign extended to implicit infinite precision; otherwise it is zero sign extended to implicit infinite precision; otherwise it is zero
extended. It is then truncated to fit in the result type's size. extended. It is then truncated to fit in the result type's size.
For example, if <code>x := uint16(0x10F0)</code>, then <code>uint32(int8(x)) == 0xFFFFFFF0</code>. For example, if <code>x := uint16(0x10F0)</code>, then <code>uint32(int8(x)) == 0xFFFFFFF0</code>.
The conversion always yields a valid value; there is no indication of overflow. The conversion always yields a valid value; there is no indication of overflow.
</li> </p>
<h4>Conversions involving floating point types</h4>
<ol>
<li> <li>
4) Between integer and floating-point types, or between floating-point types:
When converting a floating-point number to an integer, the fraction is discarded When converting a floating-point number to an integer, the fraction is discarded
(truncation towards zero). (truncation towards zero).
In all conversions involving floating-point values, if the result type cannot represent the
value the conversion succeeds but the result value is unspecified.
<font color=red>This behavior may change.</font>
</li> </li>
<li> <li>
5) Strings permit three special conversions: When converting a number to a floating-point type, the result value is rounded
to the precision specified by the floating point type.
For instance, the value of a variable <code>x</code> of type <code>float32</code>
may be stored using additional precision beyond that of an IEEE-754 32-bit number,
but float32(x) represents the result of rounding <code>x</code>'s value to
32-bit precision. Similarly, <code>x + 0.1</code> may use more than 32 bits
of precision, <code>but float32(x + 0.1)</code> does not.
</li> </li>
</ol>
<p>
In all conversions involving floating-point values, if the result type cannot
represent the value the conversion succeeds but the result value is
implementation-dependent.
</p>
<h4>Conversions to a string type</h4>
<ol>
<li> <li>
5a) Converting an integer value yields a string containing the UTF-8 Converting an integer value yields a string containing the UTF-8
representation of the integer. representation of the integer.
<pre> <pre>
string(0x65e5) // "\u65e5" == "日" == "\xe6\x97\xa5" string(0x65e5) // "\u65e5" == "日" == "\xe6\x97\xa5"
</pre> </pre>
</li> </li>
<li> <li>
5b) Converting a slice of integers yields a string that is the Converting a slice of integers yields a string that is the
concatenation of the individual integers converted to strings. concatenation of the individual integers converted to strings.
If the slice value is <code>nil</code>, the result is the empty string. If the slice value is <code>nil</code>, the result is the empty string.
<pre> <pre>
string([]int{0x767d, 0x9d6c, 0x7fd4}) // "\u767d\u9d6c\u7fd4" == "白鵬翔"</pre> string([]int{0x767d, 0x9d6c, 0x7fd4}) // "\u767d\u9d6c\u7fd4" == "白鵬翔"
</pre>
</li> </li>
<li> <li>
5c) Converting a slice of bytes yields a string whose successive Converting a slice of bytes yields a string whose successive
bytes are those of the slice. If the slice value is <code>nil</code>, bytes are those of the slice. If the slice value is <code>nil</code>,
the result is the empty string. the result is the empty string.
@ -3066,7 +3088,7 @@ the result is the empty string.
string([]byte{'h', 'e', 'l', 'l', 'o'}) // "hello" string([]byte{'h', 'e', 'l', 'l', 'o'}) // "hello"
</pre> </pre>
</li> </li>
</ul> </ol>
<p> <p>
There is no linguistic mechanism to convert between pointers and integers. There is no linguistic mechanism to convert between pointers and integers.
@ -3152,7 +3174,15 @@ overflow etc. errors being caught.
When evaluating the elements of an assignment or expression, When evaluating the elements of an assignment or expression,
all function calls, method calls and all function calls, method calls and
communication operations are evaluated in lexical left-to-right communication operations are evaluated in lexical left-to-right
order. Otherwise, the order of evaluation is unspecified. order.
</p>
<p>
Floating-point operations within a single expression are evaluated according to
the associativity of the operators. Explicit parentheses affect the evaluation
by overriding the default associativity.
In the expression <code>x + (y + z)</code> the addition <code>y + z</code>
is performed before adding <code>x</code>.
</p> </p>
<p> <p>
@ -4132,7 +4162,7 @@ guaranteed to stay in the language. They do not return a result.
</p> </p>
<pre class="grammar"> <pre class="grammar">
Call Behavior Function Behavior
print prints all arguments; formatting of arguments is implementation-specific print prints all arguments; formatting of arguments is implementation-specific
println like print but prints spaces between arguments and a newline at the end println like print but prints spaces between arguments and a newline at the end