/[gentoo-x86]/eclass/linux-mod.eclass
Gentoo

Diff of /eclass/linux-mod.eclass

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

Revision 1.39 Revision 1.54
1# Copyright 1999-2004 Gentoo Foundation 1# Copyright 1999-2004 Gentoo Foundation
2# Distributed under the terms of the GNU General Public License v2 2# Distributed under the terms of the GNU General Public License v2
3# $Header: /var/cvsroot/gentoo-x86/eclass/linux-mod.eclass,v 1.39 2005/06/30 08:58:55 brix Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/linux-mod.eclass,v 1.54 2005/10/22 17:35:39 johnm Exp $
4 4
5# Description: This eclass is used to interface with linux-info in such a way 5# Description: This eclass is used to interface with linux-info in such a way
6# to provide the functionality required and initial functions 6# to provide the functionality required and initial functions
7# required to install external modules against a kernel source 7# required to install external modules against a kernel source
8# tree. 8# tree.
12# 12#
13# Please direct your bugs to the current eclass maintainer :) 13# Please direct your bugs to the current eclass maintainer :)
14 14
15# A Couple of env vars are available to effect usage of this eclass 15# A Couple of env vars are available to effect usage of this eclass
16# These are as follows: 16# These are as follows:
17# 17#
18# Env Var Option Default Description 18# Env Var Option Default Description
19# KERNEL_DIR <string> /usr/src/linux The directory containing kernel 19# KERNEL_DIR <string> /usr/src/linux The directory containing kernel
20# the target kernel sources. 20# the target kernel sources.
21# ECONF_PARAMS <string> The parameters to pass to econf. 21# ECONF_PARAMS <string> The parameters to pass to econf.
22# If this is not set, then econf 22# If this is not set, then econf
23# isn't run. 23# isn't run.
24# BUILD_PARAMS <string> The parameters to pass to emake. 24# BUILD_PARAMS <string> The parameters to pass to emake.
25# BUILD_TARGETS <string> clean modules The build targets to pass to 25# BUILD_TARGETS <string> clean modules The build targets to pass to
26# make. 26# make.
27# MODULE_NAMES <string> This is the modules which are 27# MODULE_NAMES <string> This is the modules which are
28# to be built automatically using 28# to be built automatically using
29# the default pkg_compile/install. 29# the default pkg_compile/install.
30# They are explained properly 30# They are explained properly
31# below. It will only make 31# below. It will only make
32# BUILD_TARGETS once in any 32# BUILD_TARGETS once in any
33# directory. 33# directory.
34 34
35# MODULE_NAMES - Detailed Overview 35# MODULE_NAMES - Detailed Overview
36# 36#
37# The structure of each MODULE_NAMES entry is as follows: 37# The structure of each MODULE_NAMES entry is as follows:
38# modulename(libdir:srcdir:objdir) 38# modulename(libdir:srcdir:objdir)
39# for example: 39# for example:
40# MODULE_NAMES="module_pci(pci:${S}/pci:${S}) module_usb(usb:${S}/usb:${S})" 40# MODULE_NAMES="module_pci(pci:${S}/pci:${S}) module_usb(usb:${S}/usb:${S})"
41# 41#
42# what this would do is 42# what this would do is
43# cd ${S}/pci 43# cd ${S}/pci
44# make ${BUILD_PARAMS} ${BUILD_TARGETS} 44# make ${BUILD_PARAMS} ${BUILD_TARGETS}
45# cd ${S} 45# cd ${S}
46# insinto /lib/modules/${KV_FULL}/pci 46# insinto /lib/modules/${KV_FULL}/pci
78# the full path to any associated 78# the full path to any associated
79# documents for $modulename 79# documents for $modulename
80 80
81 81
82inherit linux-info 82inherit linux-info
83ECLASS=linux-mod
84INHERITED="$INHERITED $ECLASS"
85EXPORT_FUNCTIONS pkg_setup pkg_postinst src_install src_compile pkg_postrm 83EXPORT_FUNCTIONS pkg_setup pkg_postinst src_install src_compile pkg_postrm
86 84
87IUSE="${IUSE}" 85IUSE="" # don't put pcmcia here, rather in the ebuilds that actually support pcmcia
88SLOT="0" 86SLOT="0"
89DESCRIPTION="Based on the $ECLASS eclass" 87DESCRIPTION="Based on the $ECLASS eclass"
88RDEPEND="virtual/modutils
89 pcmcia? ( virtual/pcmcia )"
90DEPEND="virtual/linux-sources 90DEPEND="virtual/linux-sources
91 sys-apps/sed 91 sys-apps/sed
92 virtual/modutils
93 pcmcia? ( virtual/pcmcia )" 92 pcmcia? ( virtual/pcmcia )"
94 93
95# eclass utilities 94# eclass utilities
96# ---------------------------------- 95# ----------------------------------
96
97check_vermagic() {
98 local curr_gcc_ver=$(gcc -dumpversion)
99 local tmpfile old_chost old_gcc_ver result=0
100
101 tmpfile=`find ${KV_DIR}/ -iname "*.o.cmd" -exec grep usr/lib/gcc {} \; -quit`
102 tmpfile=${tmpfile//*usr/lib}
103 tmpfile=${tmpfile//\/include*}
104 old_chost=${tmpfile//*gcc\/}
105 old_chost=${old_chost//\/*}
106 old_gcc_ver=${tmpfile//*\/}
107
108 if [[ -z ${old_gcc_ver} || -z ${old_chost} ]]; then
109 ewarn ""
110 ewarn "Unable to detect what version of GCC was used to compile"
111 ewarn "the kernel. Build will continue, but you may experience problems."
112 elif [[ ${curr_gcc_ver} != ${old_gcc_ver} ]]; then
113 ewarn ""
114 ewarn "The version of GCC you are using (${curr_gcc_ver}) does"
115 ewarn "not match the version of GCC used to compile the"
116 ewarn "kernel (${old_gcc_ver})."
117 result=1
118 elif [[ ${CHOST} != ${old_chost} ]]; then
119 ewarn ""
120 ewarn "The current CHOST (${CHOST}) does not match the chost"
121 ewarn "used when compiling the kernel (${old_chost})."
122 result=1
123 fi
124
125 if [[ ${result} -gt 0 ]]; then
126 ewarn ""
127 ewarn "Build will not continue, because you will experience problems."
128 ewarn "To fix this either change the version of GCC you wish to use"
129 ewarn "to match the kernel, or recompile the kernel first."
130 die "GCC Version Mismatch."
131 fi
132}
97 133
98unpack_pcmcia_sources() { 134unpack_pcmcia_sources() {
99 # So while the two eclasses exist side-by-side and also the ebuilds inherit 135 # So while the two eclasses exist side-by-side and also the ebuilds inherit
100 # both we need to check for PCMCIA_SOURCE_DIR, and if we find it, then we 136 # both we need to check for PCMCIA_SOURCE_DIR, and if we find it, then we
101 # bail out and assume pcmcia.eclass is working on it. 137 # bail out and assume pcmcia.eclass is working on it.
102 [[ -n ${PCMCIA_SOURCE_DIR} ]] && return 1 138 [[ -n ${PCMCIA_SOURCE_DIR} ]] && return 1
103 139
104 if [[ -f "${1}" ]]; then 140 if [[ -f "${1}" ]]; then
105 PCMCIA_SOURCE_DIR="${WORKDIR}/pcmcia-cs/" 141 PCMCIA_SOURCE_DIR="${WORKDIR}/pcmcia-cs/"
106 142
107 ebegin "Decompressing pcmcia-cs sources" 143 ebegin "Decompressing pcmcia-cs sources"
108 mkdir -p ${PCMCIA_SOURCE_DIR} 144 mkdir -p ${PCMCIA_SOURCE_DIR}
109 tar -xjf ${1} -C ${PCMCIA_SOURCE_DIR} 145 tar -xjf ${1} -C ${PCMCIA_SOURCE_DIR}
110 eend $? 146 eend $?
111 147
141} 177}
142 178
143use_m() { 179use_m() {
144 # if we haven't determined the version yet, we need too. 180 # if we haven't determined the version yet, we need too.
145 get_version; 181 get_version;
146 182
147 # if the kernel version is greater than 2.6.6 then we should use 183 # if the kernel version is greater than 2.6.6 then we should use
148 # M= instead of SUBDIRS= 184 # M= instead of SUBDIRS=
149 [ ${KV_MAJOR} -eq 2 -a ${KV_MINOR} -gt 5 -a ${KV_PATCH} -gt 5 ] && \ 185 [ ${KV_MAJOR} -eq 2 -a ${KV_MINOR} -gt 5 -a ${KV_PATCH} -gt 5 ] && \
150 return 0 || return 1 186 return 0 || return 1
151} 187}
162} 198}
163 199
164update_depmod() { 200update_depmod() {
165 # if we haven't determined the version yet, we need too. 201 # if we haven't determined the version yet, we need too.
166 get_version; 202 get_version;
167 203
168 ebegin "Updating module dependencies for ${KV_FULL}" 204 ebegin "Updating module dependencies for ${KV_FULL}"
169 if [ -r ${KV_OUT_DIR}/System.map ] 205 if [ -r ${KV_OUT_DIR}/System.map ]
170 then 206 then
171 depmod -ae -F ${KV_OUT_DIR}/System.map -b ${ROOT} -r ${KV_FULL} 207 depmod -ae -F ${KV_OUT_DIR}/System.map -b ${ROOT} -r ${KV_FULL}
172 eend $? 208 eend $?
186 /sbin/modules-update 222 /sbin/modules-update
187 eend $? 223 eend $?
188 fi 224 fi
189} 225}
190 226
227move_old_moduledb() {
228 local OLDDIR=${ROOT}/usr/share/module-rebuild/
229 local NEWDIR=${ROOT}/var/lib/module-rebuild/
230
231 if [[ -f ${OLDDIR}/moduledb ]]; then
232 [[ ! -d ${NEWDIR} ]] && mkdir -p ${NEWDIR}
233 [[ ! -f ${NEWDIR}/moduledb ]] && \
234 mv ${OLDDIR}/moduledb ${NEWDIR}/moduledb
235 rm -f ${OLDDIR}/*
236 rmdir ${OLDDIR}
237 fi
238}
239
191update_moduledb() { 240update_moduledb() {
192 if [[ ! -f ${ROOT}/usr/share/module-rebuild/moduledb ]]; then 241 local MODULEDB_DIR=${ROOT}/var/lib/module-rebuild/
193 [[ ! -d ${ROOT}/usr/share/module-rebuild/ ]] && mkdir ${ROOT}/usr/share/module-rebuild/ 242 move_old_moduledb
194 touch ${ROOT}/usr/share/module-rebuild/moduledb 243
244 if [[ ! -f ${MODULEDB_DIR}/moduledb ]]; then
245 [[ ! -d ${MODULEDB_DIR} ]] && mkdir -p ${MODULEDB_DIR}
246 touch ${MODULEDB_DIR}/moduledb
195 fi 247 fi
196 if [[ -z $(grep ${CATEGORY}/${PN}-${PVR} ${ROOT}/usr/share/module-rebuild/moduledb) ]]; then 248 if [[ -z $(grep ${CATEGORY}/${PN}-${PVR} ${MODULEDB_DIR}/moduledb) ]]; then
197 einfo "Adding module to moduledb." 249 einfo "Adding module to moduledb."
198 echo "a:1:${CATEGORY}/${PN}-${PVR}" >> ${ROOT}/usr/share/module-rebuild/moduledb 250 echo "a:1:${CATEGORY}/${PN}-${PVR}" >> ${MODULEDB_DIR}/moduledb
199 fi 251 fi
200} 252}
201 253
202remove_moduledb() { 254remove_moduledb() {
255 local MODULEDB_DIR=${ROOT}/var/lib/module-rebuild/
256 move_old_moduledb
257
203 if [[ -n $(grep ${CATEGORY}/${PN}-${PVR} ${ROOT}/usr/share/module-rebuild/moduledb) ]]; then 258 if [[ -n $(grep ${CATEGORY}/${PN}-${PVR} ${MODULEDB_DIR}/moduledb) ]]; then
204 einfo "Removing ${CATEGORY}/${PN}-${PVR} from moduledb." 259 einfo "Removing ${CATEGORY}/${PN}-${PVR} from moduledb."
205 sed -ie "/.*${CATEGORY}\/${P}.*/d" ${ROOT}/usr/share/module-rebuild/moduledb 260 sed -ie "/.*${CATEGORY}\/${P}.*/d" ${MODULEDB_DIR}/moduledb
206 fi 261 fi
207} 262}
208 263
209set_kvobj() { 264set_kvobj() {
210 if kernel_is 2 6 265 if kernel_is 2 6
220 275
221generate_modulesd() { 276generate_modulesd() {
222 # This function will generate the neccessary modules.d file from the 277 # This function will generate the neccessary modules.d file from the
223 # information contained in the modules exported parms 278 # information contained in the modules exported parms
224 279
225 local currm_path currm t myIFS myVAR 280 local currm_path currm currm_t t myIFS myVAR
226 local module_docs module_enabled module_aliases \ 281 local module_docs module_enabled module_aliases \
227 module_additions module_examples module_modinfo module_opts 282 module_additions module_examples module_modinfo module_opts
228 283
229 for currm_path in ${@} 284 for currm_path in ${@}
230 do 285 do
231 currm=${currm_path//*\/} 286 currm=${currm_path//*\/}
232 currm=$(echo ${currm} | tr '[:lower:]' '[:upper:]') 287 currm=$(echo ${currm} | tr '[:lower:]' '[:upper:]')
288 currm_t=${currm}
289 while [[ -z ${currm_t//*-*} ]]; do
290 currm_t=${currm_t/-/_}
291 done
233 292
234 module_docs="$(eval echo \${MODULESD_${currm}_DOCS})" 293 module_docs="$(eval echo \${MODULESD_${currm_t}_DOCS})"
235 module_enabled="$(eval echo \${MODULESD_${currm}_ENABLED})" 294 module_enabled="$(eval echo \${MODULESD_${currm_t}_ENABLED})"
236 module_aliases="$(eval echo \${#MODULESD_${currm/-/_}_ALIASES[*]})" 295 module_aliases="$(eval echo \${#MODULESD_${currm_t}_ALIASES[*]})"
237 module_additions="$(eval echo \${#MODULESD_${currm/-/_}_ADDITIONS[*]})" 296 module_additions="$(eval echo \${#MODULESD_${currm_t}_ADDITIONS[*]})"
238 module_examples="$(eval echo \${#MODULESD_${currm/-/_}_EXAMPLES[*]})" 297 module_examples="$(eval echo \${#MODULESD_${currm_t}_EXAMPLES[*]})"
239 298
240 [[ ${module_aliases} -eq 0 ]] && unset module_aliases 299 [[ ${module_aliases} -eq 0 ]] && unset module_aliases
241 [[ ${module_additions} -eq 0 ]] && unset module_additions 300 [[ ${module_additions} -eq 0 ]] && unset module_additions
242 [[ ${module_examples} -eq 0 ]] && unset module_examples 301 [[ ${module_examples} -eq 0 ]] && unset module_examples
243 302
244 # If we specify we dont want it, then lets exit, otherwise we assume 303 # If we specify we dont want it, then lets exit, otherwise we assume
245 # that if its set, we do want it. 304 # that if its set, we do want it.
246 [[ ${module_enabled} == no ]] && return 0 305 [[ ${module_enabled} == no ]] && return 0
247 306
248 # unset any unwanted variables. 307 # unset any unwanted variables.
249 for t in ${!module_*} 308 for t in ${!module_*}
290 echo >> ${module_config} 349 echo >> ${module_config}
291 echo "# Configurable module parameters" >> ${module_config} 350 echo "# Configurable module parameters" >> ${module_config}
292 echo "# ------------------------------" >> ${module_config} 351 echo "# ------------------------------" >> ${module_config}
293 myIFS="${IFS}" 352 myIFS="${IFS}"
294 IFS="$(echo -en "\n\b")" 353 IFS="$(echo -en "\n\b")"
295 354
296 for t in ${module_modinfo} 355 for t in ${module_modinfo}
297 do 356 do
298 myVAR="$(echo ${t#*:} | grep -e " [0-9][ =]" | sed "s:.*\([01][= ]\).*:\1:")" 357 myVAR="$(echo ${t#*:} | grep -e " [0-9][ =]" | sed "s:.*\([01][= ]\).*:\1:")"
299 if [[ -n ${myVAR} ]] 358 if [[ -n ${myVAR} ]]
300 then 359 then
301 module_opts="${module_opts} ${t%%:*}:${myVAR}" 360 module_opts="${module_opts} ${t%%:*}:${myVAR}"
302 fi 361 fi
303 echo -e "# ${t%%:*}:\t${t#*:}" >> ${module_config} 362 echo -e "# ${t%%:*}:\t${t#*:}" >> ${module_config}
304 done 363 done
305 IFS="${myIFS}" 364 IFS="${myIFS}"
306 echo '' >> ${module_config} 365 echo '' >> ${module_config}
307 fi 366 fi
308 367
309 #----------------------------------------------------------------------- 368 #-----------------------------------------------------------------------
340 echo "$(eval echo \${MODULESD_${currm}_ADDITIONS[$t]})" \ 399 echo "$(eval echo \${MODULESD_${currm}_ADDITIONS[$t]})" \
341 >> ${module_config} 400 >> ${module_config}
342 done 401 done
343 echo '' >> ${module_config} 402 echo '' >> ${module_config}
344 fi 403 fi
345 404
346 #----------------------------------------------------------------------- 405 #-----------------------------------------------------------------------
347 406
348 # then we install it 407 # then we install it
349 insinto /etc/modules.d 408 insinto /etc/modules.d
350 newins ${module_config} ${currm_path//*\/} 409 newins ${module_config} ${currm_path//*\/}
354 done 413 done
355 eend 0 414 eend 0
356 return 0 415 return 0
357} 416}
358 417
359display_postinst() {
360 # if we haven't determined the version yet, we need too.
361 get_version;
362
363 local modulename moduledir sourcedir moduletemp file i
364
365 file=${ROOT}/etc/modules.autoload.d/kernel-${KV_MAJOR}.${KV_MINOR}
366 file=${file/\/\///}
367
368 for i in ${MODULE_IGNORE}
369 do
370 MODULE_NAMES=${MODULE_NAMES//${i}(*}
371 done
372
373 if [[ -n ${MODULE_NAMES} ]]
374 then
375 einfo "If you would like to load this module automatically upon boot"
376 einfo "please type the following as root:"
377 for i in ${MODULE_NAMES}
378 do
379 unset libdir srcdir objdir
380 for n in $(find_module_params ${i})
381 do
382 eval ${n/:*}=${n/*:/}
383 done
384 einfo " # echo \"${modulename}\" >> ${file}"
385 done
386 einfo
387 fi
388}
389
390find_module_params() { 418find_module_params() {
391 local matched_offset=0 matched_opts=0 test="${@}" temp_var result 419 local matched_offset=0 matched_opts=0 test="${@}" temp_var result
392 local i=0 y=0 z=0 420 local i=0 y=0 z=0
393 421
394 for((i=0; i<=${#test}; i++)) 422 for((i=0; i<=${#test}; i++))
395 do 423 do
396 case ${test:${i}:1} in 424 case ${test:${i}:1} in
397 \() matched_offset[0]=${i};; 425 \() matched_offset[0]=${i};;
398 \:) matched_opts=$((${matched_opts} + 1)); 426 \:) matched_opts=$((${matched_opts} + 1));
399 matched_offset[${matched_opts}]="${i}";; 427 matched_offset[${matched_opts}]="${i}";;
400 \)) matched_opts=$((${matched_opts} + 1)); 428 \)) matched_opts=$((${matched_opts} + 1));
401 matched_offset[${matched_opts}]="${i}";; 429 matched_offset[${matched_opts}]="${i}";;
402 esac 430 esac
403 done 431 done
404 432
405 for((i=0; i<=${matched_opts}; i++)) 433 for((i=0; i<=${matched_opts}; i++))
406 do 434 do
407 # i = offset were working on 435 # i = offset were working on
408 # y = last offset 436 # y = last offset
409 # z = current offset - last offset 437 # z = current offset - last offset
413 *) y=$((${matched_offset[$((${i} - 1))]} + 1)) 441 *) y=$((${matched_offset[$((${i} - 1))]} + 1))
414 z=$((${matched_offset[${i}]} - ${matched_offset[$((${i} - 1))]})); 442 z=$((${matched_offset[${i}]} - ${matched_offset[$((${i} - 1))]}));
415 z=$((${z} - 1)) 443 z=$((${z} - 1))
416 tempvar=${test:${y}:${z}};; 444 tempvar=${test:${y}:${z}};;
417 esac 445 esac
418 446
419 case ${i} in 447 case ${i} in
420 0) result="${result} modulename:${tempvar}";; 448 0) result="${result} modulename:${tempvar}";;
421 1) result="${result} libdir:${tempvar}";; 449 1) result="${result} libdir:${tempvar}";;
422 2) result="${result} srcdir:${tempvar}";; 450 2) result="${result} srcdir:${tempvar}";;
423 3) result="${result} objdir:${tempvar}";; 451 3) result="${result} objdir:${tempvar}";;
424 esac 452 esac
425 done 453 done
426 454
427 echo ${result} 455 echo ${result}
428} 456}
429 457
430# default ebuild functions 458# default ebuild functions
431# -------------------------------- 459# --------------------------------
433linux-mod_pkg_setup() { 461linux-mod_pkg_setup() {
434 linux-info_pkg_setup; 462 linux-info_pkg_setup;
435 check_kernel_built; 463 check_kernel_built;
436 check_modules_supported; 464 check_modules_supported;
437 set_kvobj; 465 set_kvobj;
466 check_vermagic;
438} 467}
439 468
440linux-mod_src_compile() { 469linux-mod_src_compile() {
441 local modulename libdir srcdir objdir i n myARCH="${ARCH}" 470 local modulename libdir srcdir objdir i n myARCH="${ARCH}"
442 unset ARCH 471 ARCH="$(tc-arch-kernel)"
443 472
444 BUILD_TARGETS=${BUILD_TARGETS:-clean module} 473 BUILD_TARGETS=${BUILD_TARGETS:-clean module}
445 474
446 for i in ${MODULE_IGNORE} 475 for i in ${MODULE_IGNORE}
447 do 476 do
448 MODULE_NAMES=${MODULE_NAMES//${i}(*} 477 MODULE_NAMES=${MODULE_NAMES//${i}(*}
449 done 478 done
450 479
456 eval ${n/:*}=${n/*:/} 485 eval ${n/:*}=${n/*:/}
457 done 486 done
458 libdir=${libdir:-misc} 487 libdir=${libdir:-misc}
459 srcdir=${srcdir:-${S}} 488 srcdir=${srcdir:-${S}}
460 objdir=${objdir:-${srcdir}} 489 objdir=${objdir:-${srcdir}}
461 490
462 if [ ! -f "${srcdir}/.built" ]; 491 if [ ! -f "${srcdir}/.built" ];
463 then 492 then
464 cd ${srcdir} 493 cd ${srcdir}
465 einfo "Preparing ${modulename} module" 494 einfo "Preparing ${modulename} module"
466 if [[ -n ${ECONF_PARAMS} ]] 495 if [[ -n ${ECONF_PARAMS} ]]
480 ARCH="${myARCH}" 509 ARCH="${myARCH}"
481} 510}
482 511
483linux-mod_src_install() { 512linux-mod_src_install() {
484 local modulename libdir srcdir objdir i n 513 local modulename libdir srcdir objdir i n
485 514
486 for i in ${MODULE_IGNORE} 515 for i in ${MODULE_IGNORE}
487 do 516 do
488 MODULE_NAMES=${MODULE_NAMES//${i}(*} 517 MODULE_NAMES=${MODULE_NAMES//${i}(*}
489 done 518 done
490 519
502 einfo "Installing ${modulename} module" 531 einfo "Installing ${modulename} module"
503 cd ${objdir} 532 cd ${objdir}
504 insinto ${ROOT}lib/modules/${KV_FULL}/${libdir} 533 insinto ${ROOT}lib/modules/${KV_FULL}/${libdir}
505 doins ${modulename}.${KV_OBJ} 534 doins ${modulename}.${KV_OBJ}
506 cd ${OLDPWD} 535 cd ${OLDPWD}
507 536
508 generate_modulesd ${objdir}/${modulename} 537 generate_modulesd ${objdir}/${modulename}
509 done 538 done
510} 539}
511 540
512linux-mod_pkg_postinst() { 541linux-mod_pkg_postinst() {
513 update_depmod; 542 update_depmod;
514 update_modules; 543 update_modules;
515 update_moduledb; 544 update_moduledb;
516 display_postinst;
517} 545}
518 546
519linux-mod_pkg_postrm() { 547linux-mod_pkg_postrm() {
520 remove_moduledb; 548 remove_moduledb;
521} 549}

Legend:
Removed from v.1.39  
changed lines
  Added in v.1.54

  ViewVC Help
Powered by ViewVC 1.1.20