summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSantiago M. Mola <coldwind@gentoo.org>2008-11-02 12:59:44 +0000
committerSantiago M. Mola <coldwind@gentoo.org>2008-11-02 12:59:44 +0000
commit493a39275ee57c2727e1c16e308fa9e899bcdf1d (patch)
tree4931ff7762d4ad1f4dee3111aae4c76bb244c038 /media-video/qc-usb-messenger
parentWhitespace. (diff)
downloadgentoo-2-493a39275ee57c2727e1c16e308fa9e899bcdf1d.tar.gz
gentoo-2-493a39275ee57c2727e1c16e308fa9e899bcdf1d.tar.bz2
gentoo-2-493a39275ee57c2727e1c16e308fa9e899bcdf1d.zip
Version bump, fix kernel 2.6.26 compatibility (bug #232700). Module is now
called qcmessenger. (Portage version: 2.2_rc12/cvs/Linux 2.6.27-gentoo-r1 x86_64)
Diffstat (limited to 'media-video/qc-usb-messenger')
-rw-r--r--media-video/qc-usb-messenger/ChangeLog10
-rw-r--r--media-video/qc-usb-messenger/files/qc-usb-messenger-1.8-kcompat-2.6.26.patch256
-rw-r--r--media-video/qc-usb-messenger/qc-usb-messenger-1.8.ebuild48
3 files changed, 313 insertions, 1 deletions
diff --git a/media-video/qc-usb-messenger/ChangeLog b/media-video/qc-usb-messenger/ChangeLog
index 5be054921eb7..adcb981af5b2 100644
--- a/media-video/qc-usb-messenger/ChangeLog
+++ b/media-video/qc-usb-messenger/ChangeLog
@@ -1,6 +1,14 @@
# ChangeLog for media-video/qc-usb-messenger
# Copyright 1999-2008 Gentoo Foundation; Distributed under the GPL v2
-# $Header: /var/cvsroot/gentoo-x86/media-video/qc-usb-messenger/ChangeLog,v 1.11 2008/02/08 16:52:35 tove Exp $
+# $Header: /var/cvsroot/gentoo-x86/media-video/qc-usb-messenger/ChangeLog,v 1.12 2008/11/02 12:59:43 coldwind Exp $
+
+*qc-usb-messenger-1.8 (02 Nov 2008)
+
+ 02 Nov 2008; Santiago M. Mola <coldwind@gentoo.org>
+ +files/qc-usb-messenger-1.8-kcompat-2.6.26.patch,
+ +qc-usb-messenger-1.8.ebuild:
+ Version bump, fix kernel 2.6.26 compatibility (bug #232700). Module is now
+ called qcmessenger.
08 Feb 2008; Torsten Veller <tove@gentoo.org>
qc-usb-messenger-1.7-r1.ebuild:
diff --git a/media-video/qc-usb-messenger/files/qc-usb-messenger-1.8-kcompat-2.6.26.patch b/media-video/qc-usb-messenger/files/qc-usb-messenger-1.8-kcompat-2.6.26.patch
new file mode 100644
index 000000000000..4813e6c1b328
--- /dev/null
+++ b/media-video/qc-usb-messenger/files/qc-usb-messenger-1.8-kcompat-2.6.26.patch
@@ -0,0 +1,256 @@
+--- qc-usb-messenger-1.8/qc-memory.c 2006-11-05 06:36:51.000000000 +0000
++++ qc-usb-messenger-1.8/qc-memory.c 2008-10-07 01:32:40.000000000 +0100
+@@ -81,12 +81,14 @@
+ #define pte_offset(pmd,adr) pte_offset_map(pmd,adr) /* Emulation for a kernel using the new rmap-vm */
+ #endif /* Fix by Michele Balistreri <brain87@gmx.net> */
+
++#if LINUX_VERSION_CODE>=KERNEL_VERSION(2,5,3) && LINUX_VERSION_CODE<KERNEL_VERSION(2,6,26)
+ #ifndef SetPageReserved
+ #define SetPageReserved(p) mem_map_reserve(p)
+ #endif
+ #ifndef ClearPageReserved
+ #define ClearPageReserved(p) mem_map_unreserve(p)
+ #endif
++#endif
+ /* }}} */
+
+ /* {{{ [fold] kvirt_to_pa(): obtain physical address from virtual address obtained by vmalloc() */
+--- qc-usb-messenger-1.8/qc-driver.c 2008-05-26 12:29:16.000000000 +0100
++++ qc-usb-messenger-1.8/qc-driver.c 2008-10-07 01:07:48.000000000 +0100
+@@ -1616,7 +1616,7 @@
+ fd->maxrawdatalen = 0; /* Hopefully stops all ongoing captures, might need locking though */
+ wake_up(&fd->wq);
+ if (qcdebug&QC_DEBUGFRAME) PDEBUG("waiting=%i",fd->waiting);
+- if (qcdebug&QC_DEBUGMUTEX) PDEBUG("up(%p) in qc_frame_exit() : %i", qc, sem_getcount(&qc->lock));
++ if (qcdebug&QC_DEBUGMUTEX) PDEBUG("up(%p) in qc_frame_exit() : %i", qc, 0);
+ up(&qc->lock); /* The lock was down when entering this function */
+ while (fd->waiting > 0) {
+ schedule();
+@@ -1627,7 +1627,7 @@
+ }
+ #endif
+ }
+- if (qcdebug&QC_DEBUGMUTEX) PDEBUG("down(%p) in qc_frame_exit() : %i", qc, sem_getcount(&qc->lock));
++ if (qcdebug&QC_DEBUGMUTEX) PDEBUG("down(%p) in qc_frame_exit() : %i", qc, 0);
+ down(&qc->lock);
+ vfree(fd->rawdatabuf);
+ POISON(fd->rawdatabuf);
+@@ -1656,14 +1656,14 @@
+ /* Wait until the next frame is available */
+ if (qcdebug&QC_DEBUGFRAME) PDEBUG("qc_frame_get/consume(qc=%p,tail=%i,head=%i)",qc,fd->tail,fd->head);
+ fd->waiting++;
+- if (qcdebug&QC_DEBUGMUTEX) PDEBUG("up(%p) in qc_frame_get() : %i", qc, sem_getcount(&qc->lock));
++ if (qcdebug&QC_DEBUGMUTEX) PDEBUG("up(%p) in qc_frame_get() : %i", qc, 0);
+ up(&qc->lock); /* Release lock while waiting */
+
+ ret = wait_event_interruptible(fd->wq, fd->head!=fd->tail || fd->exiting); //FIXME:What if we get -ERESTARTSYS?
+ if(ret == -ERESTARTSYS) {
+ PDEBUG("wait_event_interruptible() returned ERESTARTSYS");
+ }
+- if (qcdebug&QC_DEBUGMUTEX) PDEBUG("down(%p) in qc_frame_get() : %i", qc, sem_getcount(&qc->lock));
++ if (qcdebug&QC_DEBUGMUTEX) PDEBUG("down(%p) in qc_frame_get() : %i", qc, 0);
+ down(&qc->lock);
+ if (!ret) {
+ if (!fd->exiting) {
+@@ -2685,12 +2685,12 @@
+ if (qcdebug&QC_DEBUGMUTEX) PDEBUG("MOD_INC_USE_COUNT in qc_v4l_open() : %i",GET_USE_COUNT(THIS_MODULE));
+ MOD_INC_USE_COUNT;
+
+- if (qcdebug&QC_DEBUGMUTEX) PDEBUG("down_intr(quickcam_list) in qc_v4l_open() : %i", sem_getcount(&quickcam_list_lock));
++ if (qcdebug&QC_DEBUGMUTEX) PDEBUG("down_intr(quickcam_list) in qc_v4l_open() : %i", 0);
+
+ r = qc_lock(qc);
+ if (r<0) goto fail1;
+
+- if (qcdebug&QC_DEBUGMUTEX) PDEBUG("down_intr(%p) in qc_v4l_open() : %i", qc, sem_getcount(&qc->lock));
++ if (qcdebug&QC_DEBUGMUTEX) PDEBUG("down_intr(%p) in qc_v4l_open() : %i", qc, 0);
+ if (down_interruptible(&qc->lock)) {
+ r = -ERESTARTSYS;
+ goto fail2;
+@@ -2705,15 +2705,15 @@
+ if (qcdebug&QC_DEBUGLOGIC) PDEBUG("First user, initializing");
+ if ((r = qc_v4l_init(qc))<0) goto fail4;
+ }
+- if (qcdebug&QC_DEBUGMUTEX) PDEBUG("up(%p) in qc_v4l_open() : %i",qc, sem_getcount(&qc->lock));
++ if (qcdebug&QC_DEBUGMUTEX) PDEBUG("up(%p) in qc_v4l_open() : %i",qc, 0);
+ up(&qc->lock);
+ up(&quickcam_list_lock);
+ return 0;
+
+ fail4: qc->users--;
+-fail3: if (qcdebug&QC_DEBUGMUTEX) PDEBUG("up(%p) in qc_v4l_open()=failed : %i",qc, sem_getcount(&qc->lock));
++fail3: if (qcdebug&QC_DEBUGMUTEX) PDEBUG("up(%p) in qc_v4l_open()=failed : %i",qc, 0);
+ up(&qc->lock);
+-fail2: if (qcdebug&QC_DEBUGMUTEX) PDEBUG("up(quickcam_list) in qc_v4l_open()=failed : %i", sem_getcount(&qc->lock));
++fail2: if (qcdebug&QC_DEBUGMUTEX) PDEBUG("up(quickcam_list) in qc_v4l_open()=failed : %i", 0);
+ up(&quickcam_list_lock);
+ fail1: if (qcdebug&QC_DEBUGMUTEX) PDEBUG("MOD_DEC_USE_COUNT in qc_v4l_open() : %i",GET_USE_COUNT(THIS_MODULE));
+ MOD_DEC_USE_COUNT;
+@@ -2747,9 +2747,9 @@
+ #else
+ TEST_BUG_MSG(qc==NULL, "qc==NULL");
+ #endif
+- if (qcdebug&QC_DEBUGMUTEX) PDEBUG("down(quickcam_list) in qc_v4l_close() : %i", sem_getcount(&quickcam_list_lock));
++ if (qcdebug&QC_DEBUGMUTEX) PDEBUG("down(quickcam_list) in qc_v4l_close() : %i", 0);
+ down(&quickcam_list_lock); /* Can not interrupt, we must success */
+- if (qcdebug&QC_DEBUGMUTEX) PDEBUG("down(%p) in qc_v4l_close() : %i", qc, sem_getcount(&qc->lock));
++ if (qcdebug&QC_DEBUGMUTEX) PDEBUG("down(%p) in qc_v4l_close() : %i", qc, 0);
+ down(&qc->lock); /* Can not interrupt, we must success */
+ qc->users--;
+ PDEBUG("close users=%i", qc->users);
+@@ -2764,10 +2764,10 @@
+ }
+ }
+ if (qc) {
+- if (qcdebug&QC_DEBUGMUTEX) PDEBUG("up(%p) in qc_v4l_close() : %i", qc, sem_getcount(&qc->lock));
++ if (qcdebug&QC_DEBUGMUTEX) PDEBUG("up(%p) in qc_v4l_close() : %i", qc, 0);
+ up(&qc->lock);
+ }
+- if (qcdebug&QC_DEBUGMUTEX) PDEBUG("up(quickcam_list) in qc_v4l_close() : %i", sem_getcount(&quickcam_list_lock));
++ if (qcdebug&QC_DEBUGMUTEX) PDEBUG("up(quickcam_list) in qc_v4l_close() : %i", 0);
+ up(&quickcam_list_lock);
+ if (qcdebug&QC_DEBUGMUTEX) PDEBUG("MOD_DEC_USE_COUNT in qc_v4l_close() : %i", GET_USE_COUNT(THIS_MODULE));
+ MOD_DEC_USE_COUNT;
+@@ -2801,7 +2801,7 @@
+ PDEBUG("qc_read: no video_device available or no buffer attached :( EFAULT");
+ return -EFAULT;
+ }
+- if (qcdebug&QC_DEBUGMUTEX) PDEBUG("down_intr(%p) in qc_v4l_read() : %i", qc, sem_getcount(&qc->lock));
++ if (qcdebug&QC_DEBUGMUTEX) PDEBUG("down_intr(%p) in qc_v4l_read() : %i", qc, 0);
+ if (down_interruptible(&qc->lock)) return -ERESTARTSYS;
+ if (!qc->connected) {
+ r = -ENODEV;
+@@ -2823,7 +2823,7 @@
+ }
+ r = count;
+
+-fail: if (qcdebug&QC_DEBUGMUTEX) PDEBUG("up(%p) in qc_v4l_read() : %i", qc, sem_getcount(&qc->lock));
++fail: if (qcdebug&QC_DEBUGMUTEX) PDEBUG("up(%p) in qc_v4l_read() : %i", qc, 0);
+ up(&qc->lock);
+ if (qcdebug&QC_DEBUGLOGIC || qcdebug&QC_DEBUGERRORS) if (r<0) PDEBUG("failed qc_v4l_read()=%i", (int)r);
+ return r;
+@@ -2852,14 +2852,14 @@
+ struct vm_area_struct *vma = NULL;
+ #endif
+ if (qcdebug&QC_DEBUGLOGIC || qcdebug&QC_DEBUGUSER) PDEBUG("qc_v4l_mmap(dev=%p,size=%li,qc=%p)",dev,size,qc);
+- if (qcdebug&QC_DEBUGMUTEX) PDEBUG("down_intr(%p) in qc_v4l_mmap() : %i", qc, sem_getcount(&qc->lock));
++ if (qcdebug&QC_DEBUGMUTEX) PDEBUG("down_intr(%p) in qc_v4l_mmap() : %i", qc, 0);
+ if (down_interruptible(&qc->lock)) return -ERESTARTSYS;
+ if (!qc->connected) { ret = -ENODEV; goto fail; }
+ frame_size = qc_capt_frameaddr(qc, &frame);
+ if (frame_size<0) { ret = frame_size; goto fail; } /* Should never happen */
+ ret = qc_mm_remap(vma, frame, frame_size, start, size);
+
+-fail: if (qcdebug&QC_DEBUGMUTEX) PDEBUG("up(%p) in qc_v4l_mmap() : %i", qc, sem_getcount(&qc->lock));
++fail: if (qcdebug&QC_DEBUGMUTEX) PDEBUG("up(%p) in qc_v4l_mmap() : %i", qc, 0);
+ up(&qc->lock);
+ if (ret<0) if (qcdebug&QC_DEBUGLOGIC || qcdebug&QC_DEBUGERRORS) PDEBUG("failed qc_v4l_mmap()=%i",ret);
+ return ret;
+@@ -2881,7 +2881,7 @@
+ int i, retval = 0;
+
+ if (qcdebug&QC_DEBUGLOGIC || qcdebug&QC_DEBUGUSER) PDEBUG("qc_v4l_ioctl(dev=%p,cmd=%u,arg=%p,qc=%p)",dev,cmd,argp,qc);
+- if (qcdebug&QC_DEBUGMUTEX) PDEBUG("down_intr(%p) in qc_v4l_ioctl() : %i", qc, sem_getcount(&qc->lock));
++ if (qcdebug&QC_DEBUGMUTEX) PDEBUG("down_intr(%p) in qc_v4l_ioctl() : %i", qc, 0);
+ if (down_interruptible(&qc->lock)) return -ERESTARTSYS;
+ if (!qc->connected) {
+ retval = -ENODEV;
+@@ -3452,7 +3452,7 @@
+ retval = -ENOIOCTLCMD;
+ break;
+ }
+-fail: if (qcdebug&QC_DEBUGMUTEX) PDEBUG("up(%p) in qc_v4l_ioctl() : %i", qc, sem_getcount(&qc->lock));
++fail: if (qcdebug&QC_DEBUGMUTEX) PDEBUG("up(%p) in qc_v4l_ioctl() : %i", qc, 0);
+ up(&qc->lock);
+ if (retval<0) if (qcdebug&(QC_DEBUGLOGIC|QC_DEBUGUSER|QC_DEBUGERRORS)) PDEBUG("failed qc_v4l_ioctl()=%i",retval);
+ return retval;
+@@ -3547,21 +3547,21 @@
+
+ /* Check if there is already a suitable quickcam struct that can be reused */
+ reuse_qc = FALSE;
+- if (qcdebug&QC_DEBUGMUTEX) PDEBUG("down_intr(quickcam_list_lock) in qc_usb_init() : %i", sem_getcount(&quickcam_list_lock));
++ if (qcdebug&QC_DEBUGMUTEX) PDEBUG("down_intr(quickcam_list_lock) in qc_usb_init() : %i", 0);
+ if (down_interruptible(&quickcam_list_lock)) return NULL;
+ list_for_each_entry(qc, &quickcam_list, list) {
+ if (qc->dev != NULL) {
+ continue; /* quickcam_list_lock protects this test */
+ }
+- if (qcdebug&QC_DEBUGMUTEX) PDEBUG("down_intr(%p) in qc_usb_init() : %i",qc, sem_getcount(&qc->lock));
++ if (qcdebug&QC_DEBUGMUTEX) PDEBUG("down_intr(%p) in qc_usb_init() : %i",qc, 0);
+ if (down_interruptible(&qc->lock)) {
+ /* Failed to lock the camera. Move on in the list, skipping this camera */
+- if (qcdebug&QC_DEBUGMUTEX) PDEBUG("failed locking the camera %p in qc_usb_init() : %i",qc,sem_getcount(&qc->lock));
++ if (qcdebug&QC_DEBUGMUTEX) PDEBUG("failed locking the camera %p in qc_usb_init() : %i",qc,0);
+ continue;
+ }
+ if (qc->users<=0) {
+ PRINTK(KERN_NOTICE, "Unplugged unused camera detected!");
+- if (qcdebug&QC_DEBUGMUTEX) PDEBUG("up(%p) in qc_usb_init() : %i",qc, sem_getcount(&qc->lock));
++ if (qcdebug&QC_DEBUGMUTEX) PDEBUG("up(%p) in qc_usb_init() : %i",qc, 0);
+ up(&qc->lock);
+ continue;
+ }
+@@ -3662,7 +3662,7 @@
+ #endif
+ /* Register input device for button */
+ qc->input_ptr->name = "Quickcam snapshot button";
+- qc->input_ptr->private = qc;
++ //qc->input_ptr->private = qc;
+ #if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,24)
+ qc->input_ptr->evbit[0] = BIT_MASK(EV_KEY);
+ qc->input_ptr->keybit[BIT_WORD(BTN_0)] = BIT_MASK(BTN_0);
+@@ -3769,9 +3769,9 @@
+ qc_v4l_exit(qc);
+ #endif
+
+- if (qcdebug&QC_DEBUGMUTEX) PDEBUG("up(%p) in qc_usb_init() : %i",qc, sem_getcount(&qc->lock));
++ if (qcdebug&QC_DEBUGMUTEX) PDEBUG("up(%p) in qc_usb_init() : %i",qc, 0);
+ up(&qc->lock);
+- if (qcdebug&QC_DEBUGMUTEX) PDEBUG("up(quickcam_list) in qc_usb_init() : %i", sem_getcount(&quickcam_list_lock));
++ if (qcdebug&QC_DEBUGMUTEX) PDEBUG("up(quickcam_list) in qc_usb_init() : %i", 0);
+ up(&quickcam_list_lock);
+ return qc;
+
+@@ -3781,14 +3781,14 @@
+ fail2:
+ qc->dev = NULL;
+ qc->connected = FALSE;
+- if (qcdebug&QC_DEBUGMUTEX) PDEBUG("up(%p) in qc_usb_init()=failed : %i",qc, sem_getcount(&qc->lock));
++ if (qcdebug&QC_DEBUGMUTEX) PDEBUG("up(%p) in qc_usb_init()=failed : %i",qc, 0);
+ up(&qc->lock);
+
+ if (!reuse_qc) {
+ kfree(qc);
+ }
+ fail1: if (qcdebug&QC_DEBUGLOGIC || qcdebug&QC_DEBUGERRORS) PDEBUG("failed qc_usb_init()=%i",r);
+- if (qcdebug&QC_DEBUGMUTEX) PDEBUG("up(quickcam_list) in qc_usb_init()=failed : %i", sem_getcount(&quickcam_list_lock));
++ if (qcdebug&QC_DEBUGMUTEX) PDEBUG("up(quickcam_list) in qc_usb_init()=failed : %i", 0);
+ up(&quickcam_list_lock);
+ return NULL;
+ }
+@@ -4057,9 +4057,9 @@
+ */
+ qc->connected = FALSE;
+
+- if (qcdebug&QC_DEBUGMUTEX) PDEBUG("down(quickcam_list) in qc_usb_disconnect() : %i", sem_getcount(&quickcam_list_lock));
++ if (qcdebug&QC_DEBUGMUTEX) PDEBUG("down(quickcam_list) in qc_usb_disconnect() : %i", 0);
+ down(&quickcam_list_lock); /* Also avoids race condition with open() */
+- if (qcdebug&QC_DEBUGMUTEX) PDEBUG("down(%p) in qc_usb_disconnect() : %i", qc, sem_getcount(&qc->lock));
++ if (qcdebug&QC_DEBUGMUTEX) PDEBUG("down(%p) in qc_usb_disconnect() : %i", qc, 0);
+ down(&qc->lock); /* Can not interrupt, we must success */
+
+ if (qc->users <= 0) {
+@@ -4072,11 +4072,11 @@
+ qc_isoc_stop(qc); /* Unlink and free isochronous URBs */
+ qc_int_exit(qc);
+ qc->dev = NULL; /* Must be set to NULL only after interrupts are guaranteed to be disabled! */
+- if (qcdebug&QC_DEBUGMUTEX) PDEBUG("up(%p) in qc_usb_disconnect() : %i",qc, sem_getcount(&qc->lock));
++ if (qcdebug&QC_DEBUGMUTEX) PDEBUG("up(%p) in qc_usb_disconnect() : %i",qc, 0);
+ up(&qc->lock);
+ }
+
+- if (qcdebug&QC_DEBUGMUTEX) PDEBUG("up(quickcam_list) in qc_usb_disconnect() : %i", sem_getcount(&quickcam_list_lock));
++ if (qcdebug&QC_DEBUGMUTEX) PDEBUG("up(quickcam_list) in qc_usb_disconnect() : %i", 0);
+ up(&quickcam_list_lock);
+ if (qcdebug&QC_DEBUGMUTEX) PDEBUG("MOD_DEC_USE_COUNT in qc_usb_disconnect() : %i",GET_USE_COUNT(THIS_MODULE));
+ MOD_DEC_USE_COUNT; /* Release lock--if device is not open, module can be now freed */
diff --git a/media-video/qc-usb-messenger/qc-usb-messenger-1.8.ebuild b/media-video/qc-usb-messenger/qc-usb-messenger-1.8.ebuild
new file mode 100644
index 000000000000..f778c1c03a56
--- /dev/null
+++ b/media-video/qc-usb-messenger/qc-usb-messenger-1.8.ebuild
@@ -0,0 +1,48 @@
+# Copyright 1999-2008 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Header: /var/cvsroot/gentoo-x86/media-video/qc-usb-messenger/qc-usb-messenger-1.8.ebuild,v 1.1 2008/11/02 12:59:43 coldwind Exp $
+
+inherit eutils linux-mod
+
+DESCRIPTION="Logitech USB Quickcam Express Messenger & Communicate Linux Driver Modules"
+HOMEPAGE="http://home.mag.cx/messenger"
+SRC_URI="http://home.mag.cx/messenger/source/${P}.tar.gz"
+
+IUSE=""
+LICENSE="GPL-2"
+SLOT="0"
+KEYWORDS="~amd64 ~x86"
+
+CONFIG_CHECK="USB VIDEO_DEV VIDEO_V4L1_COMPAT"
+MODULE_NAMES="qcmessenger(usb:)"
+BUILD_TARGETS="all"
+
+DEPEND="virtual/linux-sources"
+
+pkg_setup() {
+ ABI=${KERNEL_ABI}
+ linux-mod_pkg_setup
+ BUILD_PARAMS="LINUX_DIR=${KV_DIR} OUTPUT_DIR=${KV_OUT_DIR}"
+}
+
+src_unpack() {
+ unpack ${A}
+ cd "${S}"
+ convert_to_m Makefile
+ epatch "${FILESDIR}"/${PN}-koutput.patch
+ epatch "${FILESDIR}"/${P}-kcompat-2.6.26.patch
+}
+
+src_install() {
+ linux-mod_src_install
+
+ dobin qcset
+ dodoc README* APPLICATIONS CREDITS TODO FAQ _CHANGES_MESSENGER _README_MESSENGER
+
+ insinto /usr/share/doc/${PF}
+ doins *.sh
+}
+
+pkg_postinst() {
+ elog "QuickCam Messenger module is now called 'qcmessenger'."
+}