unit-test : add page backbutton control test
[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
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 GEO_VERSION = jquery-geo-1.0b2
53
54 LIBS_JS_FILES = jlayout/jquery.sizes.js \
55                                 jlayout/jlayout.border.js \
56                                 jlayout/jlayout.grid.js \
57                                 jlayout/jlayout.flexgrid.js \
58                                 jlayout/jlayout.flow.js \
59                                 jlayout/jquery.jlayout.js \
60                                 jquery.easing.1.3.js \
61                                 jquery.tmpl.js \
62                                 jquery.mobile.js \
63                                 ${GEO_VERSION}/js/jsrender.js \
64                                 ${GEO_VERSION}/js/jquery.mousewheel.js \
65                                 ${GEO_VERSION}/js/jquery.geo.core.js \
66                                 ${GEO_VERSION}/js/jquery.geo.geographics.js \
67                                 ${GEO_VERSION}/js/jquery.geo.geomap.js \
68                                 ${GEO_VERSION}/js/jquery.geo.tiled.js \
69                                 ${GEO_VERSION}/js/jquery.geo.shingled.js \
70                 $(NULL)
71
72 JQUERY_MOBILE_CSS = submodules/jquery-mobile/compiled/jquery.mobile.structure.css \
73                     submodules/jquery-mobile/compiled/jquery.mobile.css \
74                     $(NULL)
75 JQUERY_MOBILE_IMAGES = submodules/jquery-mobile/css/themes/default/images
76
77 JQM_VERSION = jquery-mobile-1.2.0
78 JQM_LIB_PATH = $(CURDIR)/libs/js/${JQM_VERSION}
79
80 JQUERY = jquery-1.8.2.js
81 JQUERY_MIN = $(subst .js,.min.js,$(JQUERY))
82
83 LIBS_CSS_FILES =
84 ifeq (${DEBUG},yes)
85 LIBS_CSS_FILES +=\
86     $(CURDIR)/src/jqm/compiled/jquery.mobile-1.0rc2pre.css \
87     $(NULL)
88 else
89 LIBS_CSS_FILES +=\
90     $(CURDIR)/src/jqm/compiled/jquery.mobile-1.0rc2pre.min.css \
91     $(NULL)
92 endif
93
94
95 all: libs_prepare third_party widgets libs_cleanup loader themes version version_compat compress
96
97 libs_prepare:
98         # Prepare libs/ build...
99         @@test -d ${LIBS_DIR}.bak && rm -rf ${LIBS_DIR} && mv ${LIBS_DIR}.bak ${LIBS_DIR}; \
100         cp -a ${LIBS_DIR} ${LIBS_DIR}.bak
101         for f in `ls ${LIBS_DIR}/patch/*.patch`; do \
102                 cd $(CURDIR); \
103                 echo "Apply patch: $$f";  \
104                 cat $$f | patch -p1 -N; \
105         done; \
106
107 libs_cleanup:
108         # Cleanup libs/ directory...
109         @@rm -rf ${LIBS_DIR} && mv ${LIBS_DIR}.bak ${LIBS_DIR}
110
111 jqm: init
112         # Building jQuery Mobile...
113         cd ${JQM_LIB_PATH} && make js NODE=/usr/bin/node || exit 1; \
114         cp -f ${JQM_LIB_PATH}/compiled/*.js ${JQM_LIB_PATH}/../; \
115
116 third_party: init jqm
117         # Building third party components...
118         @@cd ${LIBS_DIR}/js; \
119             for f in ${LIBS_JS_FILES}; do \
120                 cat $$f >> ${FW_LIB_JS}; \
121                 uglifyjs --ascii $$f >> ${FW_LIB_MIN}; \
122                 echo "" >> ${FW_LIB_MIN}; \
123             done; \
124             cp ${LIBS_DIR}/js/${JQUERY} ${JS_OUTPUT_ROOT}/jquery.js
125             cp ${LIBS_DIR}/js/${JQUERY_MIN} ${JS_OUTPUT_ROOT}/jquery.min.js
126         @@cd ${LIBS_DIR}/css; \
127             for f in ${LIBS_CSS_FILES}; do \
128                 cat $$f >> ${FW_CSS}; \
129             done; \
130             cp -r images/* ${CSS_IMAGES_OUTPUT_DIR}
131
132         #@@cp -a ${LIBS_DIR}/images ${FRAMEWORK_ROOT}/
133
134
135 widgets: init third_party
136         # Building widgets...
137         @@ls -l ${WIDGETS_DIR} | grep '^d' | awk '{print $$NF;}' | \
138             while read REPLY; do \
139                 echo "  # Building widget $$REPLY"; \
140                         if test ${JSLINT_LEVEL} -ge 1; then \
141                                 if test $$REPLY != ${COMMON_WIDGET}; then \
142                                         for FNAME in ${WIDGETS_DIR}/$$REPLY/js/*.js; do \
143                                                 ${JSLINT} $$FNAME; \
144                                                 if test ${JSLINT_LEVEL} -ge 2 -a $$? -ne 0; then \
145                                                         exit 1; \
146                                                 fi; \
147                                         done; \
148                                 fi; \
149                         fi; \
150                         if test "x${INLINE_PROTO}x" = "x1x"; then \
151                                 ./tools/inline-protos.sh ${WIDGETS_DIR}/$$REPLY >> ${WIDGETS_DIR}/$$REPLY/js/$$REPLY.js.compiled; \
152                                 cat ${WIDGETS_DIR}/$$REPLY/js/$$REPLY.js.compiled >> ${FW_JS}; \
153                         else \
154                                 for f in `find ${WIDGETS_DIR}/$$REPLY -iname 'js/*.js' | sort`; do \
155                                         echo "          $$f"; \
156                                         cat $$f >> ${FW_JS}; \
157                                 done; \
158             fi; \
159                 for f in `find ${WIDGETS_DIR}/$$REPLY -iname '*.js.theme' | sort`; do \
160                     echo "              $$f"; \
161                     cat $$f >> ${FW_JS_THEME}; \
162                 done; \
163                 for f in `find ${WIDGETS_DIR}/$$REPLY -iname '*.less' | sort`; do \
164                     echo "              $$f"; \
165                     lessc $$f > $$f.css; \
166                 done; \
167                 for f in `find ${WIDGETS_DIR}/$$REPLY -iname '*.css' | sort`; do \
168                     echo "              $$f"; \
169                     cat $$f >> ${FW_CSS}; \
170                 done; \
171                 for f in `find ${WIDGETS_DIR}/$$REPLY -iname '*.gif' -or -iname '*.png' -or -iname '*.jpg' | sort`; do \
172                     echo "              $$f"; \
173                     cp $$f ${CSS_IMAGES_OUTPUT_DIR}; \
174                 done; \
175                 if test "x${INLINE_PROTO}x" != "x1x"; then \
176                   for f in `find ${WIDGETS_DIR}/$$REPLY -iname '*.prototype.html' | sort`; do \
177                       echo "            $$f"; \
178                       cp $$f ${PROTOTYPE_HTML_OUTPUT_DIR}; \
179                   done; \
180                 fi; \
181             done
182
183
184 loader: widgets globalize
185         cat 'src/loader/loader.js' >> ${FW_JS}
186
187
188 globalize: widgets
189         cat 'libs/js/globalize/lib/globalize.js' >> ${FW_JS}
190         # copy globalize libs...
191         cp -a libs/js/globalize/lib/cultures ${FRAMEWORK_ROOT}/js/
192
193
194 themes:
195         make -C src/themes || exit $?
196
197 version: loader themes
198         echo '(function($$){$$.tizen.frameworkData.pkgVersion="$(PKG_VERSION)";}(jQuery));' >> ${FW_JS}
199         echo "$(PKG_VERSION)" > ${FRAMEWORK_ROOT}/../VERSION
200
201 compress: widgets loader themes
202         # Javacript code compressing
203         @@echo "        # Compressing...."; \
204         echo '/*' > ${FW_MIN}; \
205         cat ${COPYING_FILE} >> ${FW_MIN}; \
206         echo '*/' >> ${FW_MIN}; \
207         uglifyjs --ascii -nc ${FW_JS} >> ${FW_MIN}; \
208         # CSS compressing
209         @@cd ${THEME_OUTPUT_ROOT}; \
210         for csspath in */*.css; do \
211                 echo "Compressing $$csspath"; \
212                 cleancss -o $${csspath/%.css/.min.css} $$csspath; \
213         done
214
215
216 docs: init
217         # Building documentation...
218         @@hash docco 2>&1 /dev/null || (echo "docco not found. Please see README."; exit 1); \
219         ls -l ${WIDGETS_DIR} | grep '^d' | awk '{print $$NF;}' | \
220         while read REPLY; do \
221                 echo "  # Building docs for widget $$REPLY"; \
222                 for f in `find ${WIDGETS_DIR}/$$REPLY -iname '*.js' | sort`; do \
223                         docco $$f > /dev/null; \
224                 done; \
225         done; \
226         cp docs/docco.custom.css docs/docco.css; \
227         cat docs/index.header > docs/index.html; \
228         for f in `find docs -name '*.html' -not -name index.html | sort`; do \
229                 echo "<li><a href=\"$$(basename $$f)\">$$(basename $$f .html)</a></li>" >> docs/index.html; \
230         done; \
231         cat docs/index.footer >> docs/index.html
232
233
234 version_compat: third_party widgets
235         # Creating compatible version dirs...
236         for v_compat in ${VERSION_COMPAT}; do \
237                 ln -sf ${VERSION} ${FRAMEWORK_ROOT}/../$$v_compat; \
238         done;
239         ln -sf ${VERSION} ${FRAMEWORK_ROOT}/../latest
240
241 demo: widgets 
242         mkdir -p ${OUTPUT_ROOT}/demos
243         cp -av demos/* ${OUTPUT_ROOT}/demos/
244         cp -f src/template/bootstrap.js ${OUTPUT_ROOT}/demos/gallery/
245
246
247 install: all
248         mkdir -p ${INSTALL_DIR}/bin ${INSTALL_DIR}/share/tizen-web-ui-fw/demos/ ${INSTALL_DIR}/share/tizen-web-ui-fw/bin/
249         cp -av ${OUTPUT_ROOT}/tizen-web-ui-fw/* src/template ${INSTALL_DIR}/share/tizen-web-ui-fw/
250         cp -av tools/* ${INSTALL_DIR}/share/tizen-web-ui-fw/bin/
251         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
252
253
254 coverage: clean all
255         # Checking unit test coverage
256         $(CURDIR)/tests/coverage/instrument.sh
257
258
259 dist: clean all docs
260         # Creating tarball...
261         @@ \
262         TMPDIR=$$(mktemp -d tarball.XXXXXXXX); \
263         DESTDIR=$${TMPDIR}/${PROJECT_NAME}; \
264         MIN=''; \
265         if test "x${DEBUG}x" = "xnox"; then \
266                 MIN='.min'; \
267         fi; \
268         TARBALL=${PROJECT_NAME}-${VERSION}-`date +%Y%m%d`$${MIN}.tar.gz; \
269         mkdir -p $${DESTDIR}; \
270         cp -a ${FW_JS} \
271                 ${FW_LIBS_JS} \
272                 ${THEMES_OUTPUT_ROOT}/tizen/${FW_THEME_CSS_FILE} \
273                 ${FW_WIDGET_CSS_FILE} \
274                 ${THEMES_OUTPUT_ROOT}/tizen/images \
275                 docs \
276                 README.md \
277                 COPYING \
278                 $${DESTDIR}; \
279         hash git 2>&1 /dev/null && touch $${DESTDIR}/$$(git log | head -n 1 | awk '{print $$2;}'); \
280         tar cfzps \
281                 $${TARBALL} \
282                 --exclude='.git' \
283                 --exclude='*.less.css' \
284                 --exclude='*.js.compiled' \
285                 --exclude='submodules/jquery-mobile' \
286                 --exclude='${JQUERY}' \
287                 -C $${TMPDIR} ${PROJECT_NAME}; \
288         rm -rf $${TMPDIR}
289
290
291 clean:
292         # Removing destination directory...
293         @@rm -rf ${OUTPUT_ROOT}
294         # Remove generated files...
295         @@rm -f `find . -iname *.less.css`
296         @@rm -f `find . -iname *.js.compiled`
297
298
299 init: clean
300         # Check build environment...
301         @@hash lessc 2>/dev/null || (echo "lessc not found. Please see HACKING."; exit 1); \
302
303         # Initializing...
304         @@mkdir -p ${JS_OUTPUT_ROOT}
305         @@mkdir -p ${THEME_OUTPUT_ROOT}
306         @@mkdir -p ${CSS_OUTPUT_ROOT}
307         @@mkdir -p ${CSS_IMAGES_OUTPUT_DIR}
308         @@mkdir -p ${PROTOTYPE_HTML_OUTPUT_DIR}
309         @@rm -f docs/*.html