Page MenuHomeFreeBSD

rc.subr(8): Set procname to command by default to match documentation
Changes PlannedPublic

Authored by 0mp on Aug 28 2019, 8:18 AM.
Tags
Referenced Files
Unknown Object (File)
Fri, Jan 10, 11:37 AM
Unknown Object (File)
Nov 25 2024, 10:04 PM
Unknown Object (File)
Nov 21 2024, 5:53 AM
Unknown Object (File)
Nov 20 2024, 2:45 PM
Unknown Object (File)
Nov 5 2024, 12:05 AM
Unknown Object (File)
Oct 16 2024, 2:46 PM
Unknown Object (File)
Oct 14 2024, 7:19 PM
Unknown Object (File)
Oct 11 2024, 10:47 AM

Details

Reviewers
jilles
Summary
rc.subr(8): Set procname to command by default to match documentation

The rc.subr(8) manual reads that variable procname defaults to the value of
command. However, procname is never set to any value in the run_rc_command.
This patch sets procname to the value of command if procname is unset or empty.
As a result it is going to be possible to use the procname variable in
*cmd functions (e.g., start_cmd).

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 26158
Build 24673: arc lint + arc unit

Event Timeline

Inline.

libexec/rc/rc.subr
951

I think this is way too subtle.

How about we do away with $_procname and just set:

: ${procname:=${command}}

and use $procname directly in rc.subr?

Answer inline

libexec/rc/rc.subr
951

Good idea. But as I was preparing the patch, I realized that it is not so starightforward.

Look at the lines 953-960: when procname is set, we start supporting two more keywords: status and poll. It seems that nothing is broken by this, however.

Get rid of _procname entirely. Just use procname in the whole run_rc_command.

In D21450#466883, @0mp wrote:

Get rid of _procname entirely. Just use procname in the whole run_rc_command.

Remember that _procname is global if it's not declared local in the function. Have you ensured that this setting of _procname isn't relied-on by whatever calls this function?

In D21450#466887, @ian wrote:
In D21450#466883, @0mp wrote:

Get rid of _procname entirely. Just use procname in the whole run_rc_command.

Remember that _procname is global if it's not declared local in the function. Have you ensured that this setting of _procname isn't relied-on by whatever calls this function?

Yes, I confirm that _procname is not used anywhere in src/libexec/rc.

It used as a local variable (although it is never declared local) in some rc.subr functions but it is always assigned a value (so it never depends on the value that could be passed over by the caller).

0mp marked an inline comment as done.Aug 29 2019, 7:59 AM

This needs some heavy testing, for which I'm afraid I just don't have the capacity for at the moment. I've been bitten quite hard recently by a 'simple' rc change recently so I'm reluctant to put my stamp on it!

It also needs approval from a src developer- perhaps try asking on -rc? Male sure you detail the testing done.

Sorry.

This needs some heavy testing, for which I'm afraid I just don't have the capacity for at the moment. I've been bitten quite hard recently by a 'simple' rc change recently so I'm reluctant to put my stamp on it!

It also needs approval from a src developer- perhaps try asking on -rc? Male sure you detail the testing done.

Sorry.

Nah, no need to say sorry! It's a great idea! Thank you for all the input. I'll do some more testing and post it to -rc@ when ready

Cheers! :)

0mp planned changes to this revision.Jun 11 2020, 9:47 AM