|
Revision tags: release/13.4.0-p5, release/13.5.0-p1, release/14.2.0-p3, release/13.5.0, release/14.2.0-p2, release/14.1.0-p8, release/13.4.0-p4, release/14.1.0-p7, release/14.2.0-p1, release/13.4.0-p3, release/14.2.0, release/13.4.0, release/14.1.0, release/13.3.0 |
|
| #
4ffc5ab0 |
| 12-Feb-2024 |
Dag-Erling Smørgrav <[email protected]> |
patch: Support long context lines.
MFC after: 1 week Sponsored by: Klara, Inc. Reviewed by: allanjude Differential Revision: https://reviews.freebsd.org/D43850
(cherry picked from commit 851a9da38f
patch: Support long context lines.
MFC after: 1 week Sponsored by: Klara, Inc. Reviewed by: allanjude Differential Revision: https://reviews.freebsd.org/D43850
(cherry picked from commit 851a9da38f070675c42a6d69c41c47a5d29ee3d0)
show more ...
|
|
Revision tags: release/14.0.0 |
|
| #
42b38843 |
| 16-Aug-2023 |
Warner Losh <[email protected]> |
Remove $FreeBSD$: one-line .h pattern
Remove /^\s*\*+\s*\$FreeBSD\$.*$\n/
|
| #
9610cbc0 |
| 07-Aug-2023 |
Pedro F. Giffuni <[email protected]> |
patch: don't run off the end of path if it ends in '/'.
Found by fuzzing (afl) in OpenBSD.
Obtained from: OpenBSD (CVS 1.65)
|
|
Revision tags: release/13.2.0, release/12.4.0, release/13.1.0, release/12.3.0 |
|
| #
c384a278 |
| 22-Jul-2021 |
Pedro F. Giffuni <[email protected]> |
patch: cleanup variable initialization a bit.
musl libc fgetln is a bit more pickier.
Hinted by: chimera-linux (git 31491e1de2e1241885984cd9e4b978965f14eda4)
|
|
Revision tags: release/13.0.0, release/12.2.0 |
|
| #
c7cddf95 |
| 16-Aug-2020 |
Warner Losh <[email protected]> |
Remove heuristic for dealing with trailing newlines being truncated by mailers.
Every version of patch since the first one posted to mod.sources in 1985 have included a heuristic for coping with the
Remove heuristic for dealing with trailing newlines being truncated by mailers.
Every version of patch since the first one posted to mod.sources in 1985 have included a heuristic for coping with the state of email messaging at the time. This heuristic would add up to 4 blank lines to a patch if it thought it needed it. The trouble is, though this causes at least one bug.
The bug in my case is that if you have a context diff whose last hunk only deletes 3 or fewer lines, then if you try to reverse apply it with -R, it will fail. The reason for this is the heuristic builds an internal representation that includes those blank lines. However, it should really replicate the lines from the pattern lines line it would any other time, not assume they are blank lines. Removing this heuristic will prevent patch from misapplying the lines removed after applying a 'fuzz' factor to the previous blank line in the file. I believe this will only affect 'new-style' 4.3BSD context diffs and not the older-style 4.2BSD diffs and plain, non-context diffs. It won't affect any of the newer formats, since they don't use the 'omitted' construct in the same way.
Since this heuristic was put into patch at a time when email / etc ate trailing white space on a regular basis, and since it's clear that this heuristic is the wrong thing to do at least some of the time, it's better to remove it entirely. It's not been needed for maybe 20 years since patch files are not usually corrupted. If there are a small number of patch files that would benefit from this corruption fixing, those already-currupt patches can be fixed by the addition of blank lines. I'd wager that no one will ever come to me with an example of a once-working patch file that breaks with this change. However, I have 2 patches from the first 195 patches to 2.11BSD that are affected by this bug, suggesting that the relative frequency of the issue has changed signficantly since the original heuristic was put into place.
Reviewed by: phk@ Differential Revision: https://reviews.freebsd.org/D26081
show more ...
|
|
Revision tags: release/11.4.0 |
|
| #
50dacbf6 |
| 04-Nov-2019 |
Kyle Evans <[email protected]> |
patch(1): give /dev/null patches special treatment
We have a bad habit of duplicating contents of files that are sourced from /dev/null and applied more than once... take the more sane (in most ways
patch(1): give /dev/null patches special treatment
We have a bad habit of duplicating contents of files that are sourced from /dev/null and applied more than once... take the more sane (in most ways) GNU route and complain if the file exists and offer reversal options.
This still falls short a little bit as selecting "don't reverse, apply anyway" will still give you duplicated file contents. There's probably other issues as well, but awareness is the first step to happiness.
MFC after: 2 weeks Differential Revision: https://reviews.freebsd.org/D21535
show more ...
|
|
Revision tags: release/12.1.0, release/11.3.0 |
|
| #
ef30b5a8 |
| 01-Mar-2019 |
Kyle Evans <[email protected]> |
patch(1): Exit successfully if we're fed a 0-length patch
This change is made in the name of GNU patch compatibility. If GNU patch is fed a zero-length patch, it will exit successfully with no outpu
patch(1): Exit successfully if we're fed a 0-length patch
This change is made in the name of GNU patch compatibility. If GNU patch is fed a zero-length patch, it will exit successfully with no output. This is used in at least one port to date (comms/wsjtx), and we break on this usage.
It seems unlikely that anyone relies on patch(1) calling their completely empty patch garbage and failing, and GNU compatibility is a plus if it helps with porting, so make the switch.
Reported by: db MFC after: 2 weeks
show more ...
|
|
Revision tags: release/12.0.0, release/11.2.0 |
|
| #
76df519f |
| 21-Dec-2017 |
Pedro F. Giffuni <[email protected]> |
patch: further cleanup to git-style diffs.
Fix adding and removing files with git-style a/ b/ diffs: only skip six letters if they actually match "--- a/" and "+++ b/" instead of laxer checks.
Obta
patch: further cleanup to git-style diffs.
Fix adding and removing files with git-style a/ b/ diffs: only skip six letters if they actually match "--- a/" and "+++ b/" instead of laxer checks.
Obtained from: OpenBSD (CVS 1.59)
show more ...
|
| #
4835edfa |
| 09-Oct-2017 |
Kyle Evans <[email protected]> |
patch(1): Don't overrun line buffer in some cases
Patches like file.txt attached to PR 190195 with a final line formed like ">(EOL)" could cause a copy past the end of the current line buffer. In th
patch(1): Don't overrun line buffer in some cases
Patches like file.txt attached to PR 190195 with a final line formed like ">(EOL)" could cause a copy past the end of the current line buffer. In the case of PR 191641, this caused a duplicate line to be copied into the resulting file.
Instead of running past the end, treat it as if it were a blank line.
PR: 191641 Reviewed by: cem, emaste, pfg Approved by: emaste (mentor) Differential Revision: https://reviews.freebsd.org/D12609
show more ...
|
|
Revision tags: release/10.4.0, release/11.1.0 |
|
| #
85823a60 |
| 02-Jul-2017 |
Pedro F. Giffuni <[email protected]> |
patch(1): add support for git generated diffs.
Sometimes patches coming from other places have extra a/ and b/ directories prepended to filenames.
Obtained from: OpenBSD (CVS rev. 1.57, 1.58)
|
| #
12300d3a |
| 08-Jun-2017 |
Pedro F. Giffuni <[email protected]> |
patch: if reading fails, do not go into infinite loop asking for a filename.
This can happen if no tty is available.
Obtained from: OpenBSD (CVS rev 1.54) MFC after: 5 days
|
| #
4f548c19 |
| 02-Jan-2017 |
Pedro F. Giffuni <[email protected]> |
Revert r311106: patch(1): extend the maximum length of a line from USHRT_MAX to UINT_MAX.
This doesn't really work for 32 bit platforms.
Pointed out by: kib
|
| #
ad8469fe |
| 02-Jan-2017 |
Pedro F. Giffuni <[email protected]> |
patch(1): extend the maximum length of a line from USHRT_MAX to UINT_MAX.
We can handle such "big data" without much trouble. Try to do a better job at detecting the rejection cause while here.
MFC
patch(1): extend the maximum length of a line from USHRT_MAX to UINT_MAX.
We can handle such "big data" without much trouble. Try to do a better job at detecting the rejection cause while here.
MFC after: 2 weeks
show more ...
|
|
Revision tags: release/11.0.1, release/11.0.0 |
|
| #
2c4eed47 |
| 24-Apr-2016 |
Pedro F. Giffuni <[email protected]> |
patch(1): avoid signed integer overflow when debugging.
Integer i is used to index p_end of type LINENUM (actually long).
Match the types.
MFC after: 5 days
|
|
Revision tags: release/10.3.0 |
|
| #
463a577b |
| 21-Oct-2015 |
Eitan Adler <[email protected]> |
Fix a ton of speelling errors
arc lint is helpful
Reviewed By: allanjude, wblock, #manpages, [email protected] Differential Revision: https://reviews.freebsd.org/D3337
|
| #
e678759c |
| 15-Aug-2015 |
Xin LI <[email protected]> |
Remove automatic checkout feature.
Obtained from: DragonFly via OpenBSD Relnotes: yes MFC: never
|
|
Revision tags: release/10.2.0 |
|
| #
3fd78bfa |
| 05-Aug-2015 |
Xin LI <[email protected]> |
Fix shell injection vulnerability in patch(1) via ed(1) by tightening sanity check of the input. [1]
While I'm there also replace ed(1) with red(1) because we do not need the unrestricted functional
Fix shell injection vulnerability in patch(1) via ed(1) by tightening sanity check of the input. [1]
While I'm there also replace ed(1) with red(1) because we do not need the unrestricted functionality. [2]
Obtained from: Bitrig [1], DragonFly [2] Security: CVE-2015-1418 [1]
show more ...
|
| #
df6e4074 |
| 20-Apr-2015 |
Pedro F. Giffuni <[email protected]> |
patch(1): small include changes.
Mostly to match OpenBSD, no functional change.
Obtained from: OpenBSD
|
| #
547e0acb |
| 25-Dec-2014 |
Pedro F. Giffuni <[email protected]> |
patch: Bring in xstrdup and use it when appropriate.
The function savestr allows NULL return values during Plan A patching so in case of out of memory conditions, Plan B can step in. In many cases,
patch: Bring in xstrdup and use it when appropriate.
The function savestr allows NULL return values during Plan A patching so in case of out of memory conditions, Plan B can step in. In many cases, NULL value is not properly handled, so use xstrdup here (it's outside Plan A/B patching, which means that even Plan B relies on successful operations).
Clean up some whitespaces while here
Obtained from: OpenBSD MFC after: 2 weeks
show more ...
|
| #
d3fc0cb8 |
| 08-Dec-2014 |
Pedro F. Giffuni <[email protected]> |
patch(1): avoid line number overflows
Introduce strtolinenum to properly check line numbers while parsing: no signs, no spaces, just digits, 0 <= x <= LONG_MAX
Properly validate line ranges supplie
patch(1): avoid line number overflows
Introduce strtolinenum to properly check line numbers while parsing: no signs, no spaces, just digits, 0 <= x <= LONG_MAX
Properly validate line ranges supplied in diff file to prevent overflows. Also fixes an out of boundary memory access because the resulting values are used as array indices.
PR: 195436 Obtained from: OpenBSD (CVS pch.c rev 1.45, 1,46, common.h rev 1.28) MFC after: 1 week
show more ...
|
| #
2b468eba |
| 07-Dec-2014 |
Pedro F. Giffuni <[email protected]> |
Small space changes
Mostly to keep in sync with OpenBSD and update the TAG.
Obtained from: OpenBSD MFC after: 5 days
|
| #
e91a64de |
| 06-Dec-2014 |
Pedro F. Giffuni <[email protected]> |
Merge fixes from OpenBSD.
Check fstat return value. Also, use off_t for file size and offsets. Avoid iterating over end of string.
Obtained from: OpenBSD (CVS rev. 1.41, 1.43) MFC after: 1 week
|
| #
dbfbf4a8 |
| 05-Dec-2014 |
Pedro F. Giffuni <[email protected]> |
Update OpenBSD CVS revision for our r255232.
This is a no-op to make it easier to track changes from OpenBSD
MFC after: 3 days
|
|
Revision tags: release/10.1.0, release/9.3.0 |
|
| #
c1a08643 |
| 15-Jun-2014 |
Pedro F. Giffuni <[email protected]> |
patch: unsign the line length to avoid overflows.
Patch(1) uses a short int for the line length, which is usually sufficient for regular diffs, but makes no effort to signal when there is an overflo
patch: unsign the line length to avoid overflows.
Patch(1) uses a short int for the line length, which is usually sufficient for regular diffs, but makes no effort to signal when there is an overflow.
Change the line length to an unsigned short int to better use the fact that a length is never negative. The change is loosely inspired on a related change in DragonFly, but we avoid spending more memory than necessary.
While here adjust the messages to be clearer on what is happening.
MFC after: 1 week
show more ...
|
| #
c44f94d0 |
| 14-Jun-2014 |
Pedro F. Giffuni <[email protected]> |
patch: cleanup some unnecessary cruft.
- Drop some bogus casts to size_t. - The new_p_foo variables are not needed after r267426.
Pointed out by: bde MFC after: 1 week
|