NAME
Enbld - Build your development environment by perl-based DSL.
SYNOPSIS
#!/usr/bin/perl
use 5.012;
use warnings;
use utf8;
use lib "$ENV{HOME}/.enbld/extlib/lib/perl5/";
use Enbld;
enbld 'myenv' => build {
# install latest version
target 'git' => define {
version 'latest';
};
# install specific version
target 'tmux' => define {
version '1.8';
};
# install software and set configuration file
target 'vim' => define {
version 'latest';
};
conf '.vimrc' => load {
from 'https://raw.github.com/magnolia-k/vimrc/master/.vimrc';
};
};
DESCRIPTION
Enbld is a tool for building development environment.
Write installation conditions (a version - latest or specific version number, the execution of a test code, configuration file etc.) of target software in perl-based DSL,then download of a source code, building, and installation will be performed altogether automatically.
If DSL is performed once again when the software of a later more high version is released, the latest version will be installed automatically.
FEATURES
Configuration file which described installation conditions is defined by perl-based DSL.
Once it writes a configuration file, same environment is easily reproducible .
Arbitrary versions are installable.
If it is specified as 'latest', the latest version will be judged automatically and it will be installed.
The version will be installed if arbitrary versions are specified.
Like other package management systems (Homebrew, MacPorts etc.), the package managerial system side does not specify a version.
It can be confirmed whether a version higher than the version installed is released.
The software (vim, git, etc.) upgraded frequently can also always use the latest version.
All software is installed in a home directory.
Software which became unnecessary can be deleted easily.
Supported software
Now, Enbld supports for installation below software.
apache http://httpd.apache.org
apr http://apr.apache.org
aprutil http://apr.apache.org
autoconf http://www.gnu.org/software/autoconf/
automake http://www.gnu.org/software/automake/
cmake http://www.cmake.org
emacs http://www.gnu.org/software/emacs/
git http://git-scm.com
groff http://www.gnu.org/software/groff/
hello http://www.gnu.org/software/hello/
libevent http://libevent.org
libidn http://www.gnu.org/software/libidn/
libtool http://www.gnu.org/software/libtool/
mysql http://www.mysql.com
nginx http://nginx.org
nodejs http://nodejs.org
pcre http://www.pcre.org
perl http://www.perl.org
pkgconfig http://www.freedesktop.org/wiki/Software/pkg-config/
python http://www.python.org
rakudostar http://rakudo.org
ruby https://www.ruby-lang.org
scala http://www.cmake.org
tmux http://tmux.sourceforge.net
tree http://mama.indstate.edu/users/ice/tree/
vim http://www.vim.org
wget http://www.gnu.org/software/wget/
zsh http://www.zsh.org
ANTI-FEATURES
Enbld does NOT aim at perfect package management software.
The selection plan of the software to support by Enbld is as follows.
Software required for a developer updated frequently (e.g. git, vim).
Software with which the developer who has participated in the project needs to unite a version (e.g. web server, database, programming language etc.).
Software required for a developer although not installed in Mac OS X (e.g. tmux).
It does not have a function which overlaps with the module controlling function which each software has (e.g. CPAN,gem etc.).
SUPPORTED PLATFORMS
Enbld is performing verification of running on Mac OS X 10.8 Mountain Lion.
Probably, it may operate also on Linux (Debian etc.). When not running, it is waiting for the report :)
CAUTION
Success of building of all the versions is not guaranteed. Since log file is displayed when building goes wrong, please analyze and send report:)
INSTALLATION
$ git clone https://github.com/magnolia-k/Enbld.git
$ cd Enbld
$ ./setup
And set Enbld's path.
In .bashrc, write below setting.
export $PATH=$HOME/.enbld/bin:$HOME/.enbld/extlib/bin:$PATH
export MANPATH=$HOME/.enbld/share/man:$HOME/.enbld/man:$MANPATH
GETTING STARTED
INSTALL LATEST VERSION
Ready configuration file
$ cat samples/git_install.plx
#!/usr/bin/perl
use 5.012;
use warnings;
use utf8;
use lib "$ENV{HOME}/.enbld/extlib/lib/perl5/";
use Enbld;
enbld 'myenv' => build {
target 'git' => define {
version 'latest';
};
}
Execute configuration file
$ ./samples/git_install.plx
Target software is installed
$ git --version
git version [latest version]
Upgrade installed software
Then, if the software of a latest version is released, please execute a configuration file again. The software of the latest version will be installed.
$ ./samples/git_install.plx
Latest software is installed.
INSTALL SPECIFIC VERSION
A specific version is specified in setting file. -> version '5.18.1';
$ cat samples/specific_version_install.plx
#!/usr/bin/perl
use 5.012;
use warnings;
use utf8;
use lib "$ENV{HOME}/.enbld/extlib/lib/perl5/";
use Enbld;
enbld 'myenv' => build {
target 'perl' => define {
version '5.18.1';
};
};
'perl 5.18.1' is installed.
$ perl -v
This is perl 5, version 18, subversion 1 (v5.18.1) built for darwin-multi-2level
DOWNLOAD OR CREATE SOFTWARE' CONFIGURATION FILE (DOTFILE)
Enbld also can create software' configuration file(.dotfile).
'conf' function set software' configuration file to home directory.
Download software' configuration file
$ cat samples/vim_install.plx
#!/usr/bin/perl
use 5.012;
use warnings;
use utf8;
use lib "$ENV{HOME}/.enbld/extlib/lib/perl5/";
use Enbld;
enbld 'myenv' => build {
target 'vim' => define {
version 'latest';
};
conf '.vimrc' => load {
from 'https://raw.github.com/magnolia-k/vimrc/master/.vimrc';
};
};
'.vimrc' is downloaded to $HOME from 'https://raw.github.com/magnolia-k/vimrc/master/.vimrc'.
Nothing is done when the file of the same file name already exists.
Create software' configuration file
conf '.vimrc' => set {
content 'syntax on';
content 'set cindent';
};
'.vimrc' is created to $HOME.
Nothing is done when the file of the same file name already exists.
MAKE TEST AT INSTALLATION
Enbld can make test at installation.
target 'git' => define {
version 'latest';
make_test 1;
};
As default, this function is OFF.
If a test goes wrong, also building will go wrong.
ADD ARGUMENTS
'arguments' method adds additional arguments to './configure'.
target 'perl' => define {
version '5.18.1';
arguments '-Dusethreads';
};
perl 5.18.1 with thread
$ perl -v
This is perl 5, version 18, subversion 1 (v5.18.1) built for darwin-thread-multi-2level
UTILITY COMMAND 'enblder'
Enbld installs utility command 'enblder'.
Displays available software
Subcommand 'available' displays software that can install by Enbld.
$ enblder available
Displays installed software
Subcommand 'list' displays software that is installed.
$ enblder list
Displays configuration file
Subcommand 'freeze' displays configuration file that is condition of installed software.
$ enblder freeze
Displays outdated software
Subcommand 'outdated' displays outdated software list.
$ enblder outdated
Upgrade outdated software
Subcommand 'upgrade' upgrade outdated software.
$ enblder upgrade git
SEE ALSO
COPYRIGHT
copyright 2013- Magnolia <magnolia.k@me.com>
.
LICENSE
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.