File: pm-jatime.rc

package info (click to toggle)
procmail-lib 1%3A2009.1202-2
  • links: PTS, VCS
  • area: main
  • in suites: squeeze, wheezy
  • size: 2,372 kB
  • ctags: 541
  • sloc: perl: 294; makefile: 196; sh: 4
file content (127 lines) | stat: -rw-r--r-- 2,929 bytes parent folder | download | duplicates (5)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
# pm-jatime.rc -- "hh:mm:ss" time parser from variable INPUT
#
#   File id
#
#       Copyright (C) 1997-2010 Jari Aalto
#
#       This program is free software; you can redistribute it and/or
#       modify it under the terms of the GNU General Public License as
#       published by the Free Software Foundation; either version 2 of the
#       License, or (at your option) any later version
#
#       This program is distributed in the hope that it will be useful, but
#       WITHOUT ANY WARRANTY; without even the implied warranty of
#       MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
#       General Public License for more details at
#       <http://www.gnu.org/copyleft/gpl.html>.
#
#   Description
#
#	This includerc parses date from variable INPUT which has string
#
#           "hh:mm:ss"
#
#       Example input
#
#           "Thu, 13 Nov 1997 11:43:23 +0200"
#
#       Returned values
#
#           hh      = 2 digits
#           mm	    = 2 digits
#           ss      = 2 digits
#
#	Variable ERROR is set to "yes" if it couldn't recognize the INPUT
#	and couldn't parse all hh, mm, ss variables.
#
#   Required settings
#
#	PMSRC must point to source directory of procmail code. This subroutine
#       will include pm-javar.rc from there.
#
#   Call arguments (variables to set before calling)
#
#           INPUT = string-to-parse
#
#       The INPUT can be anything as long as it contains NN:NN:NN
#
#   Usage example
#
#	Get the time of received message. The From_ header will always
#	have the standard time stamp.
#
#	    PMSRC	    = $HOME/pm
#	    RC_DATE_TIME    = $PMSRC/pm-jatime.rc
#
#           :0 c
#           *  ^From +\/.*
#           {
#               INPUT = $MATCH
#               #  Turn off the logging while executing this part
#
#               VERBOSE=off   INCLUDERC = $RC_DATE_TIME   VERBOSE=on
#
#               :0
#               * ERROR ?? yes
#               {
#		   # Should not ever happen, you have broken From_
#		}
#           }
#
#   Change Log (none)

# .................................................... &initializing ...

id    = "pm-jatime.rc"
dummy = "
========================================================================
$id: init:
"

:0
* !  WSPC ?? [ ]
{
    INCLUDERC = $PMSRC/pm-javar.rc
}

# ..................................................... &output-vars ...
# output variables
#
hh mm ss
ERROR = "yes"		# set default value

# ........................................................... &do-it ...
#	Check that input is something like: Thu, 13 Nov 1997
#
dummy = "$id: Parse date like [Tue, 31 Dec 1997}"
dummy = "$id: INPUT = $INPUT"

:0
*$ INPUT ?? $s*\/$d$d:$d$d:$d$d
{

    INPUT = $MATCH

    *$ INPUT ?? ^\/$d$d
    {
	hh = $MATCH
    }

    :0
    *$ INPUT ?? ^$d$d:\/$d$d
    {
	mm = $MATCH
    }


    :0
    *$ INPUT ?? ^$d$d:$d$d:\/$d$d
    {
	ss	= $MATCH
	ERROR	= "no"
    }
}

dummy = "$id: end:"

# end of file pm-jadate.rc