Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in
Toggle navigation
G
golang
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Commits
Issue Boards
Open sidebar
go
golang
Commits
7b504857
Commit
7b504857
authored
Jan 26, 2012
by
Gustavo Niemeyer
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
doc/go1: add encoding/xml changes
R=golang-dev, r CC=golang-dev
https://golang.org/cl/5569067
parent
bcb976c5
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
100 additions
and
12 deletions
+100
-12
go1.html
doc/go1.html
+50
-6
go1.tmpl
doc/go1.tmpl
+50
-6
No files found.
doc/go1.html
View file @
7b504857
...
@@ -1455,12 +1455,12 @@ or <code>panic</code> should be updated to use the new methods.
...
@@ -1455,12 +1455,12 @@ or <code>panic</code> should be updated to use the new methods.
<h3
id=
"url"
>
The url package
</h3>
<h3
id=
"url"
>
The url package
</h3>
<p>
<p>
In Go 1 several fields from the
<a
href=
"/pkg/net/url#URL"
><code>
url.URL
</code></a>
type
In Go 1 several fields from the
<a
href=
"/pkg/net/url
/
#URL"
><code>
url.URL
</code></a>
type
were removed or replaced.
were removed or replaced.
</p>
</p>
<p>
<p>
The
<a
href=
"/pkg/net/url#URL.String"
><code>
String
</code></a>
method now
The
<a
href=
"/pkg/net/url
/
#URL.String"
><code>
String
</code></a>
method now
predictably rebuilds an encoded URL string using all of
<code>
URL
</code>
's
predictably rebuilds an encoded URL string using all of
<code>
URL
</code>
's
fields as necessary. The resulting string will also no longer have
fields as necessary. The resulting string will also no longer have
passwords escaped.
passwords escaped.
...
@@ -1473,9 +1473,9 @@ method may be used in its place.
...
@@ -1473,9 +1473,9 @@ method may be used in its place.
<p>
<p>
The old
<code>
RawUserinfo
</code>
field is replaced by the
<code>
User
</code>
The old
<code>
RawUserinfo
</code>
field is replaced by the
<code>
User
</code>
field, of type
<a
href=
"/pkg/net/url#Userinfo"
><code>
*net.Userinfo
</code></a>
.
field, of type
<a
href=
"/pkg/net/url
/
#Userinfo"
><code>
*net.Userinfo
</code></a>
.
Values of this type may be created using the new
<a
href=
"/pkg/net/url#User"
><code>
net.User
</code></a>
Values of this type may be created using the new
<a
href=
"/pkg/net/url
/
#User"
><code>
net.User
</code></a>
and
<a
href=
"/pkg/net/url#UserPassword"
><code>
net.UserPassword
</code></a>
and
<a
href=
"/pkg/net/url
/
#UserPassword"
><code>
net.UserPassword
</code></a>
functions. The
<code>
EscapeUserinfo
</code>
and
<code>
UnescapeUserinfo
</code>
functions. The
<code>
EscapeUserinfo
</code>
and
<code>
UnescapeUserinfo
</code>
functions are also gone.
functions are also gone.
</p>
</p>
...
@@ -1510,7 +1510,7 @@ path for such URLs. In Go 1, the cited URL parses as:
...
@@ -1510,7 +1510,7 @@ path for such URLs. In Go 1, the cited URL parses as:
</pre>
</pre>
<p>
<p>
A new
<a
href=
"/pkg/net/url#URL.RequestURI"
><code>
RequestURI
</code></a>
method was
A new
<a
href=
"/pkg/net/url
/
#URL.RequestURI"
><code>
RequestURI
</code></a>
method was
added to
<code>
URL
</code>
.
added to
<code>
URL
</code>
.
</p>
</p>
...
@@ -1520,6 +1520,50 @@ Code that uses the old fields will fail to compile and must be updated by hand.
...
@@ -1520,6 +1520,50 @@ Code that uses the old fields will fail to compile and must be updated by hand.
The semantic changes make it difficult for gofix to update automatically.
The semantic changes make it difficult for gofix to update automatically.
</p>
</p>
<h3
id=
"xml"
>
The xml package
</h3>
<p>
In Go 1, the
<a
href=
"/pkg/encoding/xml/"
><code>
xml
</code></a>
package
has been brought closer in design to the other marshaling packages such
as
<a
href=
"/pkg/encoding/gob/"
><code>
encoding/gob
</code></a>
.
</p>
<p>
The old
<code>
Parser
</code>
type is renamed
<a
href=
"/pkg/encoding/xml/#Decoder"
><code>
Decoder
</code></a>
and has a new
<a
href=
"/pkg/encoding/xml/#Decoder.Decode"
><code>
Decode
</code></a>
method. An
<a
href=
"/pkg/encoding/xml/#Encoder"
><code>
Encoder
</code></a>
type was also
introduced.
</p>
<p>
The functions
<a
href=
"/pkg/encoding/xml/#Marshal"
><code>
Marshal
</code></a>
and
<a
href=
"/pkg/encoding/xml/#Unmarshal"
><code>
Unmarshal
</code></a>
work with
<code>
[]byte
</code>
values now. To work with streams,
use the new
<a
href=
"/pkg/encoding/xml/#Encoder"
><code>
Encoder
</code></a>
and
<a
href=
"/pkg/encoding/xml/#Decoder"
><code>
Decoder
</code></a>
types.
</p>
<p>
When marshaling or unmarshaling values, the format of supported flags in
field tags has changed to be closer to the
<a
href=
"/pkg/encoding/json"
><code>
json
</code></a>
package
(
<code>
`xml:"name,flag"`
</code>
). The matching done between field tags, field
names, and the XML attribute and element names is now case-sensitive.
The
<code>
XMLName
</code>
field tag, if present, must also match the name
of the XML element being marshaled.
</p>
<p>
<em>
Updating
</em>
:
Gofix will update most uses of the package except for some calls to
<code>
Unmarshal
</code>
. Special care must be taken with field tags,
since gofix will not update them and if not fixed by hand they will
misbehave silently in some cases. For example, the old
<code>
"attr"
</code>
is now written
<code>
",attr"
</code>
while plain
<code>
"attr"
</code>
remains valid but with a different meaning.
</p>
<h2
id=
"go_command"
>
The go command
</h2>
<h2
id=
"go_command"
>
The go command
</h2>
<h2
id=
"releases"
>
Packaged releases
</h2>
<h2
id=
"releases"
>
Packaged releases
</h2>
...
...
doc/go1.tmpl
View file @
7b504857
...
@@ -1345,12 +1345,12 @@ or <code>panic</code> should be updated to use the new methods.
...
@@ -1345,12 +1345,12 @@ or <code>panic</code> should be updated to use the new methods.
<h3 id="url">The url package</h3>
<h3 id="url">The url package</h3>
<p>
<p>
In Go 1 several fields from the <a href="/pkg/net/url#URL"><code>url.URL</code></a> type
In Go 1 several fields from the <a href="/pkg/net/url
/
#URL"><code>url.URL</code></a> type
were removed or replaced.
were removed or replaced.
</p>
</p>
<p>
<p>
The <a href="/pkg/net/url#URL.String"><code>String</code></a> method now
The <a href="/pkg/net/url
/
#URL.String"><code>String</code></a> method now
predictably rebuilds an encoded URL string using all of <code>URL</code>'
s
predictably rebuilds an encoded URL string using all of <code>URL</code>'
s
fields
as
necessary
.
The
resulting
string
will
also
no
longer
have
fields
as
necessary
.
The
resulting
string
will
also
no
longer
have
passwords
escaped
.
passwords
escaped
.
...
@@ -1363,9 +1363,9 @@ method may be used in its place.
...
@@ -1363,9 +1363,9 @@ method may be used in its place.
<
p
>
<
p
>
The
old
<
code
>
RawUserinfo
</
code
>
field
is
replaced
by
the
<
code
>
User
</
code
>
The
old
<
code
>
RawUserinfo
</
code
>
field
is
replaced
by
the
<
code
>
User
</
code
>
field
,
of
type
<
a
href
=
"/pkg/net/url#Userinfo"
><
code
>*
net
.
Userinfo
</
code
></
a
>.
field
,
of
type
<
a
href
=
"/pkg/net/url
/
#Userinfo"
><
code
>*
net
.
Userinfo
</
code
></
a
>.
Values
of
this
type
may
be
created
using
the
new
<
a
href
=
"/pkg/net/url#User"
><
code
>
net
.
User
</
code
></
a
>
Values
of
this
type
may
be
created
using
the
new
<
a
href
=
"/pkg/net/url
/
#User"
><
code
>
net
.
User
</
code
></
a
>
and
<
a
href
=
"/pkg/net/url#UserPassword"
><
code
>
net
.
UserPassword
</
code
></
a
>
and
<
a
href
=
"/pkg/net/url
/
#UserPassword"
><
code
>
net
.
UserPassword
</
code
></
a
>
functions
.
The
<
code
>
EscapeUserinfo
</
code
>
and
<
code
>
UnescapeUserinfo
</
code
>
functions
.
The
<
code
>
EscapeUserinfo
</
code
>
and
<
code
>
UnescapeUserinfo
</
code
>
functions
are
also
gone
.
functions
are
also
gone
.
</
p
>
</
p
>
...
@@ -1400,7 +1400,7 @@ path for such URLs. In Go 1, the cited URL parses as:
...
@@ -1400,7 +1400,7 @@ path for such URLs. In Go 1, the cited URL parses as:
</
pre
>
</
pre
>
<
p
>
<
p
>
A
new
<
a
href
=
"/pkg/net/url#URL.RequestURI"
><
code
>
RequestURI
</
code
></
a
>
method
was
A
new
<
a
href
=
"/pkg/net/url
/
#URL.RequestURI"
><
code
>
RequestURI
</
code
></
a
>
method
was
added
to
<
code
>
URL
</
code
>.
added
to
<
code
>
URL
</
code
>.
</
p
>
</
p
>
...
@@ -1410,6 +1410,50 @@ Code that uses the old fields will fail to compile and must be updated by hand.
...
@@ -1410,6 +1410,50 @@ Code that uses the old fields will fail to compile and must be updated by hand.
The
semantic
changes
make
it
difficult
for
gofix
to
update
automatically
.
The
semantic
changes
make
it
difficult
for
gofix
to
update
automatically
.
</
p
>
</
p
>
<
h3
id
=
"xml"
>
The
xml
package
</
h3
>
<
p
>
In
Go
1
,
the
<
a
href
=
"/pkg/encoding/xml/"
><
code
>
xml
</
code
></
a
>
package
has
been
brought
closer
in
design
to
the
other
marshaling
packages
such
as
<
a
href
=
"/pkg/encoding/gob/"
><
code
>
encoding
/
gob
</
code
></
a
>.
</
p
>
<
p
>
The
old
<
code
>
Parser
</
code
>
type
is
renamed
<
a
href
=
"/pkg/encoding/xml/#Decoder"
><
code
>
Decoder
</
code
></
a
>
and
has
a
new
<
a
href
=
"/pkg/encoding/xml/#Decoder.Decode"
><
code
>
Decode
</
code
></
a
>
method
.
An
<
a
href
=
"/pkg/encoding/xml/#Encoder"
><
code
>
Encoder
</
code
></
a
>
type
was
also
introduced
.
</
p
>
<
p
>
The
functions
<
a
href
=
"/pkg/encoding/xml/#Marshal"
><
code
>
Marshal
</
code
></
a
>
and
<
a
href
=
"/pkg/encoding/xml/#Unmarshal"
><
code
>
Unmarshal
</
code
></
a
>
work
with
<
code
>[]
byte
</
code
>
values
now
.
To
work
with
streams
,
use
the
new
<
a
href
=
"/pkg/encoding/xml/#Encoder"
><
code
>
Encoder
</
code
></
a
>
and
<
a
href
=
"/pkg/encoding/xml/#Decoder"
><
code
>
Decoder
</
code
></
a
>
types
.
</
p
>
<
p
>
When
marshaling
or
unmarshaling
values
,
the
format
of
supported
flags
in
field
tags
has
changed
to
be
closer
to
the
<
a
href
=
"/pkg/encoding/json"
><
code
>
json
</
code
></
a
>
package
(<
code
>`
xml
:
"name,flag"
`</
code
>).
The
matching
done
between
field
tags
,
field
names
,
and
the
XML
attribute
and
element
names
is
now
case
-
sensitive
.
The
<
code
>
XMLName
</
code
>
field
tag
,
if
present
,
must
also
match
the
name
of
the
XML
element
being
marshaled
.
</
p
>
<
p
>
<
em
>
Updating
</
em
>:
Gofix
will
update
most
uses
of
the
package
except
for
some
calls
to
<
code
>
Unmarshal
</
code
>.
Special
care
must
be
taken
with
field
tags
,
since
gofix
will
not
update
them
and
if
not
fixed
by
hand
they
will
misbehave
silently
in
some
cases
.
For
example
,
the
old
<
code
>
"attr"
</
code
>
is
now
written
<
code
>
",attr"
</
code
>
while
plain
<
code
>
"attr"
</
code
>
remains
valid
but
with
a
different
meaning
.
</
p
>
<
h2
id
=
"go_command"
>
The
go
command
</
h2
>
<
h2
id
=
"go_command"
>
The
go
command
</
h2
>
<
h2
id
=
"releases"
>
Packaged
releases
</
h2
>
<
h2
id
=
"releases"
>
Packaged
releases
</
h2
>
...
...
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