9c6c64571f338c62d57b5771c449526aa44b9fb1
[scm/bb/meta-tizen.git] / recipes-tizen / libprivilege-control / libprivilege-control.inc
1 DESCRIPTION = "Library to control privilege of application"
2 HOMEPAGE = "http://nohomepage.org"
3 SECTION = "Security/Access Control"
4 LICENSE = "Apache-2.0"
5
6 SRC_URI = ""
7
8 S = "${WORKDIR}/git"
9
10 inherit autotools-brokensep
11
12 PROVIDES = ""
13
14 #PROVIDES by libprivilege-control 
15
16
17 #PROVIDES by libprivilege-control-conf 
18
19
20 #PROVIDES by libprivilege-control-dev 
21
22
23 RDEPENDS = ""
24 #RDEPENDS of libprivilege-control-conf (${PN}-conf)
25 RDEPENDS_${PN}-conf += "libprivilege-control"
26
27 #RDEPENDS of libprivilege-control-dev (${PN}-dev)
28 RDEPENDS_${PN}-dev += "libprivilege-control"
29
30
31 DEPENDS = ""
32 #DEPENDS of libprivilege-control 
33 DEPENDS_append_class-native = " cmake-native"
34 DEPENDS_append_class-target = " cmake-native"
35 DEPENDS += "dlog"
36 DEPENDS += "libiri"
37 DEPENDS += "smack"
38 DEPENDS += "sqlite3"
39 DEPENDS += "libcap"
40
41 do_prep() {
42  cd ${S}
43  chmod -Rf a+rX,u+w,g-w,o-w ${S}
44  #setup -q
45  cp ${S}/packaging/libprivilege-control.manifest .
46  
47  
48 }
49 do_patch_append() {
50     bb.build.exec_func('do_prep', d)
51 }
52
53 do_configure() {
54 }
55
56 do_compile() {
57  cd ${S}
58  LANG=C
59  export LANG
60  unset DISPLAY
61  CFLAGS="-O2 -g -m64 -fmessage-length=0 -D_FORTIFY_SOURCE=2 -fstack-protector -funwind-tables -fasynchronous-unwind-tables" ; export CFLAGS ; 
62  CXXFLAGS="${CXXFLAGS:--O2 -g -m64 -fmessage-length=0 -D_FORTIFY_SOURCE=2 -fstack-protector -funwind-tables -fasynchronous-unwind-tables}" ; export CXXFLAGS ; 
63  FFLAGS="${FFLAGS:--O2 -g -m64 -fmessage-length=0 -D_FORTIFY_SOURCE=2 -fstack-protector -funwind-tables -fasynchronous-unwind-tables -I%_fmoddir}" ; export FFLAGS ; 
64  LD_AS_NEEDED=1; export LD_AS_NEEDED ; 
65  
66  
67  export CFLAGS="${CFLAGS} -Wno-implicit-function-declaration"
68  
69    CFLAGS="${CFLAGS:--O2 -g -m64 -fmessage-length=0 -D_FORTIFY_SOURCE=2 -fstack-protector -funwind-tables -fasynchronous-unwind-tables}" ; export CFLAGS ; 
70    CXXFLAGS="${CXXFLAGS:--O2 -g -m64 -fmessage-length=0 -D_FORTIFY_SOURCE=2 -fstack-protector -funwind-tables -fasynchronous-unwind-tables}" ; export CXXFLAGS ; 
71    FFLAGS="${FFLAGS:--O2 -g -m64 -fmessage-length=0 -D_FORTIFY_SOURCE=2 -fstack-protector -funwind-tables -fasynchronous-unwind-tables}" ; export FFLAGS ; 
72    cmake \
73          -DCMAKE_VERBOSE_MAKEFILE=ON \
74          -DCMAKE_INSTALL_PREFIX:PATH=${prefix} \
75          -DCMAKE_INSTALL_LIBDIR:PATH=${prefix}/lib \
76          -DINCLUDE_INSTALL_DIR:PATH=${prefix}/include \
77          -DLIB_INSTALL_DIR:PATH=${prefix}/lib \
78          -DSYSCONF_INSTALL_DIR:PATH=${sysconfdir} \
79          -DSHARE_INSTALL_PREFIX:PATH=${prefix}/share \
80          -DCMAKE_SKIP_RPATH:BOOL=ON \
81          -DBUILD_SHARED_LIBS:BOOL=ON . -DCMAKE_BUILD_TYPE=RELEASE \
82           -DCMAKE_VERBOSE_MAKEFILE=ON
83  
84  VERBOSE=1 make -j16
85  
86  
87  
88 }
89
90 do_install() {
91  echo export RPM_BUILD_ROOT=${D}
92  cd ${S}
93  LANG=C
94  export LANG
95  unset DISPLAY
96  rm -rf ${D} 
97  mkdir -p ${D} 
98  
99  
100    oe_runmake \
101          DESTDIR=${D} \
102          INSTALL_ROOT=${D} \
103          BINDIR=${prefix}/bin \
104    install  
105    rm -f ${D}${infodir}/dir 
106    find ${D} -regex ".*\.la$" | xargs rm -f -- 
107    find ${D} -regex ".*\.a$" | xargs rm -f --
108  mkdir -p ${D}/usr/share/privilege-control/
109  
110  mkdir -p ${D}/usr/lib/systemd/system/multi-user.target.wants
111  ln -sf /usr/lib/systemd/system/smack-rules.service ${D}/usr/lib/systemd/system/multi-user.target.wants/smack-rules.service
112  mkdir -p ${D}/opt/dbspace
113  
114  
115 }
116
117 PACKAGES += " libprivilege-control-conf "
118
119 libprivilege-control_files = ""
120 libprivilege-control_files += "libprivilege-control.manifest"
121 libprivilege-control_files += "${prefix}/lib/*.so.*"
122 libprivilege-control_files += "${prefix}/bin/slp-su"
123 libprivilege-control_files += "${prefix}/lib/librules-db-sql-udf.so"
124 libprivilege-control_files += "/usr/lib/systemd/system/smack-rules.service"
125 libprivilege-control_files += "/usr/bin/api_feature_loader"
126 libprivilege-control_files += "/usr/lib/systemd/system/multi-user.target.wants/smack-rules.service"
127 libprivilege-control_files += "/usr/share/privilege-control/db/rules-db.sql"
128 libprivilege-control_files += "/usr/share/privilege-control/db/rules-db-data.sql"
129 libprivilege-control_files += "/usr/share/privilege-control/db/updater.sh"
130 libprivilege-control_files += "/usr/share/privilege-control/db/updates/*"
131 libprivilege-control_files += "/usr/share/privilege-control/db/load-rules-db.sql"
132 libprivilege-control_files += "/etc/opt/upgrade/220.libprivilege-updater.patch.sh"
133 libprivilege-control_files += "%dir /opt/dbspace"
134
135 libprivilege-control-conf_files = ""
136 libprivilege-control-conf_files += "libprivilege-control.manifest"
137 libprivilege-control-conf_files += "/opt/dbspace/.privilege_control*.db"
138
139 libprivilege-control-dev_files = ""
140 libprivilege-control-dev_files += "libprivilege-control.manifest"
141 libprivilege-control-dev_files += "${prefix}/include/*.h"
142 libprivilege-control-dev_files += "${prefix}/lib/*.so"
143 libprivilege-control-dev_files += "${prefix}/lib/pkgconfig/*.pc"
144
145 FILES_${PN} = "${libprivilege-control_files}"
146 FILES_${PN}-conf = "${libprivilege-control-conf_files}"
147 FILES_${PN}-dev = "${libprivilege-control-dev_files}"
148
149 PKG_libprivilege-control= "libprivilege-control"
150 PKG_libprivilege-control-conf= "libprivilege-control-conf"
151 PKG_libprivilege-control-dev= "libprivilege-control-dev"
152
153 require libprivilege-control-extraconf.inc
154