Buildsystems presentation
Why do we need buildsystems?
Imagine you are writing your own project. When it is simple or even consists of only one source file – it is obvious for you and other how to build it. Moreover, it is usually being compiled in one command. But what if your project consists of hundreds of source files? And what if it has a lot of dependencies that have their own dependencies and so on and so forth? Not so easy, right?
Here is were buildsystems come to the rescue
What is buildsystem?
Buildsystem is a collection of tasks that automate repetitive work. In other words buildsystems are software tools designed to automate the process of program compilation.
In two words buildsystems do a lot of things that simplify the developer’s life. But first developer have to setup build system before enjoying simple life :)
Demo project
Let setup a gulp
buildsystem for a simple web project written in javascript. Source code of this demo is available on GitHub
What is gulp
? Gulp is a streaming build system written in javascript. The main idea is that you put your files into stream and then apply different transformations to the stream. It is somehow similar to the idea of bash
pipes:
First of all we have to setup gulp. Gulp must be installed both globally in your system and locally as devDependency of your project.
Then create gulpfile.js
file in the root of your project. It is a file where all your tasks are defined. Let define there a simple task:
Here my-first-task is the name of your task, empty array means that your task has no dependencies. And when you will run this task the function’s body will be executed.
You can run it by typing gulp my-first-task
in your console.
Tasks can depend on other tasks. To do that just add the name of the dependency into the array parameter of dependent task. Like that:
If you have some task that you run pretty often and you do not want to type its name each time you execute it, make this task default. Then you will have to type just gulp
to run this task:
Well, we have learned some basics. Let do some real job. We have the following project structure:
We have our source files in the src directory. All scripts are stored in src/js
files We do not want to load both files in our html pages, we want to create one js file which we will load. Stylesheets are written in stylus
so we will need to preprocess them.
First we will need to install some modules for gulp:
We will start from just copying files from one directory to another. To do that we source our input files and then apply gulp.dest
to them:
We can source multiple files at once. To do that we can use globs
. If you are not familiar with globs take a look here.
In demo project we do not have a lot of javascript. However there are a lot of javascript code in big projects. In order to speed up page load time javascript is often being minified. To do that we have gulp-uglify
plugin.
Now we have two minified javascript files in our output directory. But as we remember we do not want to load two files. We want to have one javascript file, which includes the contents of that two. Here comes gulp-concat
to the rescue!
During development process we often need to rebuild our javascript as we change the source code. It is not convenient to do it manually, so maybe there is gulp plugin for that? The answer is
Gulp can do that out of the box. Without any plugins!
Here is code we need to watch changes in our source files and rebuild project as we detect them:
Now it is time to build styles for our project. We use stylus in our demo project. Hence we need gulp-stylus
plugin to build our styles:
To sum up
We have followed the process of setting up gulp buildsystem. Of course there are still a lot of things to improve in our build system like stopping watch task as build fails or optimizing images… You can find some of that steps done in demo repository. Also check my slides for cute pony pictures. You can check out this awesome video tutorial about setting up gulp.