Commit a9647bf9 by Ian Lance Taylor

compiler: stop iterator on error

    
    If there is an error reading or parsing an archive header, the
    Archive_iterator code would return a dummy header but would not mark
    itself as done.  The effect is that an invalid archive leads to an
    endless loop reading and re-reading the same archive header.  Avoid
    that by setting the offset to the end of the file, which will cause
    the iterator to == archive_end.
    
    No test since it doesn't seem worth constructing an invalid archive.
    
    Reviewed-on: https://go-review.googlesource.com/c/158217

From-SVN: r268129
parent 44f4e418
c76ba3014e42cc6adc3d43709bba28c5ad7a6ba2 e7427654f3af83e1feea727a62a97172d7721403
The first line of this file holds the git revision number of the last The first line of this file holds the git revision number of the last
merge done from the gofrontend repository. merge done from the gofrontend repository.
...@@ -780,6 +780,7 @@ Archive_iterator::read_next_header() ...@@ -780,6 +780,7 @@ Archive_iterator::read_next_header()
&this->next_off_)) &this->next_off_))
{ {
this->header_.off = filesize; this->header_.off = filesize;
this->off_ = filesize;
return; return;
} }
this->header_.off = this->off_; this->header_.off = this->off_;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment