NAME

App::Virtualenv - Perl virtual environment

VERSION

version 2.03

ABSTRACT

Perl virtual environment

#!/bin/sh
perl -MApp::Virtualenv -erun -- environment_path

See also: virtualenv.pl

DESCRIPTION

App::Virtualenv is a Perl package to create isolated Perl virtual environments, like Python virtual environment.

Functions

sh(@args)

runs shell program defined in SHELL environment variable, otherwise /bin/sh

@args: arguments of shell program

return value: exit code of shell program

perl(@args)

runs Perl interpreter

@args: arguments of Perl interpreter

return value: exit code of Perl interpreter

activate($virtualenvPath)

activates Perl virtual environment

$virtualenvPath: virtual environment path

return value: virtual environment path if success, otherwise undef

deactivate($nondestructive)

deactivates Perl virtual environment

$nondestructive: leaves envionment variables as it is, unless there are old envionment variables

return value: always 1

create($virtualenvPath, $empty)

creates Perl virtual environment

$virtualenvPath: new virtual environment path

$empty: create empty virtual environment

return value: virtual environment path if success, otherwise undef

findVirtualenvPath($virtualenvPath)

finds Perl virtual environment path by $virtualenvPath argument or activated virtual environment or running script or PERL5LIB environment variable

$virtualenvPath: virtual environment path

return value: best matching virtual environment path

activate2($virtualenvPath, $inform)

activates Perl virtual environment by findVirtualenvPath function

$virtualenvPath: virtual environment path

$inform: informs activated virtual environment path to STDERR if new activated path differs old one

return value: activated best matching virtual environment path if success, otherwise undef

getInc($virtualenvPath)

gets array ref of include paths given virtual environment path or sitelib paths

$virtualenvPath: virtual environment path

return value: array ref of paths

list(%params)

lists packages or modules or files by given %params

%params: parameters of function

    one: output is one-column, by default 0

    detail: prints additional detail by given value: module or file. by default undef

return value: always 1

main(@argv)

App::Virtualenv main function to run on command-line

See also: virtualenv.pl

@argv: command-line arguments

return value: exit code of program

run

runs App::Virtualenv by main function with command-line arguments by @ARGV

return value: function doesn't return, exits with main function return code

PREVIOUS VERSION

Previous version of App::Virtualenv has include PiV(Perl in Virtual environment) to list/install/uninstall modules using CPANPLUS API. Aimed with PiV making a package manager like Python pip. But Perl has various powerful package tools mainly CPAN and cpanminus, CPANPLUS and etc. And also building a great package manager requires huge community support. So, PiV is deprecated in version 2.xx.

You should uninstall previous version before upgrading from v1.xx: cpanm -U App::Virtualenv; cpanm -i App::Virtualenv;

See also: App::Virtualenv 1.13

Deprecated Modules

  • App::Virtualenv::Piv

  • App::Virtualenv::Module

  • App::Virtualenv::Utils

INSTALLATION

To install this module type the following

perl Makefile.PL
make
make test
make install

from CPAN

cpan -i App::Virtualenv

You should uninstall previous version before upgrading from v1.xx: cpanm -U App::Virtualenv; cpanm -i App::Virtualenv;

DEPENDENCIES

This module requires these other modules and libraries:

  • local::lib

  • ExtUtils::Installed

  • CPAN

  • Cwd

  • Lazy::Utils

REPOSITORY

GitHub https://github.com/orkunkaraduman/perl5-virtualenv

CPAN https://metacpan.org/release/App-Virtualenv

SEE ALSO

AUTHOR

Orkun Karaduman <orkunkaraduman@gmail.com>

COPYRIGHT AND LICENSE

Copyright (C) 2017 Orkun Karaduman <orkunkaraduman@gmail.com>

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 3 of the License, 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, see <http://www.gnu.org/licenses/>.