2014-08-04 17:53:18 +04:00
|
|
|
var fs = require('fs'),
|
2014-08-06 16:08:19 +04:00
|
|
|
https = require('https'),
|
|
|
|
exec = require('child_process').exec,
|
2014-08-04 17:53:18 +04:00
|
|
|
eventStream = require('event-stream'),
|
2014-08-07 15:04:45 +04:00
|
|
|
runSequence = require('run-sequence'),
|
2014-08-13 16:14:35 +04:00
|
|
|
through = require('through2'),
|
|
|
|
lodash = require('lodash'),
|
|
|
|
PoFile = require('pofile'),
|
|
|
|
strftime = require('strftime'),
|
2015-03-31 13:54:34 +03:00
|
|
|
del = require('del'),
|
2015-03-23 19:42:32 +03:00
|
|
|
bower = require('bower'),
|
2014-08-04 17:53:18 +04:00
|
|
|
gulp = require('gulp'),
|
|
|
|
uglify = require('gulp-uglify'),
|
|
|
|
concat = require('gulp-concat'),
|
|
|
|
phpcs = require('gulp-phpcs'),
|
|
|
|
order = require('gulp-order'),
|
|
|
|
handlebars = require('gulp-handlebars'),
|
2014-09-15 18:32:34 +04:00
|
|
|
handlebarsEngine = require('handlebars'),
|
2014-08-04 17:53:18 +04:00
|
|
|
defineModule = require('gulp-define-module'),
|
2014-08-07 15:04:45 +04:00
|
|
|
header = require('gulp-header'),
|
|
|
|
zip = require('gulp-zip'),
|
|
|
|
tar = require('gulp-tar'),
|
|
|
|
gzip = require('gulp-gzip'),
|
2014-08-13 12:40:42 +04:00
|
|
|
chmod = require('gulp-chmod'),
|
|
|
|
xgettext = require('gulp-xgettext'),
|
2015-03-23 19:42:32 +03:00
|
|
|
concatPo = require('gulp-concat-po'),
|
2016-05-30 16:15:50 +03:00
|
|
|
rename = require('gulp-rename'),
|
|
|
|
eslint = require('gulp-eslint');
|
2014-08-04 17:53:18 +04:00
|
|
|
|
|
|
|
// Set global configs.
|
|
|
|
var config = {
|
|
|
|
mibewPath: 'mibew',
|
2014-09-26 17:18:42 +04:00
|
|
|
configsPath: 'mibew/configs',
|
2014-08-04 17:53:18 +04:00
|
|
|
phpVendorPath: 'mibew/vendor',
|
2015-03-23 19:42:32 +03:00
|
|
|
jsVendorPath: 'mibew/js/vendor',
|
2014-08-04 17:53:18 +04:00
|
|
|
pluginsPath: 'mibew/plugins',
|
2014-09-26 17:18:42 +04:00
|
|
|
avatarsPath: 'mibew/files/avatar',
|
2014-09-24 17:04:37 +04:00
|
|
|
cachePath: 'mibew/cache',
|
2014-08-04 17:53:18 +04:00
|
|
|
jsPath: 'mibew/js',
|
2014-10-13 17:52:17 +04:00
|
|
|
chatStylesPath: 'mibew/styles/chats',
|
2014-08-04 17:53:18 +04:00
|
|
|
pageStylesPath: 'mibew/styles/pages',
|
2014-08-06 16:08:19 +04:00
|
|
|
compiledTemplatesHeader: fs.readFileSync('tools/compiled_templates_header.txt'),
|
2014-08-07 15:04:45 +04:00
|
|
|
getComposerUrl: 'https://getcomposer.org/installer',
|
2014-08-12 14:35:57 +04:00
|
|
|
phpBin: 'php -d "suhosin.executor.include.whitelist = phar"',
|
2014-12-11 17:21:20 +03:00
|
|
|
package: require('./composer.json')
|
2014-08-04 17:53:18 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2015-03-31 13:54:34 +03:00
|
|
|
// Cleans all built files
|
|
|
|
gulp.task('clean', function(callback) {
|
|
|
|
del([
|
|
|
|
'release',
|
|
|
|
'composer.lock',
|
|
|
|
config.phpVendorPath,
|
|
|
|
config.jsVendorPath,
|
2015-04-14 14:43:56 +03:00
|
|
|
config.jsPath + '/compiled/**/*',
|
2015-03-31 13:54:34 +03:00
|
|
|
'!' + config.jsPath + '/compiled/.keep',
|
|
|
|
config.chatStylesPath + '/default/templates_compiled/client_side/*.js',
|
|
|
|
config.chatStylesPath + '/default/js/compiled/*.js',
|
|
|
|
config.pageStylesPath + '/default/templates_compiled/client_side/*.js'
|
|
|
|
], callback);
|
|
|
|
});
|
|
|
|
|
2014-08-04 17:53:18 +04:00
|
|
|
// Checks all PHP files with PHP Code Sniffer.
|
2014-08-06 16:08:19 +04:00
|
|
|
gulp.task('phpcs', ['composer-install-dev'], function() {
|
2014-08-04 17:53:18 +04:00
|
|
|
return gulp.src([
|
|
|
|
config.mibewPath + '/**/*.php',
|
|
|
|
'!' + config.phpVendorPath + '/**/*.*',
|
2014-09-24 17:04:37 +04:00
|
|
|
'!' + config.pluginsPath + '/**/*.*',
|
|
|
|
'!' + config.cachePath + '/**/*.*'
|
|
|
|
], {
|
|
|
|
// Content of the cache directory is readable only for webserver. Thus
|
|
|
|
// we must to set "strict" option to false to prevent "EACCES" errors.
|
|
|
|
// At the same we need to see all errors that take place.
|
|
|
|
strict: false,
|
|
|
|
silent: false
|
|
|
|
})
|
2014-08-04 17:53:18 +04:00
|
|
|
.pipe(phpcs({
|
|
|
|
bin: config.phpVendorPath + '/bin/phpcs',
|
|
|
|
standard: 'PSR2',
|
|
|
|
warningSeverity: 0
|
2014-08-13 15:03:03 +04:00
|
|
|
}))
|
|
|
|
.pipe(phpcs.reporter('log'))
|
|
|
|
.pipe(phpcs.reporter('fail'));
|
2014-08-04 17:53:18 +04:00
|
|
|
});
|
|
|
|
|
2016-05-30 16:15:50 +03:00
|
|
|
// Checks all JavaScript Source files with ESLint.
|
|
|
|
gulp.task('eslint', function() {
|
|
|
|
return gulp.src(config.jsPath + '/source/**/*.js')
|
|
|
|
.pipe(eslint())
|
|
|
|
.pipe(eslint.format())
|
|
|
|
.pipe(eslint.failAfterError());
|
|
|
|
});
|
|
|
|
|
2014-08-06 16:08:19 +04:00
|
|
|
// Get and install PHP Composer
|
|
|
|
gulp.task('get-composer', function(callback) {
|
|
|
|
// Check if Composer already in place
|
|
|
|
if (fs.existsSync('./composer.phar')) {
|
|
|
|
callback(null);
|
|
|
|
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Get installer from the internet
|
|
|
|
https.get(config.getComposerUrl, function(response) {
|
|
|
|
// Run PHP to install Composer
|
2014-08-12 14:35:57 +04:00
|
|
|
var php = exec(config.phpBin, function(error, stdout, stderr) {
|
2014-08-06 16:08:19 +04:00
|
|
|
callback(error ? stderr : null);
|
|
|
|
});
|
|
|
|
// Pass installer code to PHP via STDIN
|
|
|
|
response.pipe(php.stdin);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
// Install Composer dependencies excluding development ones
|
|
|
|
gulp.task('composer-install', ['get-composer'], function(callback) {
|
2014-08-12 14:35:57 +04:00
|
|
|
exec(config.phpBin + ' composer.phar install --no-dev', function(error, stdout, stderr) {
|
2014-08-06 16:08:19 +04:00
|
|
|
callback(error ? stderr : null);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
// Install all Composer dependencies
|
|
|
|
gulp.task('composer-install-dev', ['get-composer'], function(callback) {
|
2014-08-12 14:35:57 +04:00
|
|
|
exec(config.phpBin + ' composer.phar install', function(error, stdout, stderr) {
|
2014-08-06 16:08:19 +04:00
|
|
|
callback(error ? stderr : null);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2015-03-23 19:42:32 +03:00
|
|
|
// Installs bower dependencies
|
|
|
|
gulp.task('bower-install', function(callback) {
|
|
|
|
bower.commands.install([], {}, {})
|
|
|
|
.on('error', function(error) {
|
|
|
|
callback(error);
|
|
|
|
})
|
|
|
|
.on('end', function() {
|
|
|
|
// We should manually minify JavaScript files that was not minified
|
|
|
|
// by bower packages' authors.
|
|
|
|
// TODO: This is a temproary workaround and should be removed once
|
|
|
|
// the packages will be fixed.
|
|
|
|
var stream = eventStream.merge(
|
|
|
|
gulp.src(config.jsVendorPath + '/backbone/backbone.js', {base: config.jsVendorPath})
|
|
|
|
.pipe(uglify({preserveComments: 'some'}))
|
|
|
|
// There are neither "@license" tag nor "!preserve" in the
|
|
|
|
// header. Add the header manually.
|
|
|
|
.pipe(header(
|
|
|
|
"// Backbone.js 1.1.2\n"
|
|
|
|
+ "// (c) 2010-2015 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors\n"
|
|
|
|
+ "// Backbone may be freely distributed under the MIT license.\n"
|
|
|
|
+ "// For all details and documentation:\n"
|
|
|
|
+ "// http://backbonejs.org\n"
|
|
|
|
))
|
|
|
|
.pipe(rename('backbone/backbone-min.js')),
|
|
|
|
gulp.src(config.jsVendorPath + '/json/json2.js', {base: config.jsVendorPath})
|
|
|
|
.pipe(uglify({preserveComments: 'some'}))
|
|
|
|
// There are neither "@license" tag nor "!preserve" in the
|
|
|
|
// header. Add the header manually.
|
|
|
|
.pipe(header("// json2.js. Public Domain. See http://www.JSON.org/js.html\n"))
|
|
|
|
.pipe(rename('json/json2.min.js'))
|
2015-04-14 14:39:33 +03:00
|
|
|
)
|
|
|
|
.pipe(gulp.dest(config.jsVendorPath));
|
2015-03-23 19:42:32 +03:00
|
|
|
|
|
|
|
stream
|
|
|
|
.on('error', callback)
|
|
|
|
.on('end', callback);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2014-08-04 17:53:18 +04:00
|
|
|
// Compile all JavaScript files of the Mibew Core
|
|
|
|
gulp.task('js', function() {
|
|
|
|
return eventStream.merge(
|
|
|
|
getClientSideApp('default'),
|
|
|
|
getClientSideApp('chat'),
|
|
|
|
getClientSideApp('thread_log'),
|
|
|
|
getClientSideApp('users'),
|
|
|
|
gulp.src(config.jsPath + '/source/**/*.js')
|
|
|
|
)
|
|
|
|
.pipe(uglify({preserveComments: 'some'}))
|
|
|
|
.pipe(gulp.dest(config.jsPath + '/compiled'));
|
|
|
|
});
|
|
|
|
|
|
|
|
// Performs all job related with chat styles.
|
|
|
|
gulp.task('chat-styles', ['chat-styles-handlebars', 'chat-styles-js'], function() {
|
|
|
|
// This task is just a combination of other tasks. That is why there is no
|
|
|
|
// real code.
|
|
|
|
});
|
|
|
|
|
|
|
|
// Compile and concatenate handlebars files for all chat styles.
|
|
|
|
gulp.task('chat-styles-handlebars', function() {
|
2017-03-10 01:44:53 +03:00
|
|
|
var promises = [];
|
|
|
|
fs.readdir(config.chatStylesPath, function(err, list){
|
|
|
|
if(err) return done(err);
|
|
|
|
list.filter(function(path){
|
|
|
|
return fs.lstatSync(config.chatStylesPath + "/" + path).isDirectory();
|
|
|
|
}).map(function(dir){
|
|
|
|
promises.push(new Promise(function(resolve, reject){
|
|
|
|
var pipeline = gulp.src(config.chatStylesPath + '/' + dir + '/templates_src/client_side/**/*.handlebars')
|
|
|
|
.pipe(handlebars({
|
|
|
|
// Use specific version of Handlebars.js
|
|
|
|
handlebars: handlebarsEngine
|
|
|
|
}))
|
|
|
|
.pipe(wrapHandlebarsTemplate())
|
|
|
|
.pipe(concat('templates.js'))
|
|
|
|
.pipe(uglify({preserveComments: 'some'}))
|
|
|
|
.pipe(header(config.compiledTemplatesHeader))
|
|
|
|
.pipe(gulp.dest(config.chatStylesPath + '/' + dir + '/templates_compiled/client_side'));
|
|
|
|
pipeline.on('end', resolve);
|
|
|
|
pipeline.on('error', reject);
|
|
|
|
}));
|
|
|
|
});
|
|
|
|
});
|
2014-08-04 17:53:18 +04:00
|
|
|
});
|
|
|
|
|
|
|
|
// Compile and concatenate js files for all chat styles.
|
|
|
|
gulp.task('chat-styles-js', function() {
|
2017-03-10 01:44:53 +03:00
|
|
|
var promises = [];
|
|
|
|
fs.readdir(config.chatStylesPath, function(err, list){
|
|
|
|
if(err) return done(err);
|
|
|
|
list.filter(function(path){
|
|
|
|
return fs.lstatSync(config.chatStylesPath + "/" + path).isDirectory();
|
|
|
|
}).map(function(dir){
|
|
|
|
promises.push(new Promise(function(resolve, reject){
|
|
|
|
var pipeline = gulp.src(config.chatStylesPath + '/' + dir + '/js/source/**/*.js')
|
|
|
|
.pipe(concat('scripts.js'))
|
|
|
|
.pipe(uglify({preserveComments: 'some'}))
|
|
|
|
.pipe(gulp.dest(config.chatStylesPath + '/' + dir + '/js/compiled'));
|
|
|
|
pipeline.on('end', resolve);
|
|
|
|
pipeline.on('error', reject);
|
|
|
|
}));
|
|
|
|
});
|
|
|
|
});
|
2014-08-04 17:53:18 +04:00
|
|
|
});
|
|
|
|
|
|
|
|
// Performs all job related with pages styles.
|
|
|
|
gulp.task('page-styles', function() {
|
2017-03-10 01:44:53 +03:00
|
|
|
var promises = [];
|
|
|
|
fs.readdir(config.pageStylesPath, function(err, list){
|
|
|
|
if(err) return done(err);
|
|
|
|
list.filter(function(path){
|
|
|
|
return fs.lstatSync(config.pageStylesPath + "/" + path).isDirectory();
|
|
|
|
}).map(function(dir){
|
|
|
|
promises.push(new Promise(function(resolve, reject){
|
|
|
|
var pipeline = gulp.src(config.pageStylesPath + '/' + dir + '/templates_src/client_side/**/*.handlebars')
|
|
|
|
.pipe(handlebars({
|
|
|
|
// Use specific version of Handlebars.js
|
|
|
|
handlebars: handlebarsEngine
|
|
|
|
}))
|
|
|
|
.pipe(wrapHandlebarsTemplate())
|
|
|
|
.pipe(concat('templates.js'))
|
|
|
|
.pipe(uglify({preserveComments: 'some'}))
|
|
|
|
.pipe(header(config.compiledTemplatesHeader))
|
|
|
|
.pipe(gulp.dest(config.pageStylesPath + '/' + dir + '/templates_compiled/client_side'));
|
|
|
|
pipeline.on('end', resolve);
|
|
|
|
pipeline.on('error', reject);
|
|
|
|
}));
|
|
|
|
});
|
|
|
|
});
|
2014-08-04 17:53:18 +04:00
|
|
|
});
|
|
|
|
|
2014-08-13 12:40:42 +04:00
|
|
|
// Generate .pot files based on the sources
|
|
|
|
gulp.task('generate-pot', function() {
|
2014-08-13 16:14:35 +04:00
|
|
|
return eventStream.merge(
|
|
|
|
gulp.src([
|
|
|
|
config.mibewPath + '/**/*.php',
|
|
|
|
'!' + config.phpVendorPath + '/**/*.*',
|
2014-09-24 17:04:37 +04:00
|
|
|
'!' + config.pluginsPath + '/**/*.*',
|
|
|
|
'!' + config.cachePath + '/**/*.*'
|
|
|
|
], {
|
|
|
|
// Content of the cache directory is readable only for webserver.
|
|
|
|
// Thus we must to set "strict" option to false to prevent "EACCES"
|
|
|
|
// errors. At the same we need to see all errors that take place.
|
|
|
|
strict: false,
|
|
|
|
silent: false
|
|
|
|
})
|
2014-08-13 16:14:35 +04:00
|
|
|
.pipe(xgettext({
|
|
|
|
language: 'PHP',
|
|
|
|
keywords: [
|
2014-08-18 13:42:08 +04:00
|
|
|
{name: 'getlocal'},
|
|
|
|
{name: 'no_field'},
|
|
|
|
{name: 'wrong_field'},
|
|
|
|
{name: 'failed_uploading_file', singular: 2}
|
2014-08-13 16:14:35 +04:00
|
|
|
]
|
|
|
|
})),
|
2014-08-18 13:23:15 +04:00
|
|
|
gulp.src(config.jsPath + '/source/**/*.js', {base: config.mibewPath})
|
|
|
|
.pipe(xgettext({
|
|
|
|
language: 'JavaScript',
|
|
|
|
keywords: [
|
|
|
|
{name: 'trans'}
|
|
|
|
]
|
|
|
|
})),
|
2014-08-13 16:14:35 +04:00
|
|
|
gulp.src([
|
|
|
|
config.chatStylesPath + '/default/templates_src/**/*.handlebars',
|
|
|
|
config.pageStylesPath + '/default/templates_src/**/*.handlebars'
|
|
|
|
], {base: config.mibewPath})
|
|
|
|
.pipe(xgettextHandlebars())
|
|
|
|
)
|
2014-08-13 12:40:42 +04:00
|
|
|
.pipe(concatPo('translation.pot', {
|
|
|
|
headers: {
|
2014-08-19 16:49:54 +04:00
|
|
|
'Project-Id-Version': 'Mibew Messenger ' + config.package.version,
|
2014-12-11 17:21:20 +03:00
|
|
|
'Report-Msgid-Bugs-To': config.package.support.email,
|
2014-08-13 16:14:35 +04:00
|
|
|
'POT-Creation-Date': strftime('%Y-%m-%d %H:%M%z'),
|
2014-08-13 12:40:42 +04:00
|
|
|
'PO-Revision-Date': '',
|
|
|
|
'Last-Translator': '',
|
|
|
|
'Language-Team': '',
|
|
|
|
'Content-Type': 'text/plain; charset=UTF-8'
|
|
|
|
}
|
|
|
|
}))
|
|
|
|
.pipe(gulp.dest('release'));
|
|
|
|
});
|
|
|
|
|
2014-08-07 15:04:45 +04:00
|
|
|
// Pack sources to .zip and .tar.gz archives.
|
2015-03-23 19:42:32 +03:00
|
|
|
gulp.task('pack-sources', ['composer-install', 'bower-install'], function() {
|
2014-08-13 13:04:44 +04:00
|
|
|
var sources = [
|
|
|
|
config.mibewPath + '/**/*',
|
2014-09-26 17:18:42 +04:00
|
|
|
// Exclude user's config
|
|
|
|
'!' + config.configsPath + '/config.yml',
|
|
|
|
// Exclude cache files but not the ".keep" file.
|
2014-09-24 17:04:37 +04:00
|
|
|
'!' + config.cachePath + '/**/!(.keep)',
|
2014-09-26 17:18:42 +04:00
|
|
|
// Exclude avatars but not the ".keep" file.
|
|
|
|
'!' + config.avatarsPath + '/!(.keep)',
|
|
|
|
// Exclude plugins but not the ".keep" file.
|
|
|
|
'!' + config.pluginsPath + '/!(.keep)',
|
|
|
|
'!' + config.pluginsPath + '/*/**/*',
|
2014-08-13 13:04:44 +04:00
|
|
|
// Exclude Git repositories that can be shipped with third-party libs
|
|
|
|
'!' + config.phpVendorPath + '/**/.git',
|
2014-12-11 17:06:15 +03:00
|
|
|
'!' + config.phpVendorPath + '/**/.git/**/*',
|
|
|
|
// Exclude vendors binaries
|
2014-12-23 17:48:26 +03:00
|
|
|
'!' + config.phpVendorPath + '/bin/**/*',
|
|
|
|
// Exclude JavaScript sources
|
2015-03-23 19:42:32 +03:00
|
|
|
'!' + config.jsPath + '/source/**/*',
|
|
|
|
// Actually we does not need backbone.babysitter and backbone.wreqr
|
|
|
|
// dependencies because they embed into marionette.js. So we exclude
|
|
|
|
// "backbone.babysitter" and "backbone.wreqr" directories and all their
|
|
|
|
// contents.
|
|
|
|
'!' + config.jsVendorPath + '/backbone.babysitter{,/**}',
|
|
|
|
'!' + config.jsVendorPath + '/backbone.wreqr{,/**}',
|
|
|
|
// Exclude dot files within third-party JS libraries.
|
|
|
|
'!' + config.jsVendorPath + '/**/.*',
|
|
|
|
// Exclude config files of various package systems
|
|
|
|
'!' + config.jsVendorPath + '/**/{bower,component,package,composer}.json',
|
|
|
|
// Exclude config files of various build systems
|
|
|
|
'!' + config.jsVendorPath + '/**/Gruntfile.*',
|
|
|
|
'!' + config.jsVendorPath + '/**/gulpfile.*',
|
|
|
|
'!' + config.jsVendorPath + '/**/Makefile',
|
|
|
|
// Exclude HTML files from third-party JS libraries. Such files can be
|
|
|
|
// used for docs or for tests, we need none of them.
|
|
|
|
'!' + config.jsVendorPath + '/**/*.html',
|
|
|
|
// There are too many useless files in Vex.js library. Exclude them.
|
|
|
|
'!' + config.jsVendorPath + '/vex/sass{,/**}',
|
|
|
|
'!' + config.jsVendorPath + '/vex/docs{,/**}',
|
|
|
|
'!' + config.jsVendorPath + '/vex/docs{,/**}',
|
|
|
|
'!' + config.jsVendorPath + '/vex/coffee{,/**}'
|
2014-08-13 13:04:44 +04:00
|
|
|
];
|
2014-09-24 17:04:37 +04:00
|
|
|
var srcOptions = {
|
|
|
|
// Dot files (.htaccess, .keep, etc.) must be included in the package.
|
|
|
|
dot: true,
|
|
|
|
// Content of the cache directory is readable only for webserver. Thus
|
|
|
|
// we must to set "strict" option to false to prevent "EACCES" errors.
|
|
|
|
// At the same we need to see all errors that take place.
|
|
|
|
strict: false,
|
|
|
|
silent: false
|
|
|
|
}
|
2014-08-13 13:04:44 +04:00
|
|
|
var version = config.package.version;
|
2014-08-07 15:04:45 +04:00
|
|
|
|
|
|
|
return eventStream.merge(
|
2014-09-24 17:04:37 +04:00
|
|
|
gulp.src(sources, srcOptions)
|
2014-08-07 15:04:45 +04:00
|
|
|
.pipe(zip('mibew-' + version + '.zip')),
|
2014-09-24 17:04:37 +04:00
|
|
|
gulp.src(sources, srcOptions)
|
2014-08-07 15:04:45 +04:00
|
|
|
.pipe(tar('mibew-' + version + '.tar'))
|
|
|
|
.pipe(gzip())
|
|
|
|
)
|
2017-02-08 10:41:18 +03:00
|
|
|
.pipe(chmod(644))
|
2014-08-07 15:04:45 +04:00
|
|
|
.pipe(gulp.dest('release'));
|
|
|
|
});
|
|
|
|
|
2014-08-28 12:38:07 +04:00
|
|
|
// Performs all tasks in the correct order.
|
|
|
|
gulp.task('prepare-release', function(callback) {
|
2014-08-07 15:04:45 +04:00
|
|
|
runSequence(
|
2015-03-31 13:54:34 +03:00
|
|
|
'clean',
|
2014-08-13 12:40:42 +04:00
|
|
|
['phpcs', 'js', 'chat-styles', 'page-styles', 'generate-pot'],
|
2014-08-07 15:04:45 +04:00
|
|
|
'pack-sources',
|
|
|
|
callback
|
|
|
|
);
|
2014-08-04 17:53:18 +04:00
|
|
|
});
|
|
|
|
|
2015-04-17 17:18:59 +03:00
|
|
|
// Prepares ready to use development version of Mibew without packing or
|
|
|
|
// validating it.
|
|
|
|
gulp.task('rebuild', function(callback) {
|
|
|
|
runSequence(
|
|
|
|
'clean',
|
|
|
|
['js', 'chat-styles', 'page-styles', 'composer-install', 'bower-install'],
|
|
|
|
callback
|
|
|
|
);
|
|
|
|
});
|
|
|
|
|
2014-08-28 12:38:07 +04:00
|
|
|
// Builds the sources
|
|
|
|
gulp.task('default', function(callback) {
|
|
|
|
runSequence(
|
2015-04-17 16:07:25 +03:00
|
|
|
'clean',
|
2014-08-28 12:38:07 +04:00
|
|
|
['js', 'chat-styles', 'page-styles'],
|
|
|
|
'pack-sources',
|
|
|
|
callback
|
|
|
|
);
|
|
|
|
});
|
|
|
|
|
2014-08-04 17:53:18 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Loads and prepare js file for a client side application with the specified
|
|
|
|
* name.
|
|
|
|
*
|
|
|
|
* @param {String} name Application name
|
|
|
|
* @returns A files stream that can be piped to any gulp plugin.
|
|
|
|
*/
|
|
|
|
var getClientSideApp = function(name) {
|
|
|
|
var appSource = config.jsPath + '/source/' + name;
|
|
|
|
|
|
|
|
return gulp.src(appSource + '/**/*.js')
|
|
|
|
.pipe(order(
|
|
|
|
[
|
|
|
|
appSource + '/init.js',
|
|
|
|
// The following line is equivalent to
|
|
|
|
// gulp.src([appSource + '/*.js', '!' + appSource + '/app.js']);
|
|
|
|
appSource + '/!(app).js',
|
|
|
|
appSource + '/models/**/base*.js',
|
|
|
|
appSource + '/models/**/*.js',
|
|
|
|
appSource + '/collections/**/base*.js',
|
|
|
|
appSource + '/collections/**/*.js',
|
|
|
|
appSource + '/model_views/**/base*.js',
|
|
|
|
appSource + '/model_views/**/*.js',
|
|
|
|
appSource + '/collection_views/**/base*.js',
|
|
|
|
appSource + '/collection_views/**/*.js',
|
|
|
|
appSource + '/regions/**/base*.js',
|
|
|
|
appSource + '/regions/**/*.js',
|
|
|
|
appSource + '/layouts/**/base*.js',
|
|
|
|
appSource + '/layouts/**/*.js',
|
|
|
|
appSource + '/**/base*.js',
|
|
|
|
// The following line is equivalent to
|
|
|
|
// gulp.src([appSource + '/**/*.js', '!' + appSource + '/app.js']);
|
|
|
|
'!' + appSource + '/app.js',
|
|
|
|
appSource + '/app.js'
|
|
|
|
],
|
|
|
|
{base: process.cwd()}
|
|
|
|
))
|
|
|
|
.pipe(concat(name + '_app.js'));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Wraps a handlebars template with a function and attach it to the
|
|
|
|
* Handlebars.templates object.
|
|
|
|
*
|
|
|
|
* @returns {Function} A function that can be used in pipe() method of a file
|
|
|
|
* stream right after gulp-handlebars plugin.
|
|
|
|
*/
|
|
|
|
var wrapHandlebarsTemplate = function() {
|
|
|
|
return defineModule('plain', {
|
|
|
|
wrapper: '(function() {\n'
|
|
|
|
+ 'var templates = Handlebars.templates = Handlebars.templates || {};\n'
|
|
|
|
+ 'Handlebars.templates["<%= relative %>"] = <%= handlebars %>;\n'
|
|
|
|
+ '})()',
|
|
|
|
context: function(context) {
|
2015-01-23 14:34:24 +03:00
|
|
|
return {relative: context.file.relative.replace(/\.js$/, '').replace(/\\/g, '/')};
|
2014-08-04 17:53:18 +04:00
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
2014-08-13 16:14:35 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Extracts gettext messages from handlebars templates.
|
|
|
|
*
|
|
|
|
* @returns {Function} A function that can be used in pipe() method of a file
|
|
|
|
* stream.
|
|
|
|
*/
|
|
|
|
var xgettextHandlebars = function() {
|
|
|
|
var helperRegExp = /\{{2}l10n\s*('|")(.*?[^\\])\1.*?\}{2}/g;
|
|
|
|
|
|
|
|
return through.obj(function (file, enc, callback) {
|
|
|
|
var po = new PoFile();
|
|
|
|
match = false,
|
|
|
|
contents = file.contents.toString();
|
|
|
|
|
|
|
|
while (match = helperRegExp.exec(contents)) {
|
|
|
|
// Try to find item in the .po file by its name.
|
|
|
|
var item = lodash.find(po.items, function(item) {
|
|
|
|
return match[2] === item.msgid;
|
|
|
|
});
|
|
|
|
|
|
|
|
var line = contents.substr(0, match.index).split(/\r?\n|\r/g).length;
|
|
|
|
|
|
|
|
if (!item) {
|
|
|
|
// There is no such item. Create new one.
|
|
|
|
item = new PoFile.Item();
|
|
|
|
item.msgid = match[2].replace(/\\'/g, "'").replace(/\\"/g, '"');
|
|
|
|
po.items.push(item);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Add new reference
|
|
|
|
item.references.push(file.relative + ':' + line);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Update file contents
|
|
|
|
file.contents = new Buffer(po.toString());
|
|
|
|
this.push(file);
|
|
|
|
|
|
|
|
callback();
|
|
|
|
});
|
|
|
|
}
|