[Rd] (PR#9915) *.Rd file: space after topic in "\alias{topic }"

ripley at stats.ox.ac.uk ripley at stats.ox.ac.uk
Tue Sep 18 10:42:37 CEST 2007


Spaces are indeed significant in \alias, and the treatment of leading and 
trailing spaces seems undocumented.  (Four CRAN package authors have made 
assumptions here.)

As far as I can see this comes up in 3 places:

1) Writing AnIndex strips leading but not trailing spaces.
2) get_multi used to create @aliases strips both.
3) Looking up aliases in \link happens at both compile and (for [C]HTML) 
run times, and it seems never strips spaces.

I think it would have been better to leave spaces alone, but I propose to 
consistently strip leading and trailing spaces in aliases and not links, 
and to document that.

On Mon, 17 Sep 2007, bill at insightful.com wrote:

> On Mon, 17 Sep 2007 bill at insightful.com wrote:
>
>> Full_Name: Bill Dunlap
>> Version: R version 2.6.0 Under development (unstable) (2007-07-26 r42329)
>> OS: Linux
>> Submission from: (NULL) (24.16.101.199)
>>
>> If a *.Rd file has an \alias{topic } with a space
>> between 'topic' and the closing '}' then the space
>> is copied to the help/AnIndex file and help(topic)
>> fails to find the help file.
>>
>> E.g., if the help file starts with
>>    \name{test1}
>>    \alias{test1 }
>>    \alias{test2}
>>    \alias{test3 }
>>    \alias{test4}
>> then help(test1) and help(test4) work, but not
>> help(test1) or help(test3).
>>
>> A possible fix is
>> --- share/perl/R/Rdlists.pm     (revision 42846)
>> +++ share/perl/R/Rdlists.pm     (working copy)
>> @@ -329,7 +329,7 @@
>>                 $main::title2file{$rdtitle} = $manfilebase;
>>             }
>>
>> -           while($text =~ s/\\alias\{\s*(.*)\s*\}//){
>> +           while($text =~ s/\\alias\{\s*([^\s]*)\s*\}//){
>>                 $alias = $1;
>>                 $alias =~ s/\\%/%/g;
>>                 if ($internal){
>
> It looks like internal spaces are used in \alias entries,
> e.g.,
>  ./R.utils/man/Non-documented_objects.Rd:\alias{Non-documented objects}
>  ./SparseM/man/character-null-class.Rd:\alias{character or NULL-class}
> I think the trailing spaces are intended to be ignored,
> so a better fix would be
>
> --- Rdlists.pm  (revision 42846)
> +++ Rdlists.pm  (working copy)
> @@ -332,6 +332,7 @@
>            while($text =~ s/\\alias\{\s*(.*)\s*\}//){
>                $alias = $1;
>                $alias =~ s/\\%/%/g;
> +               $alias =~ s/\s*$//;
>                if ($internal){
>                    $internal{$alias} = 1;
>                }
>
>
>
> ----------------------------------------------------------------------------
> Bill Dunlap
> Insightful Corporation
> bill at insightful dot com
> 360-428-8146
>
> "All statements in this message represent the opinions of the author and do
> not necessarily reflect Insightful Corporation policy or position."
>
> ______________________________________________
> R-devel at r-project.org mailing list
> https://stat.ethz.ch/mailman/listinfo/r-devel
>

-- 
Brian D. Ripley,                  ripley at stats.ox.ac.uk
Professor of Applied Statistics,  http://www.stats.ox.ac.uk/~ripley/
University of Oxford,             Tel:  +44 1865 272861 (self)
1 South Parks Road,                     +44 1865 272866 (PA)
Oxford OX1 3TG, UK                Fax:  +44 1865 272595



More information about the R-devel mailing list