* Re: [kbuild patch] mkcompile_h produces warnings when using domain logins [not found] <4D9B63B2.1080701@gmail.com> @ 2011-04-19 8:28 ` Michal Marek 2011-04-19 18:23 ` Marcin Nowakowski 2011-04-25 12:35 ` [PATCH V2] Fix handling of backlash character in LINUX_COMPILE_BY name Marcin Nowakowski 1 sibling, 1 reply; 4+ messages in thread From: Michal Marek @ 2011-04-19 8:28 UTC (permalink / raw) To: Marcin Nowakowski; +Cc: linux-kbuild (CC linux-kbuild, please do not send patches to public projects privately) On 5.4.2011 20:47, Marcin Nowakowski wrote: > Fix handling of backslash character in LINUX_COMPILE_BY name > > When using a domain login, `whoami` returns the login in > user\domain format. This leads to either warnings on unrecognised > escape sequences or escaped characters being generated for the user. > This patch ensures that any backslash is escaped to a double-backslash > to make sure the name is preserved correctly > > Signed-off-by: Marcin Nowakowski <marcin.nowakowski.000@gmail.com> > --- a/scripts/mkcompile_h > +++ b/scripts/mkcompile_h > @@ -64,7 +64,7 @@ > echo \#define UTS_VERSION \"`echo $UTS_VERSION | $UTS_TRUNCATE`\" > > echo \#define LINUX_COMPILE_TIME \"`date +%T`\" > - echo \#define LINUX_COMPILE_BY \"`whoami`\" > + echo \#define LINUX_COMPILE_BY \"`whoami | sed > "s/\\\\\\\\/\\\\\\\\\\\\\\\\/"`\" > echo \#define LINUX_COMPILE_HOST \"`hostname | $UTS_TRUNCATE`\" Such long sequence of backslashes is rather unreadable. The same command is equivalent to sed 's/\\\\/\\\\\\\\/' if you use single quotes, but I wonder why you need to match two backslashes. You say that whoami returns 'user\domain', so the above regexp wouldn't match it. Also, is it necessary to reproduce the full user\domain string in the macro? Or could we cut everything after the backslash, like sed 's/\\.*//' ? BTW, I changed the mkcompile_h script recently, see http://git.kernel.org/?p=linux/kernel/git/mmarek/kbuild-2.6.git;a=blob;f=scripts/mkcompile_h;hb=refs/heads/for-next, could you base any further version on the for-next branch of kbuild.2.6.git or on linux-next? Thanks Michal ^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [kbuild patch] mkcompile_h produces warnings when using domain logins 2011-04-19 8:28 ` [kbuild patch] mkcompile_h produces warnings when using domain logins Michal Marek @ 2011-04-19 18:23 ` Marcin Nowakowski 0 siblings, 0 replies; 4+ messages in thread From: Marcin Nowakowski @ 2011-04-19 18:23 UTC (permalink / raw) To: Michal Marek; +Cc: linux-kbuild On 19/04/11 09:28, Michal Marek wrote: > (CC linux-kbuild, please do not send patches to public projects privately) > > On 5.4.2011 20:47, Marcin Nowakowski wrote: >> Fix handling of backslash character in LINUX_COMPILE_BY name >> >> When using a domain login, `whoami` returns the login in >> user\domain format. This leads to either warnings on unrecognised >> escape sequences or escaped characters being generated for the user. >> This patch ensures that any backslash is escaped to a double-backslash >> to make sure the name is preserved correctly >> >> Signed-off-by: Marcin Nowakowski<marcin.nowakowski.000@gmail.com> >> --- a/scripts/mkcompile_h >> +++ b/scripts/mkcompile_h >> @@ -64,7 +64,7 @@ >> echo \#define UTS_VERSION \"`echo $UTS_VERSION | $UTS_TRUNCATE`\" >> >> echo \#define LINUX_COMPILE_TIME \"`date +%T`\" >> - echo \#define LINUX_COMPILE_BY \"`whoami`\" >> + echo \#define LINUX_COMPILE_BY \"`whoami | sed >> "s/\\\\\\\\/\\\\\\\\\\\\\\\\/"`\" >> echo \#define LINUX_COMPILE_HOST \"`hostname | $UTS_TRUNCATE`\" > > Such long sequence of backslashes is rather unreadable. The same command > is equivalent to > > sed 's/\\\\/\\\\\\\\/' > > if you use single quotes, but I wonder why you need to match two > backslashes. You say that whoami returns 'user\domain', so the above > regexp wouldn't match it. The problem in this case is that when using back-quotes for command substitution, backslashes are escaped so we need the extra layer of escaping. However - having looked again at the bash documentation, I've found that if $(...) syntax is used instead of `...` then backslashes are treated literally. That, with addition of single quotes as you had suggested should allow a simple echo \#define LINUX_COMPILE_BY \"$(whoami | sed 's/\\/\\\\/g')\" instead of the rather unreadable solution I initially suggested. > Also, is it necessary to reproduce the full > user\domain string in the macro? Or could we cut everything after the > backslash, like > > sed 's/\\.*//' > > ? BTW, I changed the mkcompile_h script recently, see > http://git.kernel.org/?p=linux/kernel/git/mmarek/kbuild-2.6.git;a=blob;f=scripts/mkcompile_h;hb=refs/heads/for-next, > could you base any further version on the for-next branch of > kbuild.2.6.git or on linux-next? I'll re-send a new patched based on this tree and with the cleanup as described above thanks Marcin ^ permalink raw reply [flat|nested] 4+ messages in thread
* [PATCH V2] Fix handling of backlash character in LINUX_COMPILE_BY name [not found] <4D9B63B2.1080701@gmail.com> 2011-04-19 8:28 ` [kbuild patch] mkcompile_h produces warnings when using domain logins Michal Marek @ 2011-04-25 12:35 ` Marcin Nowakowski 2011-04-29 13:57 ` Michal Marek 1 sibling, 1 reply; 4+ messages in thread From: Marcin Nowakowski @ 2011-04-25 12:35 UTC (permalink / raw) To: linux-kbuild When using a domain login, `whoami` returns the login in user\domain format. This leads to either warnings on unrecognised escape sequences or escaped characters being generated for the user. This patch ensures that any backslash is escaped to a double-backslash to make sure the name is preserved correctly. This patch does not enforce escaping on the KBUILD_BUILD_USER variable, as this is something the user has control of and can escape if required. V2 simplifies a very complex escape pattern introduced initially. Signed-off-by: Marcin Nowakowski <marcin.nowakowski.000@gmail.com> diff --git a/scripts/mkcompile_h b/scripts/mkcompile_h index 7ad6bf7..f221ddf 100755 --- a/scripts/mkcompile_h +++ b/scripts/mkcompile_h @@ -43,7 +43,7 @@ else TIMESTAMP=$KBUILD_BUILD_TIMESTAMP fi if test -z "$KBUILD_BUILD_USER"; then - LINUX_COMPILE_BY=`whoami` + LINUX_COMPILE_BY=$(whoami | sed 's/\\/\\\\/') else LINUX_COMPILE_BY=$KBUILD_BUILD_USER fi ^ permalink raw reply related [flat|nested] 4+ messages in thread
* Re: [PATCH V2] Fix handling of backlash character in LINUX_COMPILE_BY name 2011-04-25 12:35 ` [PATCH V2] Fix handling of backlash character in LINUX_COMPILE_BY name Marcin Nowakowski @ 2011-04-29 13:57 ` Michal Marek 0 siblings, 0 replies; 4+ messages in thread From: Michal Marek @ 2011-04-29 13:57 UTC (permalink / raw) To: Marcin Nowakowski; +Cc: linux-kbuild On Mon, Apr 25, 2011 at 01:35:21PM +0100, Marcin Nowakowski wrote: > When using a domain login, `whoami` returns the login in > user\domain format. This leads to either warnings on unrecognised > escape sequences or escaped characters being generated for the user. > This patch ensures that any backslash is escaped to a double-backslash > to make sure the name is preserved correctly. This patch does not > enforce escaping on the KBUILD_BUILD_USER variable, as this is something > the user has control of and can escape if required. > V2 simplifies a very complex escape pattern introduced initially. Thanks, this is much more readable :). Applied to kbuild-2.6.git#kbuild. Michal ^ permalink raw reply [flat|nested] 4+ messages in thread
end of thread, other threads:[~2011-04-29 13:57 UTC | newest]
Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
[not found] <4D9B63B2.1080701@gmail.com>
2011-04-19 8:28 ` [kbuild patch] mkcompile_h produces warnings when using domain logins Michal Marek
2011-04-19 18:23 ` Marcin Nowakowski
2011-04-25 12:35 ` [PATCH V2] Fix handling of backlash character in LINUX_COMPILE_BY name Marcin Nowakowski
2011-04-29 13:57 ` Michal Marek
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox