Edit

kc3-lang/automake/lib/Automake/Options.pm

Branch :

  • Show log

    Commit

  • Author : Tom Tromey
    Date : 2003-09-30 19:05:54
    Hash : 8735ca14
    Message : * lib/Automake/Options.pm (_process_option_list): Recognize no-dist. * NEWS: Update. * doc/automake.texi (Options): Document no-dist. * automake.in (check_cygnus): Set no-dist option. (handle_dist): Recognize no-dist. * tests/nodist3.test: New file. * tests/Makefile.am (TESTS): Added nodist3.test.

  • lib/Automake/Options.pm
  • # Copyright (C) 2003  Free Software Foundation, Inc.
    
    # This program is free software; you can redistribute it and/or modify
    # it under the terms of the GNU General Public License as published by
    # the Free Software Foundation; either version 2, or (at your option)
    # any later version.
    
    # This program is distributed in the hope that it will be useful,
    # but WITHOUT ANY WARRANTY; without even the implied warranty of
    # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    # GNU General Public License for more details.
    
    # You should have received a copy of the GNU General Public License
    # along with this program; if not, write to the Free Software
    # Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
    # 02111-1307, USA.
    
    package Automake::Options;
    
    use strict;
    use Exporter;
    use Automake::Config;
    use Automake::ChannelDefs;
    use Automake::Channels;
    use Automake::Version;
    
    use vars qw (@ISA @EXPORT);
    
    @ISA = qw (Exporter);
    @EXPORT = qw (option global_option
    	      set_option set_global_option
    	      unset_option unset_global_option
    	      process_option_list process_global_option_list
    	      set_strictness $strictness $strictness_name
    	      &FOREIGN &GNU &GNITS);
    
    =head1 NAME
    
    Automake::Options - keep track of Automake options
    
    =head1 SYNOPSIS
    
      use Automake::Options;
    
      # Option lookup and setting.
      $opt = option 'name';
      $opt = global_option 'name';
      set_option 'name', 'value';
      set_global_option 'name', 'value';
      unset_option 'name';
      unset_global_option 'name';
    
      # Batch option setting.
      process_option_list $location, @names;
      process_global_option_list $location, @names;
    
      # Strictness lookup and setting.
      set_strictness 'foreign';
      set_strictness 'gnu';
      set_strictness 'gnits';
      if ($strictness >= GNU) { ... }
      print "$strictness_name\n";
    
    =head1 DESCRIPTION
    
    This packages manages Automake's options and strictness settings.
    Options can be either local or global.  Local options are set using an
    C<AUTOMAKE_OPTIONS> variable in a F<Makefile.am> and apply only to
    this F<Makefile.am>.  Global options are set from the command line or
    passed as an argument to C<AM_INIT_AUTOMAKE>, they apply to all
    F<Makefile.am>s.
    
    =cut
    
    # Values are the Automake::Location of the definition, except
    # for 'ansi2knr' whose value is a pair [filename, Location].
    use vars '%_options';		# From AUTOMAKE_OPTIONS
    use vars '%_global_options';	# from AM_INIT_AUTOMAKE or the command line.
    
    =head2 Constants
    
    =over 4
    
    =item FOREIGN
    
    =item GNU
    
    =item GNITS
    
    Strictness constants used as values for C<$strictness>.
    
    =back
    
    =cut
    
    # Constants to define the "strictness" level.
    use constant FOREIGN => 0;
    use constant GNU     => 1;
    use constant GNITS   => 2;
    
    =head2 Variables
    
    =over 4
    
    =item C<$strictness>
    
    The current stricness.  One of C<FOREIGN>, C<GNU>, or C<GNITS>.
    
    =item C<$strictness_name>
    
    The current stricness name.  One of C<'foreign'>, C<'gnu'>, or C<'gnits'>.
    
    =back
    
    =cut
    
    # Strictness levels.
    use vars qw ($strictness $strictness_name);
    
    # Strictness level as set on command line.
    use vars qw ($_default_strictness $_default_strictness_name);
    
    
    =head2 Functions
    
    =over 4
    
    =item C<Automake::Options::reset>
    
    Reset the options variables for the next F<Makefile.am>.
    
    In other words, this gets rid of all local options in use by the
    previous F<Makefile.am>.
    
    =cut
    
    sub reset ()
    {
      %_options = %_global_options;
      # The first time we are run,
      # remember the current setting as the default.
      if (defined $_default_strictness)
        {
          $strictness = $_default_strictness;
          $strictness_name = $_default_strictness_name;
        }
      else
        {
          $_default_strictness = $strictness;
          $_default_strictness_name = $strictness_name;
        }
    }
    
    =item C<$value = option ($name)>
    
    =item C<$value = global_option ($name)>
    
    Query the state of an option.  If the option is unset, this
    returns the empty list.  Otherwise it returns the option's value,
    as set by C<set_option> or C<set_global_option>.
    
    Not that C<global_option> should be used only when it is
    important to make sure an option hasn't been set locally.
    Otherwise C<option> should be the standard function to
    check for options (be they global or local).
    
    =cut
    
    sub option ($)
    {
      my ($name) = @_;
      return () unless defined $_options{$name};
      return $_options{$name};
    }
    
    sub global_option ($)
    {
      my ($name) = @_;
      return () unless defined $_global_options{$name};
      return $_global_options{$name};
    }
    
    =item C<set_option ($name, $value)>
    
    =item C<set_global_option ($name, $value)>
    
    Set an option.  By convention, C<$value> is usually the location
    of the option definition.
    
    =cut
    
    sub set_option ($$)
    {
      my ($name, $value) = @_;
      $_options{$name} = $value;
    }
    
    sub set_global_option ($$)
    {
      my ($name, $value) = @_;
      $_global_options{$name} = $value;
    }
    
    
    =item C<unset_option ($name)>
    
    =item C<unset_global_option ($name)>
    
    Unset an option.
    
    =cut
    
    sub unset_option ($)
    {
      my ($name) = @_;
      delete $_options{$name};
    }
    
    sub unset_global_option ($)
    {
      my ($name) = @_;
      delete $_global_options{$name};
    }
    
    
    =item C<process_option_list ($where, @options)>
    
    =item C<process_global_option_list ($where, @options)>
    
    Process Automake's option lists.  C<@options> should be a list of
    words, as they occur in C<AUTOMAKE_OPTIONS> or C<AM_INIT_AUTOMAKE>.
    
    Return 1 on error, 0 otherwise.
    
    =cut
    
    # $BOOL
    # _process_option_list (\%OPTIONS, $WHERE, @OPTIONS)
    # -------------------------------------------------
    # Process a list of options.  Return 1 on error, 0 otherwise.
    # \%OPTIONS is the hash to fill with options data, $WHERE is
    # the location where @OPTIONS occured.
    sub _process_option_list (\%$@)
    {
      my ($options, $where, @list) = @_;
    
      foreach (@list)
        {
          $options->{$_} = $where;
          if ($_ eq 'gnits' || $_ eq 'gnu' || $_ eq 'foreign')
    	{
    	  set_strictness ($_);
    	}
          elsif (/^(.*\/)?ansi2knr$/)
    	{
    	  # An option like "../lib/ansi2knr" is allowed.  With no
    	  # path prefix, we assume the required programs are in this
    	  # directory.  We save the actual option for later.
    	  $options->{'ansi2knr'} = [$_, $where];
    	}
          elsif ($_ eq 'no-installman' || $_ eq 'no-installinfo'
    	     || $_ eq 'dist-shar' || $_ eq 'dist-zip'
    	     || $_ eq 'dist-tarZ' || $_ eq 'dist-bzip2'
    	     || $_ eq 'no-dist-gzip' || $_ eq 'no-dist'
    	     || $_ eq 'dejagnu' || $_ eq 'no-texinfo.tex'
    	     || $_ eq 'readme-alpha' || $_ eq 'check-news'
    	     || $_ eq 'subdir-objects' || $_ eq 'nostdinc'
    	     || $_ eq 'no-exeext' || $_ eq 'no-define'
    	     || $_ eq 'std-options'
    	     || $_ eq 'cygnus' || $_ eq 'no-dependencies')
    	{
    	  # Explicitly recognize these.
    	}
          elsif (/^\d+\.\d+(?:\.\d+)?[a-z]?(?:-[A-Za-z0-9]+)?$/)
    	{
    	  # Got a version number.
    	  if (Automake::Version::check ($VERSION, $&))
    	    {
    	      error ($where, "require Automake $_, but have $VERSION",
    		     uniq_scope => US_GLOBAL);
    	      return 1;
    	    }
    	}
          elsif (/^(?:--warnings=|-W)(.*)$/)
    	{
    	  foreach my $cat (split (',', $1))
    	    {
    	      msg 'unsupported', $where, "unknown warning category `$cat'"
    		if switch_warning $cat;
    	    }
    	}
          else
    	{
    	  error ($where, "option `$_' not recognized",
    		 uniq_scope => US_GLOBAL);
    	  return 1;
    	}
        }
      return 0;
    }
    
    sub process_option_list ($@)
    {
      my ($where, @list) = @_;
      return _process_option_list (%_options, $where, @list);
    }
    
    sub process_global_option_list ($@)
    {
      my ($where, @list) = @_;
      return _process_option_list (%_global_options, $where, @list);
    }
    
    =item C<set_strictness ($name)>
    
    Set the current strictness level.
    C<$name> should be one of C<'foreign'>, C<'gnu'>, or C<'gnits'>.
    
    =cut
    
    # Set strictness.
    sub set_strictness ($)
    {
      $strictness_name = $_[0];
    
      Automake::ChannelDefs::set_strictness ($strictness_name);
    
      if ($strictness_name eq 'gnu')
        {
          $strictness = GNU;
        }
      elsif ($strictness_name eq 'gnits')
        {
          $strictness = GNITS;
        }
      elsif ($strictness_name eq 'foreign')
        {
          $strictness = FOREIGN;
        }
      else
        {
          prog_error "level `$strictness_name' not recognized\n";
        }
    }
    
    1;
    
    ### Setup "GNU" style for perl-mode and cperl-mode.
    ## Local Variables:
    ## perl-indent-level: 2
    ## perl-continued-statement-offset: 2
    ## perl-continued-brace-offset: 0
    ## perl-brace-offset: 0
    ## perl-brace-imaginary-offset: 0
    ## perl-label-offset: -2
    ## cperl-indent-level: 2
    ## cperl-brace-offset: 0
    ## cperl-continued-brace-offset: 0
    ## cperl-label-offset: -2
    ## cperl-extra-newline-before-brace: t
    ## cperl-merge-trailing-else: nil
    ## cperl-continued-statement-offset: 2
    ## End: