Firstly, as with all bulk search and replace tasks, be sure you have backed up the files so you have something to fall back on in case this doesn't work.
Then, on the command line, try:
$ sed -i '$s/\([[:blank:]]\)*?>\([[:blank:]]\)*$//g' "$(grep -rl '^\([[:blank:]]\)*?>\([[:blank:]]\)*$')"
- uses command substitution
$()
containing a grep command
- grep
-r
to recursively find files. If your directory has mixed in non-PHP files and takes too long, we can work in a find
, however for now try this
- grep
-l
to just list, don't show the match, thus pass file names to sed
command
-
[:blank:]
is a POSIX character class to match space or tabs.
- so the grep matches for a line beginning with space or tab for zero+ characters, the
?>
, followed by space or tab zero+ characters, then end of line.
- this is to deal with edge cases where the code does not end as expected with just
?>
but for whatever odd reason you happen to have extra white spaces before and after the ?>
- this grep alone will also include unwanted results where you happen to have
?>
on its own line in the middle of the PHP script, so to focus only on end-of-file, last line, we have the sed
-
-i
replaces in place. Could also have used -i.bak
to automatically have sed create a *.bak
file backup, but I prefer not to clutter the web server with *.bak
files, and if you followed my recommendation to backup prior to this, you already have a backup and won't need this
- the sed command starting with
$
specifies the address is the last line
- then the action to take part on that address is a replacement similar to what grep was looking for
- the sed acts via a replacement, so will still leave a blank line, which at least ensures conformity with PSR-2
All PHP files MUST end with a single blank line.
requirement
- if you aren't getting any fixes at all, it could be DOS vs Linux line ending issues preventing grep from working, in which you may need to use
dos2unix
on the PHP files and then re-try this command
The result is the successful elimination of last line ?>
, even if there were extra "unclean" spaces before or after ?>
.