Parse RRULE statements, and generate occurrences.
Execute postgres-rrule.sql
in your database:
$ psql -X -f postgres-rrule.sql
Or
$ make all
And modify your search path to include _rrule
schema:
SET search_path TO public, _rrule;
We create a table (in a newly created _rrule
schema) called RRULE
to generate start dates from rule criteria. The table constraints enforce the validity of dates in the table.
All of the types and functions are created in that schema.
Operator | Description | Notes | Result |
---|---|---|---|
= |
equal | All parameters match | boolean |
<> |
not equal | Any parameters don't match | boolean |
@> |
contains rrule |
All occurrences generated by second rule would also be generated by first rule | boolean |
<@ |
contained by rrule |
boolean |
Operator | Description | Notes | Result |
---|---|---|---|
@> |
contains timestamp |
The date of the timestamp is generated by the ruleset. | boolean |
In the case of the rrule
functions, there is a second required argument of type timestamp
, which is the "dtstart"
argument of a rruleset
. There is a form for each rrule
-accepting function that accepts a text
value, and parses it.
Requires pgTAP
and pg_resolve
. First let's install those from CPAN.
$ sudo cpan TAP::Parser::SourceHandler::pgTAP
Now you can run the tests with
$ make all test
This is a fork of Matthew Schinckel's original repo.
The MIT License (MIT)
Copyright (c) 2015 Matthew Schinckel, 2019 Volkan Unsal