write
and writeq
, the term is written with respect to
current operator declarations (See ref-syn-ops for a discussion
of operators).
write_canonical(
Term)
writes Term to the current or specified output stream
in standard syntax (see ref-syn on Prolog syntax),
and quotes atoms and functors to make them acceptable as input to
read/[1,2]
. That is, operator declarations are not used and compound
terms are therefore always written in the form:
predicate_name(arg1, ..., argn)
write/[1,2]
cannot in general be read back using
read/[1,2]
. For example,
| ?- write('a b'). a b
If you want to be sure that the atom can be read back by read/[1,2]
, you
should use writeq/[1,2]
, or write_canonical/[1,2]
, which put
quotes around atoms when necessary, or use write_term/[2,3]
with the
quoted
option set to yes
. Note also that the printing
of quoted atoms is sensitive to character escaping (see ref-syn-ces).
write/[1,2]
and writeq/[1,2]
treat terms of the form '$VAR'(
N)
specially: they write ‘A’ if N=0, ‘B’ if N=1, ...‘Z’ if N=25,
‘A1’ if N=26, etc. Terms of this form are generated by
numbervars/3
(see ref-lte-anv). Terms of the form '$VAR'(
X)
,
where X is not a number are written as unquoted terms. For example,
| ?- writeq(a('$VAR'(0),'$VAR'('Test'))). a(A,Test)
write_canonical/1
does not treat terms of the form '$VAR'(
N)
specially. It writes square bracket lists using ./2
and
[]
(that is, [a,b]
is written as ‘.(a,.(b,[]))’).