NAME
    Module::CPANfile - Parse cpanfile

SYNOPSIS
      use Module::CPANfile;

      my $file = Module::CPANfile->load("cpanfile");
      my $prereqs = $file->prereqs; # CPAN::Meta::Prereqs object

      my @features = $file->features; # CPAN::Meta::Feature objects
      my $merged_prereqs = $file->prereqs_with(@identifiers); # CPAN::Meta::Prereqs

      $file->merge_meta('MYMETA.json');

DESCRIPTION
    Module::CPANfile is a tool to handle cpanfile format to load application
    specific dependencies, not just for CPAN distributions.

METHODS
    load
          $file = Module::CPANfile->load;
          $file = Module::CPANfile->load('cpanfile');

        Load and parse a cpanfile. By default it tries to load "cpanfile" in
        the current directory, unless you pass the path to its argument.

    from_prereqs
          $file = Module::CPANfile->from_prereqs({
            runtime => { requires => { DBI => '1.000' } },
          });

        Creates a new Module::CPANfile object from prereqs hash you can get
        via CPAN::Meta's "prereqs", or CPAN::Meta::Prereqs'
        "as_string_hash".

          # read MYMETA, then feed the prereqs to create Module::CPANfile
          my $meta = CPAN::Meta->load_file('MYMETA.json');
          my $file = Module::CPANfile->from_prereqs($meta->prereqs);

          # load cpanfile, then recreate it with round-trip
          my $file = Module::CPANfile->load('cpanfile');
          $file = Module::CPANfile->from_prereqs($file->prereq_specs);
                                            # or $file->prereqs->as_string_hash

    prereqs
        Returns CPAN::Meta::Prereqs object out of the parsed cpanfile.

    prereq_specs
        Returns a hash reference that should be passed to
        "CPAN::Meta::Prereqs->new".

    features
        Returns a list of features available in the cpanfile as
        CPAN::Meta::Feature.

    prereqs_with(@identifiers), effective_prereqs(\@identifiers)
        Returns CPAN::Meta::Prereqs object, with merged prereqs for features
        identified with the @identifiers.

    to_string($include_empty)
          $file->to_string;
          $file->to_string(1);

        Returns a canonical string (code) representation for cpanfile.
        Useful if you want to convert CPAN::Meta::Prereqs to a new cpanfile.

          # read MYMETA's prereqs and print cpanfile representation of it
          my $meta = CPAN::Meta->load_file('MYMETA.json');
          my $file = Module::CPANfile->from_prereqs($meta->prereqs);
          print $file->to_string;

        By default, it omits the phase where there're no modules registered.
        If you pass the argument of a true value, it will print them as
        well.

    save
          $file->save('cpanfile');

        Saves the currently loaded prereqs as a new "cpanfile" by calling
        "to_string". Beware this method will overwrite the existing cpanfile
        without any warning or backup. Taking a backup or giving warnings to
        users is a caller's responsibility.

          # Read MYMETA.json and creates a new cpanfile
          my $meta = CPAN::Meta->load_file('MYMETA.json');
          my $file = Module::CPANfile->from_prereqs($meta->prereqs);
          $file->save('cpanfile');

    merge_meta
          $file->merge_meta('META.yml');
          $file->merge_meta('MYMETA.json', '2.0');

        Merge the effective prereqs with Meta specification loaded from the
        given META file, using CPAN::Meta. You can specify the META spec
        version in the second argument, which defaults to 1.4 in case the
        given file is YAML, and 2 if it is JSON.

AUTHOR
    Tatsuhiko Miyagawa

SEE ALSO
    cpanfile, CPAN::Meta, CPAN::Meta::Spec