1. 30 Oct, 2018 10 commits
    • Michael Anthony Knyszek's avatar
      runtime: add successor method to treap · 239341f3
      Michael Anthony Knyszek authored
      This change adds a method for computing a treap node's successor
      to the treap, which will simplify the implementation of algorithms
      used for heap growth scavenging.
      
      For #14045.
      
      Change-Id: If2af3f2707dbcbef5fb6e42cb2712061f9da5129
      Reviewed-on: https://go-review.googlesource.com/c/144718
      Run-TryBot: Michael Knyszek <mknyszek@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarAustin Clements <austin@google.com>
      239341f3
    • Michael Anthony Knyszek's avatar
      runtime: add predecessor method to treap · 5dd4d1f8
      Michael Anthony Knyszek authored
      This change adds a method for computing a treap node's predecessor
      to the treap, which will simplify the implementation of algorithms
      used for heap growth scavenging.
      
      For #14045.
      
      Change-Id: Id203e4bd246db3504f2f0c5163ec36f4579167df
      Reviewed-on: https://go-review.googlesource.com/c/144717
      Run-TryBot: Michael Knyszek <mknyszek@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarAustin Clements <austin@google.com>
      5dd4d1f8
    • Oliver Stenbom's avatar
      os: add support for long path names on unix RemoveAll · 85143d35
      Oliver Stenbom authored
      On unix systems, long enough path names will fail when performing syscalls
      like `Lstat`. The current RemoveAll uses several of these syscalls, and so
      will fail for long paths. This can be risky, as it can let users "hide"
      files from the system or otherwise make long enough paths for programs
      to fail. By using `Unlinkat` and `Openat` syscalls instead, RemoveAll is
      safer on unix systems. Initially implemented for linux, darwin, and several bsds.
      
      Fixes #27029
      Co-authored-by: default avatarGiuseppe Capizzi <gcapizzi@pivotal.io>
      Co-authored-by: default avatarJulia Nedialkova <yulia.nedyalkova@sap.com>
      
      Change-Id: Id9fcdf4775962b021b7ff438dc51ee6d16bb5f56
      GitHub-Last-Rev: b30a621fe359fa2acbb055445b54202b0c508167
      GitHub-Pull-Request: golang/go#27871
      Reviewed-on: https://go-review.googlesource.com/c/137442
      Run-TryBot: Ian Lance Taylor <iant@golang.org>
      Reviewed-by: default avatarIan Lance Taylor <iant@golang.org>
      85143d35
    • Pontus Leitzler's avatar
      crypto/tls: clarify documentation on tls.Config.NextProtos · 7bada2cf
      Pontus Leitzler authored
      This change will aid users to make less mistakes where you, for example, define both HTTP/1.1 and H2, but in the wrong order.
      
          package main
      
          import (
              "crypto/tls"
              "net"
          )
      
          func main() {
              srv := &http.Server{
                  TLSConfig: &tls.Config{
                      NextProtos: []string{"http/1.1", "h2"},
                  },
              }
              srv.ListenAndServeTLS("server.crt", "server.key")
          }
      
      When using major browsers or curl, they will never be served H2 since they also support HTTP/1.0 and the list is processed in order.
      
      Change-Id: Id14098b5e48f624ca308137917874d475c2f22a0
      GitHub-Last-Rev: f3594a6411bf7dde71c850f3e85a2b5a21974129
      GitHub-Pull-Request: golang/go#28367
      Reviewed-on: https://go-review.googlesource.com/c/144387Reviewed-by: default avatarFilippo Valsorda <filippo@golang.org>
      7bada2cf
    • Ben Shi's avatar
      test/codegen: improve arithmetic tests · 455ef3f6
      Ben Shi authored
      This CL fixes several typos and adds two more cases
      to arithmetic test.
      
      Change-Id: I086560162ea351e2166866e444e2317da36c1729
      Reviewed-on: https://go-review.googlesource.com/c/145210
      Run-TryBot: Ben Shi <powerman1st@163.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarCherry Zhang <cherryyz@google.com>
      455ef3f6
    • Alan Donovan's avatar
      bufio: suggest io.ReadFull at (*Reader).Read · 891682c8
      Alan Donovan authored
      Many times when using bufio.Reader I imagine, incorrectly, that it
      implements the retry loop itself, being a high-level buffered wrapper
      around, say, a file descriptor prone to short reads. This comment
      would have saved me much time.
      
      Change-Id: I34c790e0d7c1515430a76d02ce4739b586a36ba7
      Reviewed-on: https://go-review.googlesource.com/c/145577Reviewed-by: default avatarIan Lance Taylor <iant@golang.org>
      Reviewed-by: default avatarRob Pike <r@golang.org>
      891682c8
    • Ian Lance Taylor's avatar
      cmd/compile: add -lang flag to specify language version · 2e9f0817
      Ian Lance Taylor authored
      The default language version is the current one.
      
      For testing purposes, added a check that type aliases require version
      go1.9. There is no consistent support for changes made before 1.12.
      
      Updates #28221
      
      Change-Id: Ia1ef63fff911d5fd29ef79d5fa4e20cfd945feb7
      Reviewed-on: https://go-review.googlesource.com/c/144340
      Run-TryBot: Ian Lance Taylor <iant@golang.org>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarRobert Griesemer <gri@golang.org>
      2e9f0817
    • Tim Cooper's avatar
      crypto/tls: remove unneeded calls to bytes.NewReader · d1836e62
      Tim Cooper authored
      Updates #28269
      
      Change-Id: Iae765f85e6ae49f4b581161ed489b2f5ee27cdba
      Reviewed-on: https://go-review.googlesource.com/c/145737Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
      Run-TryBot: Brad Fitzpatrick <bradfitz@golang.org>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      d1836e62
    • BigMikes's avatar
      net/http: in Transport, don't error on non-chunked response with Trailer header · 7b0fa529
      BigMikes authored
      There are cases where HTTP message specifies the Trailer header
      but not the Transfer-Encoding = chunked. The existing
      implementation would return an error in those cases, without
      returning also the message itself.
      Instead, it would be preferable to let the library user decide when
      the message is valid or not.
      This change makes the fixTrailer() function not to return an error
      and to keep the Trailer value in the Response.Header map but not
      populate Response.Trailer.
      
      Fixes #27197
      
      Change-Id: Ic1e96791fde97f31dc5ecb8de05c8e4f49465c2c
      Reviewed-on: https://go-review.googlesource.com/c/145398
      Run-TryBot: Brad Fitzpatrick <bradfitz@golang.org>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
      7b0fa529
    • Ben Shi's avatar
      cmd/compile: optimize amd64's ADDQconstmodify/ADDLconstmodify · 5f5ea3fd
      Ben Shi authored
      This CL optimize amd64's code:
      "ADDQ $-1, MEM_OP" -> "DECQ MEM_OP"
      "ADDL $-1, MEM_OP" -> "DECL MEM_OP"
      
      1. The total size of pkg/linux_amd64 (excluding cmd/compile)
      decreases about 0.1KB.
      
      2. The go1 benchmark shows little regression, excluding noise.
      name                     old time/op    new time/op    delta
      BinaryTree17-4              2.60s ± 5%     2.64s ± 3%  +1.53%  (p=0.000 n=38+39)
      Fannkuch11-4                2.37s ± 2%     2.38s ± 2%    ~     (p=0.950 n=40+40)
      FmtFprintfEmpty-4          40.4ns ± 5%    40.5ns ± 5%    ~     (p=0.711 n=40+40)
      FmtFprintfString-4         72.4ns ± 5%    72.3ns ± 3%    ~     (p=0.485 n=40+40)
      FmtFprintfInt-4            79.7ns ± 3%    80.1ns ± 3%    ~     (p=0.124 n=40+40)
      FmtFprintfIntInt-4          126ns ± 3%     127ns ± 3%  +0.71%  (p=0.027 n=40+40)
      FmtFprintfPrefixedInt-4     153ns ± 4%     153ns ± 2%    ~     (p=0.604 n=40+40)
      FmtFprintfFloat-4           206ns ± 5%     210ns ± 5%  +1.79%  (p=0.002 n=40+40)
      FmtManyArgs-4               498ns ± 3%     496ns ± 3%    ~     (p=0.099 n=40+40)
      GobDecode-4                6.48ms ± 6%    6.47ms ± 7%    ~     (p=0.686 n=39+40)
      GobEncode-4                5.95ms ± 7%    5.96ms ± 6%    ~     (p=0.670 n=40+34)
      Gzip-4                      224ms ± 6%     223ms ± 5%    ~     (p=0.143 n=40+40)
      Gunzip-4                   36.5ms ± 4%    36.5ms ± 4%    ~     (p=0.556 n=40+40)
      HTTPClientServer-4         60.7µs ± 2%    59.9µs ± 3%  -1.20%  (p=0.000 n=39+39)
      JSONEncode-4               9.03ms ± 4%    9.04ms ± 4%    ~     (p=0.589 n=40+40)
      JSONDecode-4               49.4ms ± 4%    49.2ms ± 4%    ~     (p=0.276 n=40+40)
      Mandelbrot200-4            3.80ms ± 4%    3.79ms ± 4%    ~     (p=0.837 n=40+40)
      GoParse-4                  3.15ms ± 5%    3.13ms ± 5%    ~     (p=0.240 n=40+40)
      RegexpMatchEasy0_32-4      72.9ns ± 3%    72.0ns ± 8%  -1.25%  (p=0.003 n=40+40)
      RegexpMatchEasy0_1K-4       229ns ± 5%     230ns ± 4%    ~     (p=0.318 n=40+40)
      RegexpMatchEasy1_32-4      66.9ns ± 3%    67.3ns ± 7%    ~     (p=0.817 n=40+40)
      RegexpMatchEasy1_1K-4       371ns ± 5%     370ns ± 4%    ~     (p=0.275 n=40+40)
      RegexpMatchMedium_32-4      106ns ± 4%     104ns ± 7%  -2.28%  (p=0.000 n=40+40)
      RegexpMatchMedium_1K-4     32.0µs ± 2%    31.4µs ± 3%  -2.08%  (p=0.000 n=40+40)
      RegexpMatchHard_32-4       1.54µs ± 7%    1.52µs ± 3%  -1.80%  (p=0.007 n=39+40)
      RegexpMatchHard_1K-4       45.8µs ± 4%    45.5µs ± 3%    ~     (p=0.707 n=40+40)
      Revcomp-4                   401ms ± 5%     401ms ± 6%    ~     (p=0.935 n=40+40)
      Template-4                 62.4ms ± 4%    61.2ms ± 3%  -1.85%  (p=0.000 n=40+40)
      TimeParse-4                 315ns ± 2%     318ns ± 3%  +1.10%  (p=0.002 n=40+40)
      TimeFormat-4                297ns ± 3%     298ns ± 3%    ~     (p=0.238 n=40+40)
      [Geo mean]                 45.8µs         45.7µs       -0.22%
      
      name                     old speed      new speed      delta
      GobDecode-4               119MB/s ± 6%   119MB/s ± 7%    ~     (p=0.684 n=39+40)
      GobEncode-4               129MB/s ± 7%   128MB/s ± 6%    ~     (p=0.413 n=40+34)
      Gzip-4                   86.6MB/s ± 6%  87.0MB/s ± 6%    ~     (p=0.145 n=40+40)
      Gunzip-4                  532MB/s ± 4%   532MB/s ± 4%    ~     (p=0.556 n=40+40)
      JSONEncode-4              215MB/s ± 4%   215MB/s ± 4%    ~     (p=0.583 n=40+40)
      JSONDecode-4             39.3MB/s ± 4%  39.5MB/s ± 4%    ~     (p=0.277 n=40+40)
      GoParse-4                18.4MB/s ± 5%  18.5MB/s ± 5%    ~     (p=0.229 n=40+40)
      RegexpMatchEasy0_32-4     439MB/s ± 3%   445MB/s ± 8%  +1.28%  (p=0.003 n=40+40)
      RegexpMatchEasy0_1K-4    4.46GB/s ± 4%  4.45GB/s ± 4%    ~     (p=0.343 n=40+40)
      RegexpMatchEasy1_32-4     479MB/s ± 3%   476MB/s ± 7%    ~     (p=0.855 n=40+40)
      RegexpMatchEasy1_1K-4    2.76GB/s ± 5%  2.77GB/s ± 4%    ~     (p=0.250 n=40+40)
      RegexpMatchMedium_32-4   9.36MB/s ± 4%  9.58MB/s ± 6%  +2.31%  (p=0.001 n=40+40)
      RegexpMatchMedium_1K-4   32.0MB/s ± 2%  32.7MB/s ± 3%  +2.12%  (p=0.000 n=40+40)
      RegexpMatchHard_32-4     20.7MB/s ± 7%  21.1MB/s ± 3%  +1.95%  (p=0.005 n=40+40)
      RegexpMatchHard_1K-4     22.4MB/s ± 4%  22.5MB/s ± 3%    ~     (p=0.689 n=40+40)
      Revcomp-4                 634MB/s ± 5%   634MB/s ± 6%    ~     (p=0.935 n=40+40)
      Template-4               31.1MB/s ± 3%  31.7MB/s ± 3%  +1.88%  (p=0.000 n=40+40)
      [Geo mean]                129MB/s        130MB/s       +0.62%
      
      Change-Id: I9d61ee810d900920c572cbe89e2f1626bfed12b7
      Reviewed-on: https://go-review.googlesource.com/c/145209
      Run-TryBot: Ben Shi <powerman1st@163.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarKeith Randall <khr@golang.org>
      5f5ea3fd
  2. 29 Oct, 2018 12 commits
  3. 28 Oct, 2018 9 commits
  4. 27 Oct, 2018 7 commits
  5. 26 Oct, 2018 2 commits