From: Joe Tsai Date: Fri, 2 Sep 2016 21:37:35 +0000 (-0700) Subject: archive/tar: reapply Header.Size to regFileReader after merging X-Git-Tag: go1.8beta1~1510 X-Git-Url: http://www.git.cypherpunks.su/?a=commitdiff_plain;h=0b84a64da173d811d01a8a59545c22a7e1fd986a;p=gostls13.git archive/tar: reapply Header.Size to regFileReader after merging The use of PAX headers can modify the overall file size, thus the formerly created regFileReader may be stale. The relevant PAX specification for this behavior is: <<< Any fields in the preceding optional extended header shall override the associated fields in this header block for this file. >>> Where "optional extended header" refers to the preceding PAX header. Where "this header block" refers to the subsequent USTAR header. Fixes #15573 Fixes #15564 Change-Id: I83b1c3f05a9ca2d3be38647425ad21a9fe450ee2 Reviewed-on: https://go-review.googlesource.com/28418 Reviewed-by: Brad Fitzpatrick --- diff --git a/src/archive/tar/reader.go b/src/archive/tar/reader.go index b8b1652b2b..fa1c48adeb 100644 --- a/src/archive/tar/reader.go +++ b/src/archive/tar/reader.go @@ -175,11 +175,14 @@ loop: return nil, err } - // TODO(dsnet): The extended headers may have updated the size. - // Thus, we must setup the regFileReader again here. - // - // See golang.org/issue/15573 + // The extended headers may have updated the size. + // Thus, setup the regFileReader again after merging PAX headers. + if err := tr.handleRegularFile(hdr); err != nil { + return nil, err + } + // Sparse formats rely on being able to read from the logical data + // section; there must be a preceding call to handleRegularFile. if err := tr.handleSparseFile(hdr, rawHdr, extHdrs); err != nil { return nil, err } diff --git a/src/archive/tar/reader_test.go b/src/archive/tar/reader_test.go index 3de5299bac..9ffc8d6459 100644 --- a/src/archive/tar/reader_test.go +++ b/src/archive/tar/reader_test.go @@ -237,6 +237,23 @@ var untarTests = []*untarTest{ file: "testdata/pax-bad-mtime-file.tar", err: ErrHeader, }, + { + file: "testdata/pax-pos-size-file.tar", + headers: []*Header{{ + Name: "foo", + Mode: 0640, + Uid: 319973, + Gid: 5000, + Size: 999, + ModTime: time.Unix(1442282516, 0), + Typeflag: '0', + Uname: "joetsai", + Gname: "eng", + }}, + chksums: []string{ + "0afb597b283fe61b5d4879669a350556", + }, + }, { file: "testdata/nil-uid.tar", // golang.org/issue/5290 headers: []*Header{ diff --git a/src/archive/tar/testdata/pax-pos-size-file.tar b/src/archive/tar/testdata/pax-pos-size-file.tar new file mode 100644 index 0000000000..aed9a8aa48 Binary files /dev/null and b/src/archive/tar/testdata/pax-pos-size-file.tar differ