aboutsummaryrefslogtreecommitdiff
path: root/desktop/wmclock
diff options
context:
space:
mode:
authorB. Watson <yalhcru@gmail.com>2010-05-12 23:28:25 +0200
committerRobby Workman <rworkman@slackbuilds.org>2010-05-12 23:28:25 +0200
commit877ec9bfd1adfc1306fe343b3cac43424a995421 (patch)
tree452846ac9fbf152c23016991812a1ea9b1d12a39 /desktop/wmclock
parent8122ac328cfc88f63ddee5724e61e077f4c9052d (diff)
desktop/wmclock: Added to 12.2 repository
Diffstat (limited to 'desktop/wmclock')
-rw-r--r--desktop/wmclock/README21
-rw-r--r--desktop/wmclock/slack-desc19
-rw-r--r--desktop/wmclock/wmclock.SlackBuild69
-rw-r--r--desktop/wmclock/wmclock.info8
-rw-r--r--desktop/wmclock/wmclock_nopolling.patch77
5 files changed, 194 insertions, 0 deletions
diff --git a/desktop/wmclock/README b/desktop/wmclock/README
new file mode 100644
index 0000000000000..8cbc6514a74d0
--- /dev/null
+++ b/desktop/wmclock/README
@@ -0,0 +1,21 @@
+wmclock is an applet which displays the date and time in a dockable
+tile in the same style as the clock from the NEXTSTEP(tm) operating
+system. wmclock is specially designed for the Window Maker window
+manager, by Alfredo Kojima, and features multiple language support,
+twenty-four-hour and twelve-hour (am/pm) time display, and, optionally,
+can run a user-specified program on a mouse click.
+
+wmclock can display the month and weekday abbreviations in any of these
+languages:
+
+breton czech danish dutch english french french2 german hungarian indonesian
+italian norwegian portuguese russian slovene spanish swedish ukrainian
+
+To set the default language, set LANGUAGE to one of the above in the
+environment before running wmclock.SlackBuild, e.g.
+
+# LANGUAGE=french ./wmclock.SlackBuild
+
+This only sets the default; the other languages can still be used via
+the -monthxpm and -weekdayxpm command line options (see the wmclock man
+page for details).
diff --git a/desktop/wmclock/slack-desc b/desktop/wmclock/slack-desc
new file mode 100644
index 0000000000000..40e7f62cf2b03
--- /dev/null
+++ b/desktop/wmclock/slack-desc
@@ -0,0 +1,19 @@
+# HOW TO EDIT THIS FILE:
+# The "handy ruler" below makes it easier to edit a package description. Line
+# up the first '|' above the ':' following the base package name, and the '|'
+# on the right side marks the last column you can put a character in. You must
+# make exactly 11 lines for the formatting to be correct. It's also
+# customary to leave one space after the ':'.
+
+ |-----handy-ruler------------------------------------------------------|
+wmclock: wmclock (simple windowmaker clock/calendar dockapp)
+wmclock:
+wmclock: wmclock is an applet which displays the date and time in a dockable
+wmclock: tile in the same style as the clock from the NEXTSTEP(tm) operating
+wmclock: system. wmclock is specially designed for the Window Maker window
+wmclock: manager, by Alfredo Kojima, and features multiple language support,
+wmclock: twenty-four-hour and twelve-hour (am/pm) time display, and, optionally,
+wmclock: can run a user-specified program on a mouse click.
+wmclock:
+wmclock:
+wmclock:
diff --git a/desktop/wmclock/wmclock.SlackBuild b/desktop/wmclock/wmclock.SlackBuild
new file mode 100644
index 0000000000000..49b45a56deb8e
--- /dev/null
+++ b/desktop/wmclock/wmclock.SlackBuild
@@ -0,0 +1,69 @@
+#!/bin/sh
+
+# Slackware build script for wmclock
+
+# Written by B. Watson (yalhcru@gmail.com)
+
+PRGNAM=wmclock
+VERSION=${VERSION:-1.0.12.2}
+ARCH=${ARCH:-i486}
+BUILD=${BUILD:-1}
+TAG=${TAG:-_SBo}
+
+CWD=$(pwd)
+TMP=${TMP:-/tmp/SBo}
+PKG=$TMP/package-$PRGNAM
+OUTPUT=${OUTPUT:-/tmp}
+
+if [ "$ARCH" = "i486" ]; then
+ SLKCFLAGS="-O2 -march=i486 -mtune=i686"
+elif [ "$ARCH" = "i686" ]; then
+ SLKCFLAGS="-O2 -march=i686 -mtune=i686"
+elif [ "$ARCH" = "x86_64" ]; then
+ SLKCFLAGS="-O2 -fPIC"
+fi
+
+set -e
+
+rm -rf $PKG
+mkdir -p $TMP $PKG $OUTPUT
+cd $TMP
+rm -rf $PRGNAM-$VERSION
+tar xvf $CWD/$PRGNAM-$VERSION.tar.gz
+cd $PRGNAM-$VERSION
+chown -R root:root .
+chmod -R a-s,u+w,go+r-w .
+
+# Patch to reduce CPU usage (from the author's website)
+# Note: -p0, not the usual -p1!
+patch -p0 < $CWD/wmclock_nopolling.patch
+
+# Set the default language with LANGUAGE=<language> in the environment
+# Default is english. It's still possible to display in other
+# languages using the -monthxpm and -weekdayxpm options.
+
+# Language choices:
+# breton czech danish dutch english french french2 german hungarian indonesian
+# italian norwegian portuguese russian slovene spanish swedish ukrainian
+
+LANGUAGE=${LANGUAGE:-english}
+./configure --lang $LANGUAGE
+
+make CDEBUGFLAGS="$SLKCFLAGS"
+mkdir -p $PKG/usr/bin
+strip $PRGNAM
+install -m0755 -o root -g root $PRGNAM $PKG/usr/bin
+make install.share DESTDIR=$PKG
+
+mkdir -p $PKG/usr/man/man1
+gzip -9c $PRGNAM.man > $PKG/usr/man/man1/$PRGNAM.1.gz
+
+mkdir -p $PKG/usr/doc/$PRGNAM-$VERSION
+cp README COPYING ChangeLog $PKG/usr/doc/$PRGNAM-$VERSION
+cat $CWD/$PRGNAM.SlackBuild > $PKG/usr/doc/$PRGNAM-$VERSION/$PRGNAM.SlackBuild
+
+mkdir -p $PKG/install
+cat $CWD/slack-desc > $PKG/install/slack-desc
+
+cd $PKG
+/sbin/makepkg -l y -c n $OUTPUT/$PRGNAM-$VERSION-$ARCH-$BUILD$TAG.tgz
diff --git a/desktop/wmclock/wmclock.info b/desktop/wmclock/wmclock.info
new file mode 100644
index 0000000000000..9bbf1b6af7dca
--- /dev/null
+++ b/desktop/wmclock/wmclock.info
@@ -0,0 +1,8 @@
+PRGNAM="wmclock"
+VERSION="1.0.12.2"
+HOMEPAGE="http://liquidmeme.org/WindowMaker/wmclock/"
+DOWNLOAD="http://liquidmeme.org/WindowMaker/wmclock/wmclock-1.0.12.2.tar.gz"
+MD5SUM="97f6e82f55f216ba724859d4652586b4"
+MAINTAINER="B. Watson"
+EMAIL="yalhcru@gmail.com"
+APPROVED="rworkman"
diff --git a/desktop/wmclock/wmclock_nopolling.patch b/desktop/wmclock/wmclock_nopolling.patch
new file mode 100644
index 0000000000000..a5a338f784e06
--- /dev/null
+++ b/desktop/wmclock/wmclock_nopolling.patch
@@ -0,0 +1,77 @@
+--- wmclock.c.orig 2008-09-28 17:41:49.000000000 +0200
++++ wmclock.c 2008-09-28 20:33:59.000000000 +0200
+@@ -20,6 +20,7 @@
+ * with the software or the use or other dealings in the software.
+ */
+
++#include <sys/select.h>
+ #include <sys/types.h>
+ #include <sys/wait.h>
+ #include <sys/time.h>
+@@ -141,7 +142,8 @@
+ Display *dpy;
+ Window rootWindow;
+ int screen;
+-/* int xFd; */
++int xFd;
++fd_set xFdSet;
+ int displayDepth;
+ XSizeHints sizeHints;
+ XWMHints wmHints;
+@@ -801,6 +803,7 @@
+ XTextProperty wmName;
+ XClassHint classHint;
+ Pixmap shapeMask;
++ struct timeval nextEvent;
+
+ /* Parse command line options */
+ progName = extractProgName(argv[0]);
+@@ -849,7 +852,7 @@
+ screen = DefaultScreen(dpy);
+ rootWindow = RootWindow(dpy, screen);
+ displayDepth = DefaultDepth(dpy, screen);
+- /* xFd = XConnectionNumber(dpy); */
++ xFd = XConnectionNumber(dpy);
+
+ /* Icon Daten nach XImage konvertieren */
+ GetXpms();
+@@ -1049,14 +1052,32 @@
+ poll((struct poll *) 0, (size_t) 0, 50); /* 5/100 sec */
+ }
+ #else
+- if (enableYearDisplay)
+- {
+- usleep(200000L); /* 1/5 sec */
+- }
++ //We compute the date of next event, in order to avoid polling
++ if (enableBlinking)
++ {
++ gettimeofday(&nextEvent,NULL);
++ nextEvent.tv_sec = 0;
++ nextEvent.tv_usec = 1000000-nextEvent.tv_usec;
++ }
+ else
+- {
+- usleep(50000L); /* 5/100 sec */
+- }
++ {
++ if (enableYearDisplay)
++ {
++ nextEvent.tv_sec = 86400-actualTime%86400;
++ nextEvent.tv_usec = 0;
++ }
++ else
++ {
++ nextEvent.tv_sec = 60-actualTime%60;
++ nextEvent.tv_usec = 0;
++ }
++ }
++ printf("xFd %d\n", xFd);
++ FD_ZERO(&xFdSet);
++ FD_SET(xFd,&xFdSet);
++ printf("debut select %d\n", nextEvent.tv_sec);
++ select(FD_SETSIZE,&xFdSet,NULL,NULL,&nextEvent);
++ printf("fin select\n");
+ #endif
+ }
+ return(0);