Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
go
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
go
Commits
f618f894
Commit
f618f894
authored
Nov 03, 2008
by
Robert Griesemer
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
- keeping track of to-do items
R=r DELTA=15 (10 added, 3 deleted, 2 changed) OCL=18334 CL=18336
parent
78b0013a
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
12 additions
and
5 deletions
+12
-5
doc/go_spec.txt
doc/go_spec.txt
+12
-5
No files found.
doc/go_spec.txt
View file @
f618f894
...
@@ -4,7 +4,7 @@ The Go Programming Language Specification (DRAFT)
...
@@ -4,7 +4,7 @@ The Go Programming Language Specification (DRAFT)
Robert Griesemer, Rob Pike, Ken Thompson
Robert Griesemer, Rob Pike, Ken Thompson
----
----
(
October 30
, 2008)
(
November 3
, 2008)
This document is a semi-formal specification of the Go systems
This document is a semi-formal specification of the Go systems
...
@@ -41,17 +41,17 @@ Todo's:
...
@@ -41,17 +41,17 @@ Todo's:
[ ] need to talk about precise int/floats clearly
[ ] need to talk about precise int/floats clearly
[ ] iant suggests to use abstract/precise int for len(), cap() - good idea
[ ] iant suggests to use abstract/precise int for len(), cap() - good idea
(issue: what happens in len() + const - what is the type?)
(issue: what happens in len() + const - what is the type?)
[ ] need to be specific on (unsigned) integer operations: one must be able
to rely on wrap-around on overflow
Open issues:
Open issues:
[ ] semantics of type decl and where methods are attached
[ ] semantics of type decl and where methods are attached
what about: type MyInt int (does it produce a new (incompatible) int)?
[ ] convert should not be used for composite literals anymore,
[ ] convert should not be used for composite literals anymore,
in fact, convert() should go away
in fact, convert() should go away
[ ] if statement: else syntax must be fixed
[ ] if statement: else syntax must be fixed
[ ] old-style export decls (still needed, but ideally should go away)
[ ] old-style export decls (still needed, but ideally should go away)
[ ] new(arraytype, n1, n2): spec only talks about length, not capacity
(should only use new(arraytype, n) - this will allow later
extension to multi-dim arrays w/o breaking the language)
[ ] like to have assert() in the language, w/ option to disable code gen for it
[ ] like to have assert() in the language, w/ option to disable code gen for it
[ ] composite types should uniformly create an instance instead of a pointer
[ ] composite types should uniformly create an instance instead of a pointer
[ ] semantics of statements
[ ] semantics of statements
...
@@ -86,9 +86,14 @@ Open issues:
...
@@ -86,9 +86,14 @@ Open issues:
Decisions in need of integration into the doc:
Decisions in need of integration into the doc:
[ ] pair assignment is required to get map, and receive ok.
[ ] pair assignment is required to get map, and receive ok.
[ ] len() returns an int, new(array_type, n) n must be an int
[ ] len() returns an int, new(array_type, n) n must be an int
[ ] passing a "..." arg to another "..." parameter doesn't wrap the argument again
(so "..." args can be passed down easily)
Closed:
Closed:
[x] new(arraytype, n1, n2): spec only talks about length, not capacity
(should only use new(arraytype, n) - this will allow later
extension to multi-dim arrays w/o breaking the language) - documented
[x] should we have a shorter list of alias types? (byte, int, uint, float) - done
[x] should we have a shorter list of alias types? (byte, int, uint, float) - done
[x] reflection support
[x] reflection support
[x] syntax for var args
[x] syntax for var args
...
@@ -1140,7 +1145,7 @@ A field declaration may be followed by an optional string literal tag which
...
@@ -1140,7 +1145,7 @@ A field declaration may be followed by an optional string literal tag which
becomes an ``attribute'' for all the identifiers in the corresponding
becomes an ``attribute'' for all the identifiers in the corresponding
field declaration. The tags are available via the reflection library but
field declaration. The tags are available via the reflection library but
are ignored otherwise. A tag may contain arbitrary application-specific
are ignored otherwise. A tag may contain arbitrary application-specific
information
(for instance protocol buffer field information)
.
information.
// A struct corresponding to the EventIdMessage protocol buffer.
// A struct corresponding to the EventIdMessage protocol buffer.
// The tag strings contain the protocol buffer field tags.
// The tag strings contain the protocol buffer field tags.
...
@@ -1908,6 +1913,8 @@ For a value "v" of interface type, "v == nil" is true only if the predeclared
...
@@ -1908,6 +1913,8 @@ For a value "v" of interface type, "v == nil" is true only if the predeclared
constant "nil" is assigned explicitly to "v" (§Assignments), or "v" has not
constant "nil" is assigned explicitly to "v" (§Assignments), or "v" has not
been modified since creation (§Program initialization and execution).
been modified since creation (§Program initialization and execution).
TODO: Should we allow general comparison via interfaces? Problematic.
Logical operators
Logical operators
----
----
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment