NAME

Devel::PerlySense::Project - A Project root

SYNOPSIS

DESCRIPTION

A Project describes the root directory of a source tree.

A Project has configuration settings.

PROPERTIES

dirProject

The effective project root dir.

Readonly.

dirProjectExplicitDir

If known, the root dir made explicit by the existence of a project directory and config, else ""

Default: ""

dirProjectImplicitUse

If known, the root dir indicated by a found used module, else "".

Default: ""

dirProjectImplicitDir

If known, the root dir indicated by the presence of "lib" or "t", else "".

Default: ""

oConfig

A Config::Project object with the current Project Config. This gets loaded if there is a config file available when the Project is identified.

Default: An Config::Project::Default object

rhConfig

The actual hashref with config values.

Readonly (that includes the entire data structure).

oPerlySense

Devel::PerlySense object.

nameVcs

The name of the Version Control system for the project.

Readonly. Currently supported:

svn
none

CLASS METHODS

newFromLocation(file => $file, dir => $dir, oPerlySense => $oPs)

Create new Project given either $file, or $dir.

First, search for an explicit project root directory, then try to find any modules used in $file (if passed), then try to find any "lib" or "t" directory upwards of $file or $dir.

$file takes precedence over $dir if both are specified.

If none if this works out, no Project can be created and undef is returned.

Return the new object, or undef if no project could be found.

newFindExplicit(dir => $dir, oPerlySense => $oPs)

Create new Project if there is an explicit .PerlySenseProject directory in the path above $dir.

Return the new object, or undef if no project could be found.

MEHTODS

rhRunFile(file => $fileSource, [rhConfigType = DEDUCED_FROM_FILE])

Figure out what type of source file $fileSource is, and how it should be run.

The settings in the global config->{run_file} is used to determine the details.

Return hash ref with (keys: "dir_run_from", "command_run", "type_source_file"), or die on errors (like if no Project could be found).

dir_run_from is an absolute file name which should be the cwd when command_run is executed.

type_source_file is something like "Test", "Module".

rhConfigTypeForFile(file => $fileSource)

Return the config type hash ref (keys: command, moniker) from the ones available in the config. Match the $fileSource name against each rex in the config.

Die if no configType could be identified.

aDirIncProject(dirRelativeTo => $dirRelativeTo)

Return array with dir objects which are the inc_dir directories in the config, plus the usual inc directories. They are all relative to $dirRelativeTo.

isFileInProject(file => $file)

Return true if $file is within the project root, or in any of the INC directories, else false. Die on errors.

Test logically/structurally, not whether the file actually exists.

flymakeFile(file => $fileSource)

Do a flymake run with $fileSource according to the flymake config and output the result to STDOUT and STDERR.

Return 1 or die on errors (but that will look like the result of a failed flymake run).

raFileTestOther(file => $fileSource)

Return array ref with file names of files related to $file, i.e. the "other" files related $file.

If $file is a source file, return test files, and vice verca.

Die if Devel::CoverX::Covered isn't installed.

AUTHOR

Johan Lindström, <johanl[ÄT]DarSerMan.com>

BUGS

Please report any bugs or feature requests to bug-devel-perlysense@rt.cpan.org, or through the web interface at http://rt.cpan.org/NoAuth/ReportBug.html?Queue=Devel-PerlySense. I will be notified, and then you'll automatically be notified of progress on your bug as I make changes.

ACKNOWLEDGEMENTS

COPYRIGHT & LICENSE

Copyright 2005 Johan Lindström, All Rights Reserved.

This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.

1 POD Error

The following errors were encountered while parsing the POD:

Around line 542:

Non-ASCII character seen before =encoding in 'Lindström,'. Assuming CP1252