build: cleanaup Makefile
[platform/framework/web/web-ui-fw.git] / Makefile
1 SHELL := /bin/bash
2
3 ## Project setting
4 DEBUG ?= yes
5 PROJECT_NAME = tizen-web-ui-fw
6 VERSION = 0.2
7 VERSION_COMPAT =
8 PKG_VERSION = $(shell cat packaging/web-ui-fw.spec | grep Version: | sed -e "s@Version:\s*@@" )
9 THEME_NAME = default
10
11 PATH := $(CURDIR)/build-tools/bin:$(PATH)
12
13 JSLINT_LEVEL = 1
14 JSLINT = jslint --sloppy --eqeq --bitwise --forin --nomen --predef jQuery --color --plusplus --browser --jqmspace --regexp
15 COMMON_WIDGET = common
16 INLINE_PROTO = 1
17 OUTPUT_ROOT = $(CURDIR)/build
18 FRAMEWORK_ROOT = ${OUTPUT_ROOT}/${PROJECT_NAME}/${VERSION}
19
20 LATEST_ROOT = ${OUTPUT_ROOT}/${PROJECT_NAME}/latest
21
22 JS_OUTPUT_ROOT = ${FRAMEWORK_ROOT}/js
23 export THEME_OUTPUT_ROOT = ${FRAMEWORK_ROOT}/themes
24 CSS_OUTPUT_ROOT = ${FRAMEWORK_ROOT}/themes/${THEME_NAME}
25 CSS_IMAGES_OUTPUT_DIR = ${CSS_OUTPUT_ROOT}/images
26 WIDGET_CSS_OUTPUT_ROOT = ${FRAMEWORK_ROOT}/widget-css
27 PROTOTYPE_HTML_OUTPUT_DIR = proto-html
28
29 WIDGETS_DIR = $(CURDIR)/src/widgets
30
31 THEMES_DIR = $(CURDIR)/src/themes
32 LIBS_DIR = $(CURDIR)/libs
33
34 COPYING_FILE = $(CURDIR)/COPYING
35
36 DESTDIR ?=
37
38 PREFIX ?= /usr
39 INSTALL_DIR = ${DESTDIR}${PREFIX}
40
41 FW_JS = ${JS_OUTPUT_ROOT}/${PROJECT_NAME}.js
42 FW_MIN = $(subst .js,.min.js,$(FW_JS))
43 FW_LIB_JS = ${JS_OUTPUT_ROOT}/${PROJECT_NAME}-libs.js
44 FW_LIB_MIN = $(subst .js,.min.js,$(FW_LIB_JS))
45
46 FW_JS_THEME = ${JS_OUTPUT_ROOT}/${PROJECT_NAME}-${THEME_NAME}-theme.js
47 FW_CSS = ${CSS_OUTPUT_ROOT}/${PROJECT_NAME}-theme.css
48 FW_LIBS_JS = ${JS_OUTPUT_ROOT}/${PROJECT_NAME}-libs.js
49 FW_THEME_CSS_FILE = ${PROJECT_NAME}-theme.css
50 FW_WIDGET_CSS_FILE = ${WIDGET_CSS_OUTPUT_ROOT}/${PROJECT_NAME}-widget.css
51
52 LIBS_JS_FILES = jquery.easing.1.3.js \
53                 jquery.tmpl.js \
54                 jquery.mobile.js \
55                 $(NULL)
56
57 JQUERY_MOBILE_CSS = submodules/jquery-mobile/compiled/jquery.mobile.structure.css \
58                     submodules/jquery-mobile/compiled/jquery.mobile.css \
59                     $(NULL)
60 JQUERY_MOBILE_IMAGES = submodules/jquery-mobile/css/themes/default/images
61
62 JQM_VERSION = jquery-mobile-1.2.0
63 JQM_LIB_PATH = $(CURDIR)/libs/js/${JQM_VERSION}
64
65 JQUERY = jquery-1.8.2.js
66 JQUERY_MIN = $(subst .js,.min.js,$(JQUERY))
67
68 all: libs_prepare third_party widgets libs_cleanup loader themes version version_compat compress
69
70 libs_prepare:
71         # Prepare libs/ build...
72         @@test -d ${LIBS_DIR}.bak && rm -rf ${LIBS_DIR} && mv ${LIBS_DIR}.bak ${LIBS_DIR}; \
73         cp -a ${LIBS_DIR} ${LIBS_DIR}.bak
74         for f in `ls ${LIBS_DIR}/patch/*.patch`; do \
75                 cd $(CURDIR); \
76                 echo "Apply patch: $$f";  \
77                 cat $$f | patch -p1 -N; \
78         done; \
79
80 libs_cleanup:
81         # Cleanup libs/ directory...
82         @@rm -rf ${LIBS_DIR} && mv ${LIBS_DIR}.bak ${LIBS_DIR}
83
84 jqm: init
85         # Building jQuery Mobile...
86         cd ${JQM_LIB_PATH} && make js NODE=/usr/bin/node || exit 1; \
87         cp -f ${JQM_LIB_PATH}/compiled/*.js ${JQM_LIB_PATH}/../; \
88
89 third_party: init jqm
90         # Building third party components...
91         @@cd ${LIBS_DIR}/js; \
92             for f in ${LIBS_JS_FILES}; do \
93                 cat $$f >> ${FW_LIB_JS}; \
94                 uglifyjs --ascii $$f >> ${FW_LIB_MIN}; \
95                 echo "" >> ${FW_LIB_MIN}; \
96             done; \
97             cp ${LIBS_DIR}/js/${JQUERY} ${JS_OUTPUT_ROOT}/jquery.js
98             cp ${LIBS_DIR}/js/${JQUERY_MIN} ${JS_OUTPUT_ROOT}/jquery.min.js
99         @@cd ${LIBS_DIR}/css; \
100             cp -r images/* ${CSS_IMAGES_OUTPUT_DIR}
101
102 widgets: init third_party
103         # Building widgets...
104         @@ls -l ${WIDGETS_DIR} | grep '^d' | awk '{print $$NF;}' | \
105             while read REPLY; do \
106                 echo "  # Building widget $$REPLY"; \
107                         if test ${JSLINT_LEVEL} -ge 1; then \
108                                 if test $$REPLY != ${COMMON_WIDGET}; then \
109                                         for FNAME in ${WIDGETS_DIR}/$$REPLY/js/*.js; do \
110                                                 ${JSLINT} $$FNAME; \
111                                                 if test ${JSLINT_LEVEL} -ge 2 -a $$? -ne 0; then \
112                                                         exit 1; \
113                                                 fi; \
114                                         done; \
115                                 fi; \
116                         fi; \
117                         if test "x${INLINE_PROTO}x" = "x1x"; then \
118                                 ./tools/inline-protos.sh ${WIDGETS_DIR}/$$REPLY >> ${WIDGETS_DIR}/$$REPLY/js/$$REPLY.js.compiled; \
119                                 cat ${WIDGETS_DIR}/$$REPLY/js/$$REPLY.js.compiled >> ${FW_JS}; \
120                         else \
121                                 for f in `find ${WIDGETS_DIR}/$$REPLY -iname 'js/*.js' | sort`; do \
122                                         echo "          $$f"; \
123                                         cat $$f >> ${FW_JS}; \
124                                 done; \
125             fi; \
126                 for f in `find ${WIDGETS_DIR}/$$REPLY -iname '*.js.theme' | sort`; do \
127                     echo "              $$f"; \
128                     cat $$f >> ${FW_JS_THEME}; \
129                 done; \
130                 for f in `find ${WIDGETS_DIR}/$$REPLY -iname '*.less' | sort`; do \
131                     echo "              $$f"; \
132                     lessc $$f > $$f.css; \
133                 done; \
134                 for f in `find ${WIDGETS_DIR}/$$REPLY -iname '*.css' | sort`; do \
135                     echo "              $$f"; \
136                     cat $$f >> ${FW_CSS}; \
137                 done; \
138                 for f in `find ${WIDGETS_DIR}/$$REPLY -iname '*.gif' -or -iname '*.png' -or -iname '*.jpg' | sort`; do \
139                     echo "              $$f"; \
140                     cp $$f ${CSS_IMAGES_OUTPUT_DIR}; \
141                 done; \
142                 if test "x${INLINE_PROTO}x" != "x1x"; then \
143                   for f in `find ${WIDGETS_DIR}/$$REPLY -iname '*.prototype.html' | sort`; do \
144                       echo "            $$f"; \
145                       cp $$f ${PROTOTYPE_HTML_OUTPUT_DIR}; \
146                   done; \
147                 fi; \
148             done
149
150
151 loader: widgets globalize
152         cat 'src/loader/loader.js' >> ${FW_JS}
153
154
155 globalize: widgets
156         cat 'libs/js/globalize/lib/globalize.js' >> ${FW_JS}
157         # copy globalize libs...
158         cp -a libs/js/globalize/lib/cultures ${FRAMEWORK_ROOT}/js/
159
160
161 themes:
162         make -C src/themes || exit $?
163
164 version: loader themes
165         echo '(function($$){$$.tizen.frameworkData.pkgVersion="$(PKG_VERSION)";}(jQuery));' >> ${FW_JS}
166         echo "$(PKG_VERSION)" > ${FRAMEWORK_ROOT}/../VERSION
167
168 compress: widgets loader themes
169         # Javacript code compressing
170         @@echo "        # Compressing...."; \
171         echo '/*' > ${FW_MIN}; \
172         cat ${COPYING_FILE} >> ${FW_MIN}; \
173         echo '*/' >> ${FW_MIN}; \
174         uglifyjs --ascii -nc ${FW_JS} >> ${FW_MIN}; \
175         # CSS compressing
176         @@cd ${THEME_OUTPUT_ROOT}; \
177         for csspath in */*.css; do \
178                 echo "Compressing $$csspath"; \
179                 cleancss -o $${csspath/%.css/.min.css} $$csspath; \
180         done
181
182
183 docs: init
184         # Building documentation...
185         @@hash docco 2>&1 /dev/null || (echo "docco not found. Please see README."; exit 1); \
186         ls -l ${WIDGETS_DIR} | grep '^d' | awk '{print $$NF;}' | \
187         while read REPLY; do \
188                 echo "  # Building docs for widget $$REPLY"; \
189                 for f in `find ${WIDGETS_DIR}/$$REPLY -iname '*.js' | sort`; do \
190                         docco $$f > /dev/null; \
191                 done; \
192         done; \
193         cp docs/docco.custom.css docs/docco.css; \
194         cat docs/index.header > docs/index.html; \
195         for f in `find docs -name '*.html' -not -name index.html | sort`; do \
196                 echo "<li><a href=\"$$(basename $$f)\">$$(basename $$f .html)</a></li>" >> docs/index.html; \
197         done; \
198         cat docs/index.footer >> docs/index.html
199
200
201 version_compat: third_party widgets
202         # Creating compatible version dirs...
203         for v_compat in ${VERSION_COMPAT}; do \
204                 ln -sf ${VERSION} ${FRAMEWORK_ROOT}/../$$v_compat; \
205         done;
206         ln -sf ${VERSION} ${FRAMEWORK_ROOT}/../latest
207
208 demo: widgets 
209         mkdir -p ${OUTPUT_ROOT}/demos
210         cp -av demos/* ${OUTPUT_ROOT}/demos/
211         cp -f src/template/bootstrap.js ${OUTPUT_ROOT}/demos/gallery/
212
213
214 install: all
215         mkdir -p ${INSTALL_DIR}/bin ${INSTALL_DIR}/share/tizen-web-ui-fw/demos/ ${INSTALL_DIR}/share/tizen-web-ui-fw/bin/
216         cp -av ${OUTPUT_ROOT}/tizen-web-ui-fw/* src/template ${INSTALL_DIR}/share/tizen-web-ui-fw/
217         cp -av tools/* ${INSTALL_DIR}/share/tizen-web-ui-fw/bin/
218         cp -av demos/tizen-winsets ${INSTALL_DIR}/share/tizen-web-ui-fw/demos/ && cd ${INSTALL_DIR}/share/tizen-web-ui-fw/demos/tizen-winsets && sed -i -e "s#../../build#../../..#g" *.html
219
220
221 coverage: clean all
222         # Checking unit test coverage
223         $(CURDIR)/tests/coverage/instrument.sh
224
225
226 dist: clean all docs
227         # Creating tarball...
228         @@ \
229         TMPDIR=$$(mktemp -d tarball.XXXXXXXX); \
230         DESTDIR=$${TMPDIR}/${PROJECT_NAME}; \
231         MIN=''; \
232         if test "x${DEBUG}x" = "xnox"; then \
233                 MIN='.min'; \
234         fi; \
235         TARBALL=${PROJECT_NAME}-${VERSION}-`date +%Y%m%d`$${MIN}.tar.gz; \
236         mkdir -p $${DESTDIR}; \
237         cp -a ${FW_JS} \
238                 ${FW_LIBS_JS} \
239                 ${THEMES_OUTPUT_ROOT}/tizen/${FW_THEME_CSS_FILE} \
240                 ${FW_WIDGET_CSS_FILE} \
241                 ${THEMES_OUTPUT_ROOT}/tizen/images \
242                 docs \
243                 README.md \
244                 COPYING \
245                 $${DESTDIR}; \
246         hash git 2>&1 /dev/null && touch $${DESTDIR}/$$(git log | head -n 1 | awk '{print $$2;}'); \
247         tar cfzps \
248                 $${TARBALL} \
249                 --exclude='.git' \
250                 --exclude='*.less.css' \
251                 --exclude='*.js.compiled' \
252                 --exclude='submodules/jquery-mobile' \
253                 --exclude='${JQUERY}' \
254                 -C $${TMPDIR} ${PROJECT_NAME}; \
255         rm -rf $${TMPDIR}
256
257
258 clean:
259         # Removing destination directory...
260         @@rm -rf ${OUTPUT_ROOT}
261         # Remove generated files...
262         @@rm -f `find . -iname *.less.css`
263         @@rm -f `find . -iname *.js.compiled`
264
265
266 init: clean
267         # Check build environment...
268         @@hash lessc 2>/dev/null || (echo "lessc not found. Please see HACKING."; exit 1); \
269
270         # Initializing...
271         @@mkdir -p ${JS_OUTPUT_ROOT}
272         @@mkdir -p ${THEME_OUTPUT_ROOT}
273         @@mkdir -p ${CSS_OUTPUT_ROOT}
274         @@mkdir -p ${CSS_IMAGES_OUTPUT_DIR}
275         @@mkdir -p ${PROTOTYPE_HTML_OUTPUT_DIR}
276         @@rm -f docs/*.html