UUGRN Stammtisch.sh: Unterschied zwischen den Versionen
Aus UUGRN
Rabe (Diskussion | Beiträge) (Script und Funktionsweise.) |
Rabe (Diskussion | Beiträge) K (kat) |
||
(2 dazwischenliegende Versionen desselben Benutzers werden nicht angezeigt) | |||
Zeile 1: | Zeile 1: | ||
Dieses Script ermittelt | Dieses Script ermittelt die [[UUGRN:Stammtisch|Stammtischtermine]] und [[UUGRN:FIXME Treffen]] und gibt passenden SQL-Code für die Kalender-Tabelle aus. | ||
== | == Script == | ||
<code><pre> | |||
#! /bin/sh | |||
YEAR=${1:-$(date +%Y)} | |||
test "${YEAR}" -gt 2000 -a "${YEAR}" -lt 2038 || YEAR="$(date +%Y)" | |||
for MONTH in $(gseq -w 01 12); do for DAY in $(gseq -w 01 31); do | |||
gdate "+%u|%d|%F" --date "${YEAR}-${MONTH}-${DAY}" 2>/dev/null | |||
done; done | | |||
while IFS='|' read DOW DOM DATE; do | |||
case ${DOM} in | |||
01|02|03|04|05|06|07) NIM=1 ;; | |||
08|09|10|11|12|13|14) NIM=2 ;; | |||
15|16|17|18|19|20|21) NIM=3 ;; | |||
22|23|24|25|26|27|28) NIM=4 ;; | |||
29|30|31) NIM=5 ;; | |||
*) NIM="0" ;; | |||
esac | |||
SQL="insert into KALENDER set ID=0" | |||
SQL2="" | |||
case ${NIM}-${DOW} in | |||
1-5) # 1. Freitag | |||
SQL2=", DATUM='${DATE} 20:00:00', ORT_ID=11, TEXT='FIXME', EVENT_LINK='http://fixme.uugrn.org/'" | |||
;; | |||
3-1) # 3. Montag | |||
SQL2=", DATUM='${DATE} 20:00:00', ORT_ID=12, TEXT='UnixStammtisch', EVENT_LINK='http://stammtisch.uugrn.org/'" | |||
;; | |||
esac | |||
24 | if [ -n "${SQL2}" ]; then | ||
echo "${SQL}${SQL2};" | |||
fi | |||
done | |||
</pre></code> | |||
=== Variablen === | |||
;YEAR,MONTH,DAY: Iteriert über alle Kalendertage des angegebenen Jahres | |||
;DOW: day-of-week [1..7], 1=Montag | |||
;DOM: day-of-month [1..31] | |||
;NIM: Nth-in-month [1..5] | |||
[[Kategorie:Script]] | [[Kategorie:Script]] | ||
[[Kategorie: | [[Kategorie:UUGRN|Stammtischkalender]] |
Aktuelle Version vom 13. April 2013, 09:39 Uhr
Dieses Script ermittelt die Stammtischtermine und UUGRN:FIXME Treffen und gibt passenden SQL-Code für die Kalender-Tabelle aus.
Script[Bearbeiten]
#! /bin/sh
YEAR=${1:-$(date +%Y)}
test "${YEAR}" -gt 2000 -a "${YEAR}" -lt 2038 || YEAR="$(date +%Y)"
for MONTH in $(gseq -w 01 12); do for DAY in $(gseq -w 01 31); do
gdate "+%u|%d|%F" --date "${YEAR}-${MONTH}-${DAY}" 2>/dev/null
done; done |
while IFS='|' read DOW DOM DATE; do
case ${DOM} in
01|02|03|04|05|06|07) NIM=1 ;;
08|09|10|11|12|13|14) NIM=2 ;;
15|16|17|18|19|20|21) NIM=3 ;;
22|23|24|25|26|27|28) NIM=4 ;;
29|30|31) NIM=5 ;;
*) NIM="0" ;;
esac
SQL="insert into KALENDER set ID=0"
SQL2=""
case ${NIM}-${DOW} in
1-5) # 1. Freitag
SQL2=", DATUM='${DATE} 20:00:00', ORT_ID=11, TEXT='FIXME', EVENT_LINK='http://fixme.uugrn.org/'"
;;
3-1) # 3. Montag
SQL2=", DATUM='${DATE} 20:00:00', ORT_ID=12, TEXT='UnixStammtisch', EVENT_LINK='http://stammtisch.uugrn.org/'"
;;
esac
if [ -n "${SQL2}" ]; then
echo "${SQL}${SQL2};"
fi
done
Variablen[Bearbeiten]
- YEAR,MONTH,DAY
- Iteriert über alle Kalendertage des angegebenen Jahres
- DOW
- day-of-week [1..7], 1=Montag
- DOM
- day-of-month [1..31]
- NIM
- Nth-in-month [1..5]