Awesome
julian
A date and time library for Prolog.
Warning: This is alpha quality software. APIs will change. There are bugs. Use with caution. Time zones are not yet supported and semantics that should account for time zone choose arbitrary, unpredictable behavior.
With that out of the way, the library can do a lot of useful stuff. See the in-depth tutorial for examples.
Synopsis
:- use_module(library(julian)).
:- use_module(library(clpfd)).
solution(Year) :-
% Eisenhower presidency had Fourth of July on Sunday in ...
form_time([dow(sunday), Year-07-04]),
Year in 1953..1961.
?- solution(Y).
Y = 1954.
Installation
Using SWI-Prolog 7.1.18 or later:
?- pack_install(julian).
This module uses semantic versioning.
Source code available and pull requests accepted at http://github.com/fifth-postulate/julian
Development
Testing
Test are written with the Test Anything Protocol (TAP) and use the fnogatz/tap
library.
To install the tap pack run
?- pack_install(tap).
Next, the julian
pack should be available as a library. One can install from the local installation by running
?- pack_install('file:///home/<path-to-project>/julian').
A TAP test harness should be used to run the tests in this project. To run the t/types.pl
test on could execute
prove -v -e 'swipl -q -t main -s' t/types.pl
To run all test one could use
prove -v -e 'swipl -q -t main -s' t/**.pl
Or use make tests
.