op(+Precedence, +Type, +Name)
declares Name to be an operator of the stated Type and Precedence.
integer, must be nonvar and in the range 1-1200
[xfx,xfy,yfx,fx,fy,xf,yf], must be nonvar
atom or list of atom, must be ground
Operators are a notational convenience
to read and write Prolog terms. You can define new operators using
The Precedence of an operator is used to disambiguate the way terms are parsed. The general rule is that the operator with the highest precedence is the principal functor.
The Type of an operator decides the position of an operator and its associativity. In the atom that represents the type the character ‘f’ represents the position of the operator. For example, a type ‘fx’ says that the operator is a prefix operator. The character ‘y’ indicates that the operator is associative in that direction. For example, an operator of type ‘xfy’ is a right-associative, infix operator.
To cancel the operator properties of Name (if any) set Precedence to 0.
Please note: operators are global, as opposed to being local to the current module, Prolog text, or otherwise.
An argument is not ground
Precedence is not an integer or Type is not an integer or an operator is not an atom
Precedence is not in the range 1-1200, or Type is invalid,
Attempt to redefine the operator