Wolfgang Denk wrote:
> Dear "Eugene O'Brien",
>
> In message <[EMAIL PROTECTED]> you wrote:
>> @rm -f $(obj)tools/env/{fw_printenv,fw_setenv}
>>
>> The reason is (after scratching my head for a few hours) that on my
>> platform BASH is not the default shell. I am using Ubuntu and /bin/sh is
>> linked to dash (see https://wiki.ubuntu.com/DashAsBinSh for details). As
>> I am not an expert on shells, my guess is that the above construct is a
>> "bashism" and not compliant to /bin/sh.
>
> Good catch...
>
>> There are two trivial solutions to this problem:
>>
>> (a) Add a line SHELL=/bin/bash somewhere in top level Makefile
>> (b) Write out each individual file's path name separately in the @rm
>> command line.
>
> I think the above way to abbreviate long lists of file names that
> have a long common partis pretty useful to keep the code readable, so
> I tend to prefer solution (a).
>
> But let's see what other people say...
I *LIKE* bash, so I too like (a).
Having said that, and with the disclaimer that I'm not sure it is an
improvement, I believe the following line is a "make-ism" equivalent to
the bash-ism (untested):
@rm -f $(foreach file, fw_printenv fw_setenv, $(obj)tools/env/$(file))
> Best regards,
>
> Wolfgang Denk
Ditto,
gvb
_______________________________________________
U-Boot mailing list
[email protected]
http://lists.denx.de/mailman/listinfo/u-boot