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
e67a2504
Commit
e67a2504
authored
Jul 08, 2011
by
David Symonds
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
gob: export fields in structs in the package documentation.
R=r CC=golang-dev
https://golang.org/cl/4648075
parent
3236097a
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
17 additions
and
17 deletions
+17
-17
src/pkg/gob/doc.go
src/pkg/gob/doc.go
+17
-17
No files found.
src/pkg/gob/doc.go
View file @
e67a2504
...
@@ -29,29 +29,29 @@ receiver and transmitter will do all necessary indirection and dereferencing to
...
@@ -29,29 +29,29 @@ receiver and transmitter will do all necessary indirection and dereferencing to
convert between gobs and actual Go values. For instance, a gob type that is
convert between gobs and actual Go values. For instance, a gob type that is
schematically,
schematically,
struct {
a, b
int }
struct {
A, B
int }
can be sent from or received into any of these Go types:
can be sent from or received into any of these Go types:
struct {
a, b
int } // the same
struct {
A, B
int } // the same
*struct {
a, b
int } // extra indirection of the struct
*struct {
A, B
int } // extra indirection of the struct
struct { *
a, **b
int } // extra indirection of the fields
struct { *
A, **B
int } // extra indirection of the fields
struct {
a, b
int64 } // different concrete value type; see below
struct {
A, B
int64 } // different concrete value type; see below
It may also be received into any of these:
It may also be received into any of these:
struct {
a, b
int } // the same
struct {
A, B
int } // the same
struct {
b, a
int } // ordering doesn't matter; matching is by name
struct {
B, A
int } // ordering doesn't matter; matching is by name
struct {
a, b, c int } // extra field (c
) ignored
struct {
A, B, C int } // extra field (C
) ignored
struct {
b int } // missing field (a
) ignored; data will be dropped
struct {
B int } // missing field (A
) ignored; data will be dropped
struct {
b, c int } // missing field (a) ignored; extra field (c
) ignored.
struct {
B, C int } // missing field (A) ignored; extra field (C
) ignored.
Attempting to receive into these types will draw a decode error:
Attempting to receive into these types will draw a decode error:
struct {
a int; b uint } // change of signedness for b
struct {
A int; B uint } // change of signedness for B
struct {
a int; b float } // change of type for b
struct {
A int; B float } // change of type for B
struct { } // no field names in common
struct { } // no field names in common
struct {
c, d
int } // no field names in common
struct {
C, D
int } // no field names in common
Integers are transmitted two ways: arbitrary precision signed integers or
Integers are transmitted two ways: arbitrary precision signed integers or
arbitrary precision unsigned integers. There is no int8, int16 etc.
arbitrary precision unsigned integers. There is no int8, int16 etc.
...
@@ -269,12 +269,12 @@ StructValue:
...
@@ -269,12 +269,12 @@ StructValue:
/*
/*
For implementers and the curious, here is an encoded example. Given
For implementers and the curious, here is an encoded example. Given
type Point struct {
x, y
int}
type Point struct {
X, Y
int}
and the value
and the value
p := Point{22, 33}
p := Point{22, 33}
the bytes transmitted that encode p will be:
the bytes transmitted that encode p will be:
1f ff 81 03 01 01 05 50 6f 69 6e 74 01 ff 82 00
1f ff 81 03 01 01 05 50 6f 69 6e 74 01 ff 82 00
01 02 01 01
78 01 04 00 01 01 7
9 01 04 00 00 00
01 02 01 01
58 01 04 00 01 01 5
9 01 04 00 00 00
07 ff 82 01 2c 01 42 00
07 ff 82 01 2c 01 42 00
They are determined as follows.
They are determined as follows.
...
@@ -310,13 +310,13 @@ reserved).
...
@@ -310,13 +310,13 @@ reserved).
02 // There are two fields in the type (len(structType.field))
02 // There are two fields in the type (len(structType.field))
01 // Start of first field structure; add 1 to get field number 0: field[0].name
01 // Start of first field structure; add 1 to get field number 0: field[0].name
01 // 1 byte
01 // 1 byte
78 // structType.field[0].name = "x
"
58 // structType.field[0].name = "X
"
01 // Add 1 to get field number 1: field[0].id
01 // Add 1 to get field number 1: field[0].id
04 // structType.field[0].typeId is 2 (signed int).
04 // structType.field[0].typeId is 2 (signed int).
00 // End of structType.field[0]; start structType.field[1]; set field number to -1.
00 // End of structType.field[0]; start structType.field[1]; set field number to -1.
01 // Add 1 to get field number 0: field[1].name
01 // Add 1 to get field number 0: field[1].name
01 // 1 byte
01 // 1 byte
79 // structType.field[1].name = "y
"
59 // structType.field[1].name = "Y
"
01 // Add 1 to get field number 1: field[0].id
01 // Add 1 to get field number 1: field[0].id
04 // struct.Type.field[1].typeId is 2 (signed int).
04 // struct.Type.field[1].typeId is 2 (signed int).
00 // End of structType.field[1]; end of structType.field.
00 // End of structType.field[1]; end of structType.field.
...
...
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