The library library(record) provides named access to 
fields in a record represented as a compound term such as point(X, 
Y). The Prolog world knows various approaches to solve this 
problem, unfortunately with no consensus. The approach taken by this 
library is proposed by Richard O'Keefe on the SWI-Prolog mailinglist.
The approach automates a technique commonly described in Prolog text-books, where access and modification predicates are defined for the record type. Such predicates are subject to normal import/export as well as analysis by cross-referencers. Given the simple nature of the access predicates, an optimizing compiler can easily inline them for optimal preformance.
A record is defined using the directive record/1. We introduce the library with a short example:
:- record point(x:integer=0, y:integer=0).
        ...,
        default_point(Point),
        point_x(Point, X),
        set_x_of_point(10, Point, Point1),
        make_point([y(20)], YPoint),
The principal functor and arity of the term used defines the name and arity of the compound used as records. Each argument is described using a term of the format below.
<name>[:<type>][=<default>]
In this definition, <name> is an atom defining the 
name of the argument,
<type> is an optional type specification as defined by must_be/2 
from library library(error), and <default> 
is the default initial value. The
<type> defaults to any. If no default 
value is specified the default is an unbound variable.
A record declaration creates a set of predicates through term-expansion. We describe these predicates below. In this description, <constructor> refers to the name of the record (`point' in the example above) and <name> to the name of an argument (field).
library(option).
:- record Spec, ... is used to define access 
to named fields in a compound. It is subject to term-expansion (see
expand_term/2) 
and cannot be called as a predicate. See
section A.26 for details.