lutin/doc/mainpage.md

141 lines
3.7 KiB
Markdown
Raw Normal View History

2016-09-09 21:30:25 +02:00
Lutin Build system {#mainpage}
==================
2015-10-03 12:32:51 +02:00
2016-09-09 21:30:25 +02:00
@tableofcontents
2016-09-09 21:30:25 +02:00
`lutin` is a generic builder and package maker is a FREE software tool.
![Py package](https://badge.fury.io/py/lutin.png) https://pypi.python.org/pypi/lutin
Release (master) {#lutin_mainpage_build_master}
================
![Build Status](https://travis-ci.org/HeeroYui/lutin.svg?branch=master) https://travis-ci.org/HeeroYui/lutin
Developement (dev) {#lutin_mainpage_build_dev}
==================
![Build Status](https://travis-ci.org/HeeroYui/lutin.svg?branch=dev) https://travis-ci.org/HeeroYui/lutin
What is Lutin? {#lutin_mainpage_intro}
==============
2015-10-03 12:32:51 +02:00
Lutin is an application/library builder, it is designed to concurence CMake, Makefile, Ant, graddle ...
Lutin is deveopped in Python 2.x and 3.x to permit many user to play with it.
Python permit to Lutin to be used in many environement in a fast way.
Lutin support can compile every thing you want, just add a builder that you need (not in the common way). Basicly Lutin support languages:
- C (ainsi/89/99) ==> .o;
- C++ (98/99/03/11/14/...) ==> .o;
- .S (assembleur) ==> .o;
- .java ==> .class;
- .class ==> jar;
- .o ==> .a;
- .o ==> .so;
- .o/.a ==> binary.
2015-10-03 12:32:51 +02:00
Some packege can be generate for some platform:
- debian package;
- windows application zip;
- MacOs application .app;
- iOs package;
- Android Package .apk.
2015-10-03 12:32:51 +02:00
Compilation is availlable for:
- gcc/g++;
- clang/clang++.
2015-10-03 12:32:51 +02:00
2016-09-09 21:30:25 +02:00
Manage **workspace build** (in oposition of CMake/make/...)
2015-10-03 12:32:51 +02:00
2016-09-09 21:30:25 +02:00
Install: {#lutin_mainpage_installation}
========
2015-10-03 12:32:51 +02:00
Requirements: ``Python >= 2.7`` and ``pip``
Install lutin:
2016-09-09 21:30:25 +02:00
--------------
2015-10-03 12:32:51 +02:00
Just run:
2016-09-13 23:56:20 +02:00
```{.sh}
2015-10-03 12:32:51 +02:00
pip install lutin
```
Install pip:
2016-09-09 21:30:25 +02:00
------------
2015-10-03 12:32:51 +02:00
Install pip on debian/ubuntu:
2016-09-13 23:56:20 +02:00
```{.sh}
2015-10-03 12:32:51 +02:00
sudo apt-get install pip
```
2015-10-03 12:32:51 +02:00
Install pip on ARCH-linux:
2016-09-13 23:56:20 +02:00
```{.sh}
2015-10-03 12:32:51 +02:00
sudo pacman -S pip
```
2015-10-03 12:32:51 +02:00
Install pip on MacOs:
2016-09-13 23:56:20 +02:00
```{.sh}
2015-10-03 12:32:51 +02:00
sudo easy_install pip
```
2015-10-03 12:32:51 +02:00
Install from sources:
2016-09-09 21:30:25 +02:00
---------------------
2015-10-03 12:32:51 +02:00
2016-09-13 23:56:20 +02:00
```{.sh}
2015-10-03 12:32:51 +02:00
git clone http://github.com/HeeroYui/lutin.git
cd lutin
sudo ./setup.py install
```
2016-09-09 21:30:25 +02:00
git repository {#lutin_mainpage_repository}
==============
2015-10-03 12:32:51 +02:00
2016-09-09 21:30:25 +02:00
http://github.com/HeeroYui/lutin/
2016-09-09 21:30:25 +02:00
Tutorals: {#lutin_mainpage_tutorial}
=========
2016-09-09 21:30:25 +02:00
- @ref lutin_concept
- @ref lutin_use
- @ref lutin_module
License (APACHE v2.0) {#lutin_mainpage_licence}
=====================
2015-10-03 12:32:51 +02:00
Copyright lutin Edouard DUPIN
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
2016-09-09 21:30:25 +02:00
History: {#lutin_mainpage_history}
========
2015-10-03 12:32:51 +02:00
I work with some builder, Every one have theire own adventages, and their problems.
The main point I see, is that the polimorphisme of the worktree is really hard.
The second point is the generation on different platforms is hard too.
Some other problem example:
- Makefile is too slow on windows mingw;
- Cmake does not create end point package;
- none is really simple to write.
2015-10-03 12:32:51 +02:00
Then I create a simple interface that manage all I need. and written in python to permit to be faster on every platform.