revendor googleapi/internal/uritemplates

This commit is contained in:
Dana Hoffman 2017-06-28 09:24:00 -07:00
parent b19ae9ca8f
commit 75e4af923e
3 changed files with 58 additions and 26 deletions

View File

@ -34,11 +34,37 @@ func pctEncode(src []byte) []byte {
return dst return dst
} }
func escape(s string, allowReserved bool) string { // pairWriter is a convenience struct which allows escaped and unescaped
// versions of the template to be written in parallel.
type pairWriter struct {
escaped, unescaped bytes.Buffer
}
// Write writes the provided string directly without any escaping.
func (w *pairWriter) Write(s string) {
w.escaped.WriteString(s)
w.unescaped.WriteString(s)
}
// Escape writes the provided string, escaping the string for the
// escaped output.
func (w *pairWriter) Escape(s string, allowReserved bool) {
w.unescaped.WriteString(s)
if allowReserved { if allowReserved {
return string(reserved.ReplaceAllFunc([]byte(s), pctEncode)) w.escaped.Write(reserved.ReplaceAllFunc([]byte(s), pctEncode))
} else {
w.escaped.Write(unreserved.ReplaceAllFunc([]byte(s), pctEncode))
} }
return string(unreserved.ReplaceAllFunc([]byte(s), pctEncode)) }
// Escaped returns the escaped string.
func (w *pairWriter) Escaped() string {
return w.escaped.String()
}
// Unescaped returns the unescaped string.
func (w *pairWriter) Unescaped() string {
return w.unescaped.String()
} }
// A uriTemplate is a parsed representation of a URI template. // A uriTemplate is a parsed representation of a URI template.
@ -170,18 +196,20 @@ func parseTerm(term string) (result templateTerm, err error) {
return result, err return result, err
} }
// Expand expands a URI template with a set of values to produce a string. // Expand expands a URI template with a set of values to produce the
func (t *uriTemplate) Expand(values map[string]string) string { // resultant URI. Two forms of the result are returned: one with all the
var buf bytes.Buffer // elements escaped, and one with the elements unescaped.
func (t *uriTemplate) Expand(values map[string]string) (escaped, unescaped string) {
var w pairWriter
for _, p := range t.parts { for _, p := range t.parts {
p.expand(&buf, values) p.expand(&w, values)
} }
return buf.String() return w.Escaped(), w.Unescaped()
} }
func (tp *templatePart) expand(buf *bytes.Buffer, values map[string]string) { func (tp *templatePart) expand(w *pairWriter, values map[string]string) {
if len(tp.raw) > 0 { if len(tp.raw) > 0 {
buf.WriteString(tp.raw) w.Write(tp.raw)
return return
} }
var first = true var first = true
@ -191,30 +219,30 @@ func (tp *templatePart) expand(buf *bytes.Buffer, values map[string]string) {
continue continue
} }
if first { if first {
buf.WriteString(tp.first) w.Write(tp.first)
first = false first = false
} else { } else {
buf.WriteString(tp.sep) w.Write(tp.sep)
} }
tp.expandString(buf, term, value) tp.expandString(w, term, value)
} }
} }
func (tp *templatePart) expandName(buf *bytes.Buffer, name string, empty bool) { func (tp *templatePart) expandName(w *pairWriter, name string, empty bool) {
if tp.named { if tp.named {
buf.WriteString(name) w.Write(name)
if empty { if empty {
buf.WriteString(tp.ifemp) w.Write(tp.ifemp)
} else { } else {
buf.WriteString("=") w.Write("=")
} }
} }
} }
func (tp *templatePart) expandString(buf *bytes.Buffer, t templateTerm, s string) { func (tp *templatePart) expandString(w *pairWriter, t templateTerm, s string) {
if len(s) > t.truncate && t.truncate > 0 { if len(s) > t.truncate && t.truncate > 0 {
s = s[:t.truncate] s = s[:t.truncate]
} }
tp.expandName(buf, t.name, len(s) == 0) tp.expandName(w, t.name, len(s) == 0)
buf.WriteString(escape(s, tp.allowReserved)) w.Escape(s, tp.allowReserved)
} }

View File

@ -4,10 +4,14 @@
package uritemplates package uritemplates
func Expand(path string, values map[string]string) (string, error) { // Expand parses then expands a URI template with a set of values to produce
// the resultant URI. Two forms of the result are returned: one with all the
// elements escaped, and one with the elements unescaped.
func Expand(path string, values map[string]string) (escaped, unescaped string, err error) {
template, err := parse(path) template, err := parse(path)
if err != nil { if err != nil {
return "", err return "", "", err
} }
return template.Expand(values), nil escaped, unescaped = template.Expand(values)
return escaped, unescaped, nil
} }

6
vendor/vendor.json vendored
View File

@ -845,10 +845,10 @@
"revisionTime": "2017-06-27T10:28:48Z" "revisionTime": "2017-06-27T10:28:48Z"
}, },
{ {
"checksumSHA1": "ii4ET3JHk3vkMUEcg+9t/1RZSUU=", "checksumSHA1": "1K0JxrUfDqAB3MyRiU1LKjfHyf4=",
"path": "google.golang.org/api/googleapi/internal/uritemplates", "path": "google.golang.org/api/googleapi/internal/uritemplates",
"revision": "3f131f305a2ae45080e71fdb780128cc92e8745e", "revision": "e6586c9293b9d514c7f5d5076731ec977cff1be6",
"revisionTime": "2016-08-05T04:28:55Z" "revisionTime": "2017-06-27T10:28:48Z"
}, },
{ {
"checksumSHA1": "Mr2fXhMRzlQCgANFm91s536pG7E=", "checksumSHA1": "Mr2fXhMRzlQCgANFm91s536pG7E=",