NAME
Language::Prolog::Sugar - Syntactic sugar for Prolog term constructors
SYNOPSIS
use Language::Prolog::Sugar vars => [qw(X Y Z)];
use Language::Prolog::Sugar functors =>{ equal => '=',
minus => '-' };
use Language::Prolog::Sugar functors =>[qw(is)];
use Language::Prolog::Sugar atoms =>[qw(foo bar)];
use Language::Prolog::Sugar atoms =>{ cut => '!' };
use Language::Prolog::Sugar chains =>{ andn => ',',
orn => ';' };
$term=andn( equal(X, foo),
orn( equal(Y, [4, bar]),
equal(Y, foo)),
cut,
is(Z, minus(34, Y)));
ABSTRACT
This module allows you to easily define constructor subs for Prolog terms.
DESCRIPTION
Language::Prolog::Sugar is able to export to the calling package a set of subrutines to create Prolog terms as defined in the Language::Prolog::Types module.
Perl programs using these constructors have the same look as real Prolog programs.
Unfortunately Prolog operators syntax could not be simulated in any way I know (well, something could be done using overloading, but just something).
EXPORT
Whatever you wants!
Language::Prolog::Sugar can create constructors for four Prolog types: atoms, functors, vars and chains.
The syntax to use it is as follows:
use Language::Prolog::Sugar $type1s=>{ $name1 => $prolog_name1,
$name2 => $prolog_name2,
... },
...
or
use Language::Prolog::Sugar $type2s=>[qw($name1 $name2 ...)],
...
$type1s
, $type2s
, ... are atoms
, functors
, vars
or chains
.
$name1
, $name2
, ... are the names of the subrutines exported to the caller package.
$prolog_name
, $prolog_name2
, ... are the names that the constructors use when making the Prolog terms.
i.e:
use Language::Prolog::Sugar atoms=>{ cut => '!' }
exports a subrutine cut
that when called returns a Prolog atom !
.
use Language::Prolog::Sugar functor=>{ equal => '=' }
exports a subrutine equal
that when called returns a Prolog functor =
.
equal(3,4)
returns
'='(3,4)
It should be noted that functor arity is inferred from the number of arguments:
equal(3, 4, 5, 6, 7)
returns
'='(3, 4, 5, 6, 7)
I call 'chain' the structure formed tipically by ','/2 or ';'/2 operators in Prolog programs. i.e., Prolog program
p, o, r, s.
is actually
','(p, ','(o, ','(r, s))).
using chains allows for a more easily composition of those structures:
use Language::Prolog::Sugar chains => { andn => ',' },
atoms => [qw(p o r s)];
and
andn(p, o, r, s)
generates the Prolog structure for the example program above.
Also, the tag auto_term
can be used to install and AUTOLOAD sub on the caller module that would make a functor, term or variable for every undefined subroutine. For instance:
use Language::Prolog::Sugar 'auto_term';
swi_call(use_module(library(pce)));
swi_call(foo(hello, Hello))
The old auto_functor
tag has been obsoleted.
SEE ALSO
Language::Prolog::Types, Language::Prolog::Types::Factory
COPYRIGHT AND LICENSE
Copyright 2002-2006 by Salvador Fandiño (sfandino@yahoo.com).
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.