annotate lisp/progmodes/prolog.el @ 112450:16ddab338c43

Remove HAVE_RAW_DECL_CHOWN etc. from config.h
author Paul Eggert <eggert@cs.ucla.edu>
date Sun, 23 Jan 2011 20:53:39 -0800
parents 43d75ad47207
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
1 ;;; prolog.el --- major mode for editing and running Prolog (and Mercury) code
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
3 ;; Copyright (C) 1986, 1987, 1997, 1998, 1999, 2002, 2003, 2011 Free Software Foundation, Inc.
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
4
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
5 ;; Authors: Emil Åström <emil_astrom(at)hotmail(dot)com>
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
6 ;; Milan Zamazal <pdm(at)freesoft(dot)cz>
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
7 ;; Stefan Bruda <stefan(at)bruda(dot)ca> (current maintainer)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
8 ;; * See below for more details
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
9 ;; Keywords: prolog major mode sicstus swi mercury
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
10
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
11 (defvar prolog-mode-version "1.22"
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
12 "Prolog mode version number.")
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
13
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
14 ;; This file is part of GNU Emacs.
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
15
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
16 ;; GNU Emacs is free software: you can redistribute it and/or modify
41
467ee6fe6503 Initial revision
root <root>
parents:
diff changeset
17 ;; it under the terms of the GNU General Public License as published by
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
18 ;; the Free Software Foundation, either version 3 of the License, or
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
19 ;; (at your option) any later version.
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
20
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
21 ;; GNU Emacs is distributed in the hope that it will be useful,
41
467ee6fe6503 Initial revision
root <root>
parents:
diff changeset
22 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
467ee6fe6503 Initial revision
root <root>
parents:
diff changeset
23 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
467ee6fe6503 Initial revision
root <root>
parents:
diff changeset
24 ;; GNU General Public License for more details.
467ee6fe6503 Initial revision
root <root>
parents:
diff changeset
25
467ee6fe6503 Initial revision
root <root>
parents:
diff changeset
26 ;; You should have received a copy of the GNU General Public License
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
27 ;; along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>.
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
28
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
29 ;; Original author: Masanobu UMEDA <umerin(at)mse(dot)kyutech(dot)ac(dot)jp>
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
30 ;; Parts of this file was taken from a modified version of the original
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
31 ;; by Johan Andersson, Peter Olin, Mats Carlsson, Johan Bevemyr, Stefan
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
32 ;; Andersson, and Per Danielsson (all SICS people), and Henrik Båkman
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
33 ;; at Uppsala University, Sweden.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
34 ;;
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
35 ;; Some ideas and also a few lines of code have been borrowed (not stolen ;-)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
36 ;; from Oz.el, the Emacs major mode for the Oz programming language,
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
37 ;; Copyright (C) 1993 DFKI GmbH, Germany, with permission.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
38 ;; Authors: Ralf Scheidhauer and Michael Mehl ([scheidhr|mehl](at)dfki(dot)uni-sb(dot)de)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
39 ;;
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
40 ;; More ideas and code have been taken from the SICStus debugger mode
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
41 ;; (http://www.csd.uu.se/~perm/source_debug/index.shtml -- broken link
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
42 ;; as of Mon May 5 08:23:48 EDT 2003) by Per Mildner.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
43 ;;
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
44 ;; Additions for ECLiPSe and other helpful suggestions: Stephan Heuel
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
45 ;; <heuel(at)ipb(dot)uni-bonn(dot)de>
41
467ee6fe6503 Initial revision
root <root>
parents:
diff changeset
46
2308
f287613dfc28 Added or corrected Commentary sections
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 2307
diff changeset
47 ;;; Commentary:
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
48 ;;
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
49 ;; This package provides a major mode for editing Prolog code, with
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
50 ;; all the bells and whistles one would expect, including syntax
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
51 ;; highlighting and auto indentation. It can also send regions to an
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
52 ;; inferior Prolog process.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
53 ;;
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
54 ;; The code requires the comint, easymenu, info, imenu, and font-lock
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
55 ;; libraries. These are normally distributed with GNU Emacs and
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
56 ;; XEmacs.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
57
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
58 ;;; Installation:
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
59 ;;
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
60 ;; Insert the following lines in your init file--typically ~/.emacs
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
61 ;; (GNU Emacs and XEmacs <21.4), or ~/.xemacs/init.el (XEmacs
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
62 ;; 21.4)--to use this mode when editing Prolog files under Emacs:
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
63 ;;
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
64 ;; (setq load-path (cons "/usr/lib/xemacs/site-lisp" load-path))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
65 ;; (autoload 'run-prolog "prolog" "Start a Prolog sub-process." t)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
66 ;; (autoload 'prolog-mode "prolog" "Major mode for editing Prolog programs." t)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
67 ;; (autoload 'mercury-mode "prolog" "Major mode for editing Mercury programs." t)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
68 ;; (setq prolog-system 'swi) ; optional, the system you are using;
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
69 ;; ; see `prolog-system' below for possible values
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
70 ;; (setq auto-mode-alist (append '(("\\.pl$" . prolog-mode)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
71 ;; ("\\.m$" . mercury-mode))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
72 ;; auto-mode-alist))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
73 ;;
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
74 ;; where the path in the first line is the file system path to this file.
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
75 ;; MSDOS paths can be written like "d:/programs/emacs-19.34/site-lisp".
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
76 ;; Note: In XEmacs, either `/usr/lib/xemacs/site-lisp' (RPM default in
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
77 ;; Red Hat-based distributions) or `/usr/local/lib/xemacs/site-lisp'
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
78 ;; (default when compiling from sources) are automatically added to
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
79 ;; `load-path', so the first line is not necessary provided that you
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
80 ;; put this file in the appropriate place.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
81 ;;
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
82 ;; The last s-expression above makes sure that files ending with .pl
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
83 ;; are assumed to be Prolog files and not Perl, which is the default
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
84 ;; Emacs setting. If this is not wanted, remove this line. It is then
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
85 ;; necessary to either
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
86 ;;
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
87 ;; o insert in your Prolog files the following comment as the first line:
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
88 ;;
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
89 ;; % -*- Mode: Prolog -*-
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
90 ;;
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
91 ;; and then the file will be open in Prolog mode no matter its
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
92 ;; extension, or
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
93 ;;
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
94 ;; o manually switch to prolog mode after opening a Prolog file, by typing
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
95 ;; M-x prolog-mode.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
96 ;;
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
97 ;; If the command to start the prolog process ('sicstus', 'pl' or
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
98 ;; 'swipl' for SWI prolog, etc.) is not available in the default path,
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
99 ;; then it is necessary to set the value of the environment variable
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
100 ;; EPROLOG to a shell command to invoke the prolog process. In XEmacs
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
101 ;; and Emacs 20+ you can also customize the variable
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
102 ;; `prolog-program-name' (in the group `prolog-inferior') and provide
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
103 ;; a full path for your Prolog system (swi, scitus, etc.).
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
104 ;;
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
105 ;; Note: I (Stefan, the current maintainer) work under XEmacs. Future
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
106 ;; developments will thus be biased towards XEmacs (OK, I admit it,
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
107 ;; I am biased towards XEmacs in general), though I will do my best
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
108 ;; to keep the GNU Emacs compatibility. So if you work under Emacs
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
109 ;; and see something that does not work do drop me a line, as I have
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
110 ;; a smaller chance to notice this kind of bugs otherwise.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
111
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
112 ;; Changelog:
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
113
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
114 ;; Version 1.22:
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
115 ;; o Allowed both 'swipl' and 'pl' as names for the SWI Prolog
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
116 ;; interpreter.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
117 ;; o Atoms that start a line are not blindly coloured as
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
118 ;; predicates. Instead we check that they are followed by ( or
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
119 ;; :- first. Patch suggested by Guy Wiener.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
120 ;; Version 1.21:
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
121 ;; o Cleaned up the code that defines faces. The missing face
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
122 ;; warnings on some Emacsen should disappear.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
123 ;; Version 1.20:
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
124 ;; o Improved the handling of clause start detection and multi-line
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
125 ;; comments: `prolog-clause-start' no longer finds non-predicate
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
126 ;; (e.g., capitalized strings) beginning of clauses.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
127 ;; `prolog-tokenize' recognizes when the end point is within a
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
128 ;; multi-line comment.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
129 ;; Version 1.19:
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
130 ;; o Minimal changes for Aquamacs inclusion and in general for
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
131 ;; better coping with finding the Prolog executable. Patch
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
132 ;; provided by David Reitter
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
133 ;; Version 1.18:
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
134 ;; o Fixed syntax highlighting for clause heads that do not begin at
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
135 ;; the beginning of the line.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
136 ;; o Fixed compilation warnings under Emacs.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
137 ;; o Updated the email address of the current maintainer.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
138 ;; Version 1.17:
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
139 ;; o Minor indentation fix (patch by Markus Triska)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
140 ;; o `prolog-underscore-wordchar-flag' defaults now to nil (more
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
141 ;; consistent to other Emacs modes)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
142 ;; Version 1.16:
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
143 ;; o Eliminated a possible compilation warning.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
144 ;; Version 1.15:
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
145 ;; o Introduced three new customizable variables: electric colon
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
146 ;; (`prolog-electric-colon-flag', default nil), electric dash
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
147 ;; (`prolog-electric-dash-flag', default nil), and a possibility
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
148 ;; to prevent the predicate template insertion from adding commata
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
149 ;; (`prolog-electric-dot-full-predicate-template', defaults to t
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
150 ;; since it seems quicker to me to just type those commata). A
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
151 ;; trivial adaptation of a patch by Markus Triska.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
152 ;; o Improved the behaviour of electric if-then-else to only skip
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
153 ;; forward if the parenthesis/semicolon is preceded by
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
154 ;; whitespace. Once more a trivial adaptation of a patch by
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
155 ;; Markus Triska.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
156 ;; Version 1.14:
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
157 ;; o Cleaned up align code. `prolog-align-flag' is eliminated (since
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
158 ;; on a second thought it does not do anything useful). Added key
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
159 ;; binding (C-c C-a) and menu entry for alignment.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
160 ;; o Condensed regular expressions for lower and upper case
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
161 ;; characters (GNU Emacs seems to go over the regexp length limit
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
162 ;; with the original form). My code on the matter was improved
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
163 ;; considerably by Markus Triska.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
164 ;; o Fixed `prolog-insert-spaces-after-paren' (which used an
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
165 ;; unitialized variable).
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
166 ;; o Minor changes to clean up the code and avoid some implicit
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
167 ;; package requirements.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
168 ;; Version 1.13:
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
169 ;; o Removed the use of `map-char-table' in `prolog-build-case-strings'
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
170 ;; which appears to cause prblems in (at least) Emacs 23.0.0.1.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
171 ;; o Added if-then-else indentation + corresponding electric
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
172 ;; characters. New customization: `prolog-electric-if-then-else-flag'
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
173 ;; o Align support (requires `align'). New customization:
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
174 ;; `prolog-align-flag'.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
175 ;; o Temporary consult files have now the same name throughout the
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
176 ;; session. This prevents issues with reconsulting a buffer
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
177 ;; (this event is no longer passed to Prolog as a request to
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
178 ;; consult a new file).
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
179 ;; o Adaptive fill mode is now turned on. Comment indentation is
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
180 ;; still worse than it could be though, I am working on it.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
181 ;; o Improved filling and auto-filling capabilities. Now block
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
182 ;; comments should be [auto-]filled correctly most of the time;
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
183 ;; the following pattern in particular is worth noting as being
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
184 ;; filled correctly:
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
185 ;; <some code here> % some comment here that goes beyond the
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
186 ;; % rightmost column, possibly combined with
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
187 ;; % subsequent comment lines
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
188 ;; o `prolog-char-quote-workaround' now defaults to nil.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
189 ;; o Note: Many of the above improvements have been suggested by
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
190 ;; Markus Triska, who also provided useful patches on the matter
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
191 ;; when he realized that I was slow in responding. Many thanks.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
192 ;; Version 1.11 / 1.12
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
193 ;; o GNU Emacs compatibility fix for paragraph filling (fixed
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
194 ;; incorrectly in 1.11, fix fixed in 1.12).
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
195 ;; Version 1.10
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
196 ;; o Added paragraph filling in comment blocks and also correct auto
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
197 ;; filling for comments.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
198 ;; o Fixed the possible "Regular expression too big" error in
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
199 ;; `prolog-electric-dot'.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
200 ;; Version 1.9
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
201 ;; o Parenthesis expressions are now indented by default so that
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
202 ;; components go one underneath the other, just as for compound
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
203 ;; terms. You can use the old style (the second and subsequent
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
204 ;; lines being indented to the right in a parenthesis expression)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
205 ;; by setting the customizable variable `prolog-paren-indent-p'
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
206 ;; (group "Prolog Indentation") to t.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
207 ;; o (Somehow awkward) handling of the 0' character escape
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
208 ;; sequence. I am looking into a better way of doing it but
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
209 ;; prospects look bleak. If this breaks things for you please let
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
210 ;; me know and also set the `prolog-char-quote-workaround' (group
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
211 ;; "Prolog Other") to nil.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
212 ;; Version 1.8
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
213 ;; o Key binding fix.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
214 ;; Version 1.7
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
215 ;; o Fixed a number of issues with the syntax of single quotes,
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
216 ;; including Debian bug #324520.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
217 ;; Version 1.6
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
218 ;; o Fixed mercury mode menu initialization (Debian bug #226121).
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
219 ;; o Fixed (i.e., eliminated) Delete remapping (Debian bug #229636).
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
220 ;; o Corrected indentation for clauses defining quoted atoms.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
221 ;; Version 1.5:
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
222 ;; o Keywords fontifying should work in console mode so this is
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
223 ;; enabled everywhere.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
224 ;; Version 1.4:
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
225 ;; o Now supports GNU Prolog--minor adaptation of a patch by Stefan
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
226 ;; Moeding.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
227 ;; Version 1.3:
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
228 ;; o Info-follow-nearest-node now called correctly under Emacs too
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
229 ;; (thanks to Nicolas Pelletier). Should be implemented more
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
230 ;; elegantly (i.e., without compilation warnings) in the future.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
231 ;; Version 1.2:
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
232 ;; o Another prompt fix, still in SWI mode (people seem to have
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
233 ;; changed the prompt of SWI Prolog).
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
234 ;; Version 1.1:
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
235 ;; o Fixed dots in the end of line comments causing indentation
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
236 ;; problems. The following code is now correctly indented (note
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
237 ;; the dot terminating the comment):
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
238 ;; a(X) :- b(X),
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
239 ;; c(X). % comment here.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
240 ;; a(X).
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
241 ;; and so is this (and variants):
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
242 ;; a(X) :- b(X),
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
243 ;; c(X). /* comment here. */
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
244 ;; a(X).
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
245 ;; Version 1.0:
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
246 ;; o Revamped the menu system.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
247 ;; o Yet another prompt recognition fix (SWI mode).
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
248 ;; o This is more of a renumbering than a new edition. I promoted
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
249 ;; the mode to version 1.0 to emphasize the fact that it is now
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
250 ;; mature and stable enough to be considered production (in my
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
251 ;; opinion anyway).
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
252 ;; Version 0.1.41:
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
253 ;; o GNU Emacs compatibility fixes.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
254 ;; Version 0.1.40:
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
255 ;; o prolog-get-predspec is now suitable to be called as
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
256 ;; imenu-extract-index-name-function. The predicate index works.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
257 ;; o Since imenu works now as advertised, prolog-imenu-flag is t
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
258 ;; by default.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
259 ;; o Eliminated prolog-create-predicate-index since the imenu
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
260 ;; utilities now work well. Actually, this function is also
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
261 ;; buggy, and I see no reason to fix it since we do not need it
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
262 ;; anyway.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
263 ;; o Fixed prolog-pred-start, prolog-clause-start, prolog-clause-info.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
264 ;; o Fix for prolog-build-case-strings; now prolog-upper-case-string
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
265 ;; and prolog-lower-case-string are correctly initialized,
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
266 ;; o Various font-lock changes; most importantly, block comments (/*
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
267 ;; ... */) are now correctly fontified in XEmacs even when they
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
268 ;; extend on multiple lines.
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
269 ;; Version 0.1.36:
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
270 ;; o The debug prompt of SWI Prolog is now correctly recognized.
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
271 ;; Version 0.1.35:
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
272 ;; o Minor font-lock bug fixes.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
273
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
274 ;;; TODO:
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
275
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
276 ;; Replace ":type 'sexp" with more precise Custom types.
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
277
807
4f28bd14272c *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 659
diff changeset
278 ;;; Code:
4f28bd14272c *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 659
diff changeset
279
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
280 (eval-when-compile
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
281 (require 'compile)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
282 (require 'font-lock)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
283 ;; We need imenu everywhere because of the predicate index!
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
284 (require 'imenu)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
285 ;)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
286 (require 'info)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
287 (require 'shell)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
288 )
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
289
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
290 (require 'comint)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
291 (require 'easymenu)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
292 (require 'align)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
293
65238
a372b82c546e (comint-prompt-regexp): Add defvar.
Juanma Barranquero <lekktu@gmail.com>
parents: 64699
diff changeset
294
17414
f967f12c8ec8 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 14169
diff changeset
295 (defgroup prolog nil
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
296 "Major modes for editing and running Prolog and Mercury files."
17414
f967f12c8ec8 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 14169
diff changeset
297 :group 'languages)
f967f12c8ec8 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 14169
diff changeset
298
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
299 (defgroup prolog-faces nil
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
300 "Prolog mode specific faces."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
301 :group 'font-lock)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
302
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
303 (defgroup prolog-indentation nil
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
304 "Prolog mode indentation configuration."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
305 :group 'prolog)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
306
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
307 (defgroup prolog-font-lock nil
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
308 "Prolog mode font locking patterns."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
309 :group 'prolog)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
310
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
311 (defgroup prolog-keyboard nil
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
312 "Prolog mode keyboard flags."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
313 :group 'prolog)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
314
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
315 (defgroup prolog-inferior nil
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
316 "Inferior Prolog mode options."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
317 :group 'prolog)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
318
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
319 (defgroup prolog-other nil
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
320 "Other Prolog mode options."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
321 :group 'prolog)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
322
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
323
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
324 ;;-------------------------------------------------------------------
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
325 ;; User configurable variables
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
326 ;;-------------------------------------------------------------------
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
327
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
328 ;; General configuration
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
329
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
330 (defcustom prolog-system nil
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
331 "*Prolog interpreter/compiler used.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
332 The value of this variable is nil or a symbol.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
333 If it is a symbol, it determines default values of other configuration
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
334 variables with respect to properties of the specified Prolog
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
335 interpreter/compiler.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
336
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
337 Currently recognized symbol values are:
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
338 eclipse - Eclipse Prolog
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
339 mercury - Mercury
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
340 sicstus - SICStus Prolog
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
341 swi - SWI Prolog
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
342 gnu - GNU Prolog"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
343 :group 'prolog
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
344 :type '(choice (const :tag "SICStus" :value sicstus)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
345 (const :tag "SWI Prolog" :value swi)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
346 (const :tag "Default" :value nil)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
347 (make-variable-buffer-local 'prolog-system)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
348
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
349 ;; NB: This alist can not be processed in prolog-mode-variables to
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
350 ;; create a prolog-system-version-i variable since it is needed
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
351 ;; prior to the call to prolog-mode-variables.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
352 (defcustom prolog-system-version
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
353 '((sicstus (3 . 6))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
354 (swi (0 . 0))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
355 (mercury (0 . 0))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
356 (eclipse (3 . 7))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
357 (gnu (0 . 0)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
358 "*Alist of Prolog system versions.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
359 The version numbers are of the format (Major . Minor)."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
360 :group 'prolog)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
361
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
362 ;; Indentation
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
363
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
364 (defcustom prolog-indent-width 4
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
365 "*The indentation width used by the editing buffer."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
366 :group 'prolog-indentation
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
367 :type 'integer)
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
368
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
369 (defcustom prolog-align-comments-flag t
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
370 "*Non-nil means automatically align comments when indenting."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
371 :group 'prolog-indentation
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
372 :type 'boolean)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
373
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
374 (defcustom prolog-indent-mline-comments-flag t
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
375 "*Non-nil means indent contents of /* */ comments.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
376 Otherwise leave such lines as they are."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
377 :group 'prolog-indentation
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
378 :type 'boolean)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
379
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
380 (defcustom prolog-object-end-to-0-flag t
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
381 "*Non-nil means indent closing '}' in SICStus object definitions to level 0.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
382 Otherwise indent to `prolog-indent-width'."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
383 :group 'prolog-indentation
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
384 :type 'boolean)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
385
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
386 (defcustom prolog-left-indent-regexp "\\(;\\|\\*?->\\)"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
387 "*Regexp for character sequences after which next line is indented.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
388 Next line after such a regexp is indented to the opening paranthesis level."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
389 :group 'prolog-indentation
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
390 :type 'regexp)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
391
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
392 (defcustom prolog-paren-indent-p nil
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
393 "*If non-nil, increase indentation for parenthesis expressions.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
394 The second and subsequent line in a parenthesis expression other than
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
395 a compound term can either be indented `prolog-paren-indent' to the
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
396 right (if this variable is non-nil) or in the same way as for compound
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
397 terms (if this variable is nil, default)."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
398 :group 'prolog-indentation
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
399 :type 'boolean)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
400
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
401 (defcustom prolog-paren-indent 4
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
402 "*The indentation increase for parenthesis expressions.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
403 Only used in ( If -> Then ; Else) and ( Disj1 ; Disj2 ) style expressions."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
404 :group 'prolog-indentation
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
405 :type 'integer)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
406
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
407 (defcustom prolog-parse-mode 'beg-of-clause
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
408 "*The parse mode used (decides from which point parsing is done).
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
409 Legal values:
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
410 'beg-of-line - starts parsing at the beginning of a line, unless the
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
411 previous line ends with a backslash. Fast, but has
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
412 problems detecting multiline /* */ comments.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
413 'beg-of-clause - starts parsing at the beginning of the current clause.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
414 Slow, but copes better with /* */ comments."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
415 :group 'prolog-indentation
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
416 :type '(choice (const :value beg-of-line)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
417 (const :value beg-of-clause)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
418
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
419 ;; Font locking
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
420
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
421 (defcustom prolog-keywords
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
422 '((eclipse
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
423 ("use_module" "begin_module" "module_interface" "dynamic"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
424 "external" "export" "dbgcomp" "nodbgcomp" "compile"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
425 (mercury
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
426 ("all" "else" "end_module" "equality" "external" "fail" "func" "if"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
427 "implementation" "import_module" "include_module" "inst" "instance"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
428 "interface" "mode" "module" "not" "pragma" "pred" "some" "then" "true"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
429 "type" "typeclass" "use_module" "where"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
430 (sicstus
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
431 ("block" "dynamic" "mode" "module" "multifile" "meta_predicate"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
432 "parallel" "public" "sequential" "volatile"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
433 (swi
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
434 ("discontiguous" "dynamic" "ensure_loaded" "export" "export_list" "import"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
435 "meta_predicate" "module" "module_transparent" "multifile" "require"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
436 "use_module" "volatile"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
437 (gnu
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
438 ("built_in" "char_conversion" "discontiguous" "dynamic" "ensure_linked"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
439 "ensure_loaded" "foreign" "include" "initialization" "multifile" "op"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
440 "public" "set_prolog_flag"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
441 (t
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
442 ;; FIXME: Shouldn't we just use the union of all the above here?
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
443 ("dynamic" "module")))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
444 "*Alist of Prolog keywords which is used for font locking of directives."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
445 :group 'prolog-font-lock
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
446 :type 'sexp)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
447
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
448 (defcustom prolog-types
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
449 '((mercury
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
450 ("char" "float" "int" "io__state" "string" "univ"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
451 (t nil))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
452 "*Alist of Prolog types used by font locking."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
453 :group 'prolog-font-lock
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
454 :type 'sexp)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
455
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
456 (defcustom prolog-mode-specificators
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
457 '((mercury
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
458 ("bound" "di" "free" "ground" "in" "mdi" "mui" "muo" "out" "ui" "uo"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
459 (t nil))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
460 "*Alist of Prolog mode specificators used by font locking."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
461 :group 'prolog-font-lock
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
462 :type 'sexp)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
463
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
464 (defcustom prolog-determinism-specificators
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
465 '((mercury
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
466 ("cc_multi" "cc_nondet" "det" "erroneous" "failure" "multi" "nondet"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
467 "semidet"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
468 (t nil))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
469 "*Alist of Prolog determinism specificators used by font locking."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
470 :group 'prolog-font-lock
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
471 :type 'sexp)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
472
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
473 (defcustom prolog-directives
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
474 '((mercury
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
475 ("^#[0-9]+"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
476 (t nil))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
477 "*Alist of Prolog source code directives used by font locking."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
478 :group 'prolog-font-lock
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
479 :type 'sexp)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
480
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
481
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
482 ;; Keyboard
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
483
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
484 (defcustom prolog-electric-newline-flag (not (fboundp 'electric-indent-mode))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
485 "*Non-nil means automatically indent the next line when the user types RET."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
486 :group 'prolog-keyboard
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
487 :type 'boolean)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
488
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
489 (defcustom prolog-hungry-delete-key-flag nil
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
490 "*Non-nil means delete key consumes all preceding spaces."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
491 :group 'prolog-keyboard
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
492 :type 'boolean)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
493
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
494 (defcustom prolog-electric-dot-flag nil
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
495 "*Non-nil means make dot key electric.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
496 Electric dot appends newline or inserts head of a new clause.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
497 If dot is pressed at the end of a line where at least one white space
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
498 precedes the point, it inserts a recursive call to the current predicate.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
499 If dot is pressed at the beginning of an empty line, it inserts the head
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
500 of a new clause for the current predicate. It does not apply in strings
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
501 and comments.
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
502 It does not apply in strings and comments."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
503 :group 'prolog-keyboard
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
504 :type 'boolean)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
505
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
506 (defcustom prolog-electric-dot-full-predicate-template nil
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
507 "*If nil, electric dot inserts only the current predicate's name and `('
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
508 for recursive calls or new clause heads. Non-nil means to also
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
509 insert enough commata to cover the predicate's arity and `)',
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
510 and dot and newline for recursive calls."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
511 :group 'prolog-keyboard
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
512 :type 'boolean)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
513
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
514 (defcustom prolog-electric-underscore-flag nil
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
515 "*Non-nil means make underscore key electric.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
516 Electric underscore replaces the current variable with underscore.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
517 If underscore is pressed not on a variable then it behaves as usual."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
518 :group 'prolog-keyboard
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
519 :type 'boolean)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
520
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
521 (defcustom prolog-electric-tab-flag nil
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
522 "*Non-nil means make TAB key electric.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
523 Electric TAB inserts spaces after parentheses, ->, and ;
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
524 in ( If -> Then ; Else) and ( Disj1 ; Disj2 ) style expressions."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
525 :group 'prolog-keyboard
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
526 :type 'boolean)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
527
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
528 (defcustom prolog-electric-if-then-else-flag nil
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
529 "*Non-nil makes `(', `>' and `;' electric
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
530 to automatically indent if-then-else constructs."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
531 :group 'prolog-keyboard
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
532 :type 'boolean)
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
533
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
534 (defcustom prolog-electric-colon-flag nil
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
535 "*Makes `:' electric (inserts `:-' on a new line).
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
536 If non-nil, pressing `:' at the end of a line that starts in
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
537 the first column (i.e., clause heads) inserts ` :-' and newline."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
538 :group 'prolog-keyboard
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
539 :type 'boolean)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
540
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
541 (defcustom prolog-electric-dash-flag nil
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
542 "*Makes `-' electric (inserts a `-->' on a new line).
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
543 If non-nil, pressing `-' at the end of a line that starts in
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
544 the first column (i.e., DCG heads) inserts ` -->' and newline."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
545 :group 'prolog-keyboard
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
546 :type 'boolean)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
547
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
548 (defcustom prolog-old-sicstus-keys-flag nil
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
549 "*Non-nil means old SICStus Prolog mode keybindings are used."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
550 :group 'prolog-keyboard
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
551 :type 'boolean)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
552
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
553 ;; Inferior mode
45608
706ae7fb4033 (prolog-mode-syntax-table): Add flags to ?/ and ?* entries
Thien-Thi Nguyen <ttn@gnuvola.org>
parents: 20396
diff changeset
554
53891
4b85b1e3d610 (prolog-program-name): Use gprolog if available.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 52401
diff changeset
555 (defcustom prolog-program-name
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
556 `(((getenv "EPROLOG") (eval (getenv "EPROLOG")))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
557 (eclipse "eclipse")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
558 (mercury nil)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
559 (sicstus "sicstus")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
560 (swi ,(if (not (executable-find "swipl")) "pl" "swipl"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
561 (gnu "gprolog")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
562 (t ,(let ((names '("prolog" "gprolog" "swipl" "pl")))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
563 (while (and names
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
564 (not (executable-find (car names))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
565 (setq names (cdr names)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
566 (or (car names) "prolog"))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
567 "*Alist of program names for invoking an inferior Prolog with `run-prolog'."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
568 :group 'prolog-inferior
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
569 :type 'sexp)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
570
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
571 (defcustom prolog-program-switches
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
572 '((sicstus ("-i"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
573 (t nil))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
574 "*Alist of switches given to inferior Prolog run with `run-prolog'."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
575 :group 'prolog-inferior
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
576 :type 'sexp)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
577
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
578 (defcustom prolog-consult-string
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
579 '((eclipse "[%f].")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
580 (mercury nil)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
581 (sicstus (eval (if (prolog-atleast-version '(3 . 7))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
582 "prolog:zap_file(%m,%b,consult,%l)."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
583 "prolog:zap_file(%m,%b,consult).")))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
584 (swi "[%f].")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
585 (gnu "[%f].")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
586 (t "reconsult(%f)."))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
587 "*Alist of strings defining predicate for reconsulting.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
588
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
589 Some parts of the string are replaced:
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
590 `%f' by the name of the consulted file (can be a temporary file)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
591 `%b' by the file name of the buffer to consult
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
592 `%m' by the module name and name of the consulted file separated by colon
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
593 `%l' by the line offset into the file. This is 0 unless consulting a
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
594 region of a buffer, in which case it is the number of lines before
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
595 the region."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
596 :group 'prolog-inferior
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
597 :type 'sexp)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
598
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
599 (defcustom prolog-compile-string
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
600 '((eclipse "[%f].")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
601 (mercury "mmake ")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
602 (sicstus (eval (if (prolog-atleast-version '(3 . 7))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
603 "prolog:zap_file(%m,%b,compile,%l)."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
604 "prolog:zap_file(%m,%b,compile).")))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
605 (swi "[%f].")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
606 (t "compile(%f)."))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
607 "*Alist of strings and lists defining predicate for recompilation.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
608
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
609 Some parts of the string are replaced:
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
610 `%f' by the name of the compiled file (can be a temporary file)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
611 `%b' by the file name of the buffer to compile
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
612 `%m' by the module name and name of the compiled file separated by colon
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
613 `%l' by the line offset into the file. This is 0 unless compiling a
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
614 region of a buffer, in which case it is the number of lines before
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
615 the region.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
616
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
617 If `prolog-program-name' is non-nil, it is a string sent to a Prolog process.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
618 If `prolog-program-name' is nil, it is an argument to the `compile' function."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
619 :group 'prolog-inferior
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
620 :type 'sexp)
41
467ee6fe6503 Initial revision
root <root>
parents:
diff changeset
621
17414
f967f12c8ec8 Add defgroup's; use defcustom for user vars.
Richard M. Stallman <rms@gnu.org>
parents: 14169
diff changeset
622 (defcustom prolog-eof-string "end_of_file.\n"
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
623 "*Alist of strings that represent end of file for prolog.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
624 nil means send actual operating system end of file."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
625 :group 'prolog-inferior
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
626 :type 'sexp)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
627
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
628 (defcustom prolog-prompt-regexp
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
629 '((eclipse "^[a-zA-Z0-9()]* *\\?- \\|^\\[[a-zA-Z]* [0-9]*\\]:")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
630 (sicstus "| [ ?][- ] *")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
631 (swi "^\\(\\[[a-zA-Z]*\\] \\)?[1-9]?[0-9]*[ ]?\\?- \\|^| +")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
632 (t "^ *\\?-"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
633 "*Alist of prompts of the prolog system command line."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
634 :group 'prolog-inferior
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
635 :type 'sexp)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
636
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
637 (defcustom prolog-continued-prompt-regexp
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
638 '((sicstus "^\\(| +\\| +\\)")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
639 (t "^|: +"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
640 "*Alist of regexps matching the prompt when consulting `user'."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
641 :group 'prolog-inferior
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
642 :type 'sexp)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
643
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
644 (defcustom prolog-debug-on-string "debug.\n"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
645 "*Predicate for enabling debug mode."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
646 :group 'prolog-inferior
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
647 :type 'string)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
648
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
649 (defcustom prolog-debug-off-string "nodebug.\n"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
650 "*Predicate for disabling debug mode."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
651 :group 'prolog-inferior
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
652 :type 'string)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
653
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
654 (defcustom prolog-trace-on-string "trace.\n"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
655 "*Predicate for enabling tracing."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
656 :group 'prolog-inferior
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
657 :type 'string)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
658
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
659 (defcustom prolog-trace-off-string "notrace.\n"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
660 "*Predicate for disabling tracing."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
661 :group 'prolog-inferior
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
662 :type 'string)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
663
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
664 (defcustom prolog-zip-on-string "zip.\n"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
665 "*Predicate for enabling zip mode for SICStus."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
666 :group 'prolog-inferior
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
667 :type 'string)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
668
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
669 (defcustom prolog-zip-off-string "nozip.\n"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
670 "*Predicate for disabling zip mode for SICStus."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
671 :group 'prolog-inferior
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
672 :type 'string)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
673
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
674 (defcustom prolog-use-standard-consult-compile-method-flag t
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
675 "*Non-nil means use the standard compilation method.
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
676 Otherwise the new compilation method will be used. This
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
677 utilises a special compilation buffer with the associated
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
678 features such as parsing of error messages and automatically
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
679 jumping to the source code responsible for the error.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
680
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
681 Warning: the new method is so far only experimental and
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
682 does contain bugs. The recommended setting for the novice user
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
683 is non-nil for this variable."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
684 :group 'prolog-inferior
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
685 :type 'boolean)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
686
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
687
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
688 ;; Miscellaneous
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
689
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
690 (defcustom prolog-use-prolog-tokenizer-flag
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
691 (not (fboundp 'syntax-propertize-rules))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
692 "*Non-nil means use the internal prolog tokenizer for indentation etc.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
693 Otherwise use `parse-partial-sexp' which is faster but sometimes incorrect."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
694 :group 'prolog-other
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
695 :type 'boolean)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
696
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
697 (defcustom prolog-imenu-flag t
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
698 "*Non-nil means add a clause index menu for all prolog files."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
699 :group 'prolog-other
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
700 :type 'boolean)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
701
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
702 (defcustom prolog-imenu-max-lines 3000
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
703 "*The maximum number of lines of the file for imenu to be enabled.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
704 Relevant only when `prolog-imenu-flag' is non-nil."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
705 :group 'prolog-other
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
706 :type 'integer)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
707
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
708 (defcustom prolog-info-predicate-index
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
709 "(sicstus)Predicate Index"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
710 "*The info node for the SICStus predicate index."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
711 :group 'prolog-other
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
712 :type 'string)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
713
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
714 (defcustom prolog-underscore-wordchar-flag nil
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
715 "*Non-nil means underscore (_) is a word-constituent character."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
716 :group 'prolog-other
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
717 :type 'boolean)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
718
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
719 (defcustom prolog-use-sicstus-sd nil
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
720 "*If non-nil, use the source level debugger of SICStus 3#7 and later."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
721 :group 'prolog-other
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
722 :type 'boolean)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
723
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
724 (defcustom prolog-char-quote-workaround nil
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
725 "*If non-nil, declare 0 as a quote character to handle 0'<char>.
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
726 This is really kludgy, and unneeded (i.e. obsolete) in Emacs>=24."
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
727 :group 'prolog-other
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
728 :type 'boolean)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
729
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
730
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
731 ;;-------------------------------------------------------------------
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
732 ;; Internal variables
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
733 ;;-------------------------------------------------------------------
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
734
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
735 ;;(defvar prolog-temp-filename "") ; Later set by `prolog-temporary-file'
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
736
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
737 (defvar prolog-mode-syntax-table
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
738 ;; The syntax accepted varies depending on the implementation used.
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
739 ;; Here are some of the differences:
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
740 ;; - SWI-Prolog accepts nested /*..*/ comments.
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
741 ;; - Edinburgh-style Prologs take <radix>'<number> for non-decimal number,
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
742 ;; whereas ISO-style Prologs use 0[obx]<number> instead.
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
743 ;; - In atoms \x<hex> sometimes needs a terminating \ (ISO-style)
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
744 ;; and sometimes not.
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
745 (let ((table (make-syntax-table)))
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
746 (if prolog-underscore-wordchar-flag
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
747 (modify-syntax-entry ?_ "w" table)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
748 (modify-syntax-entry ?_ "_" table))
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
749
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
750 (modify-syntax-entry ?+ "." table)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
751 (modify-syntax-entry ?- "." table)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
752 (modify-syntax-entry ?= "." table)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
753 (modify-syntax-entry ?< "." table)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
754 (modify-syntax-entry ?> "." table)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
755 (modify-syntax-entry ?| "." table)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
756 (modify-syntax-entry ?\' "\"" table)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
757
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
758 ;; Any better way to handle the 0'<char> construct?!?
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
759 (when prolog-char-quote-workaround
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
760 (modify-syntax-entry ?0 "\\" table))
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
761
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
762 (modify-syntax-entry ?% "<" table)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
763 (modify-syntax-entry ?\n ">" table)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
764 (if (featurep 'xemacs)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
765 (progn
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
766 (modify-syntax-entry ?* ". 67" table)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
767 (modify-syntax-entry ?/ ". 58" table)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
768 )
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
769 ;; Emacs wants to see this it seems:
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
770 (modify-syntax-entry ?* ". 23b" table)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
771 (modify-syntax-entry ?/ ". 14" table)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
772 )
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
773 table))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
774 (defvar prolog-mode-abbrev-table nil)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
775 (defvar prolog-upper-case-string ""
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
776 "A string containing all upper case characters.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
777 Set by prolog-build-case-strings.")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
778 (defvar prolog-lower-case-string ""
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
779 "A string containing all lower case characters.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
780 Set by prolog-build-case-strings.")
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
781
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
782 (defvar prolog-atom-char-regexp ""
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
783 "Set by prolog-set-atom-regexps.")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
784 ;; "Regexp specifying characters which constitute atoms without quoting.")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
785 (defvar prolog-atom-regexp ""
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
786 "Set by prolog-set-atom-regexps.")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
787
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
788 (defconst prolog-left-paren "[[({]"
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
789 "The characters used as left parentheses for the indentation code.")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
790 (defconst prolog-right-paren "[])}]"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
791 "The characters used as right parentheses for the indentation code.")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
792
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
793 (defconst prolog-quoted-atom-regexp
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
794 "\\(^\\|[^0-9]\\)\\('\\([^\n']\\|\\\\'\\)*'\\)"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
795 "Regexp matching a quoted atom.")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
796 (defconst prolog-string-regexp
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
797 "\\(\"\\([^\n\"]\\|\\\\\"\\)*\"\\)"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
798 "Regexp matching a string.")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
799 (defconst prolog-head-delimiter "\\(:-\\|\\+:\\|-:\\|\\+\\?\\|-\\?\\|-->\\)"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
800 "A regexp for matching on the end delimiter of a head (e.g. \":-\").")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
801
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
802 (defvar prolog-compilation-buffer "*prolog-compilation*"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
803 "Name of the output buffer for Prolog compilation/consulting.")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
804
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
805 (defvar prolog-temporary-file-name nil)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
806 (defvar prolog-keywords-i nil)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
807 (defvar prolog-types-i nil)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
808 (defvar prolog-mode-specificators-i nil)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
809 (defvar prolog-determinism-specificators-i nil)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
810 (defvar prolog-directives-i nil)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
811 (defvar prolog-program-name-i nil)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
812 (defvar prolog-program-switches-i nil)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
813 (defvar prolog-consult-string-i nil)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
814 (defvar prolog-compile-string-i nil)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
815 (defvar prolog-eof-string-i nil)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
816 (defvar prolog-prompt-regexp-i nil)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
817 (defvar prolog-continued-prompt-regexp-i nil)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
818 (defvar prolog-help-function-i nil)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
819
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
820 (defvar prolog-align-rules
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
821 (eval-when-compile
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
822 (mapcar
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
823 (lambda (x)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
824 (let ((name (car x))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
825 (sym (cdr x)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
826 `(,(intern (format "prolog-%s" name))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
827 (regexp . ,(format "\\(\\s-*\\)%s\\(\\s-*\\)" sym))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
828 (tab-stop . nil)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
829 (modes . '(prolog-mode))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
830 (group . (1 2)))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
831 '(("dcg" . "-->") ("rule" . ":-") ("simplification" . "<=>")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
832 ("propagation" . "==>")))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
833
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
834
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
835
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
836 ;;-------------------------------------------------------------------
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
837 ;; Prolog mode
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
838 ;;-------------------------------------------------------------------
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
839
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
840 ;; Example: (prolog-atleast-version '(3 . 6))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
841 (defun prolog-atleast-version (version)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
842 "Return t if the version of the current prolog system is VERSION or later.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
843 VERSION is of the format (Major . Minor)"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
844 ;; Version.major < major or
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
845 ;; Version.major = major and Version.minor <= minor
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
846 (let* ((thisversion (prolog-find-value-by-system prolog-system-version))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
847 (thismajor (car thisversion))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
848 (thisminor (cdr thisversion)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
849 (or (< (car version) thismajor)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
850 (and (= (car version) thismajor)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
851 (<= (cdr version) thisminor)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
852 ))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
853
41
467ee6fe6503 Initial revision
root <root>
parents:
diff changeset
854 (define-abbrev-table 'prolog-mode-abbrev-table ())
467ee6fe6503 Initial revision
root <root>
parents:
diff changeset
855
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
856 (defun prolog-find-value-by-system (alist)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
857 "Get value from ALIST according to `prolog-system'."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
858 (if (listp alist)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
859 (let (result
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
860 id)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
861 (while alist
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
862 (setq id (car (car alist)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
863 (if (or (eq id prolog-system)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
864 (eq id t)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
865 (and (listp id)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
866 (eval id)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
867 (progn
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
868 (setq result (car (cdr (car alist))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
869 (if (and (listp result)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
870 (eq (car result) 'eval))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
871 (setq result (eval (car (cdr result)))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
872 (setq alist nil))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
873 (setq alist (cdr alist))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
874 result)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
875 alist))
108632
d38b0dd2bdbe Provide a simple generic indentation engine and use it for Prolog.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 108588
diff changeset
876
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
877 (defconst prolog-syntax-propertize-function
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
878 (when (fboundp 'syntax-propertize-rules)
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
879 (syntax-propertize-rules
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
880 ;; GNU Prolog only accepts 0'\' rather than 0'', but the only
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
881 ;; possible meaning of 0'' is rather clear.
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
882 ("\\<0\\(''?\\)"
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
883 (1 (unless (save-excursion (nth 8 (syntax-ppss (match-beginning 0))))
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
884 (string-to-syntax "_"))))
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
885 ;; We could check that we're not inside an atom, but I don't think
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
886 ;; that 'foo 8'z could be a valid syntax anyway, so why bother?
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
887 ("\\<[1-9][0-9]*\\('\\)[0-9a-zA-Z]" (1 "_"))
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
888 ;; Supposedly, ISO-Prolog wants \NNN\ for octal and \xNNN\ for hexadecimal
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
889 ;; escape sequences in atoms, so be careful not to let the terminating \
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
890 ;; escape a subsequent quote.
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
891 ("\\\\[x0-7][0-9a-fA-F]*\\(\\\\\\)" (1 "_"))
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
892 )))
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
893
41
467ee6fe6503 Initial revision
root <root>
parents:
diff changeset
894 (defun prolog-mode-variables ()
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
895 "Set some common variables to Prolog code specific values."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
896 (setq local-abbrev-table prolog-mode-abbrev-table)
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
897 (set (make-local-variable 'paragraph-start)
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
898 (concat "[ \t]*$\\|" page-delimiter)) ;'%%..'
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
899 (set (make-local-variable 'paragraph-separate) paragraph-start)
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
900 (set (make-local-variable 'paragraph-ignore-fill-prefix) t)
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
901 (set (make-local-variable 'normal-auto-fill-function) 'prolog-do-auto-fill)
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
902 (set (make-local-variable 'indent-line-function) 'prolog-indent-line)
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
903 (set (make-local-variable 'comment-start) "%")
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
904 (set (make-local-variable 'comment-end) "")
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
905 (set (make-local-variable 'comment-add) 1)
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
906 (set (make-local-variable 'comment-start-skip)
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
907 ;; This complex regexp makes sure that comments cannot start
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
908 ;; inside quoted atoms or strings
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
909 (format "^\\(\\(%s\\|%s\\|[^\n\'\"%%]\\)*\\)\\(/\\*+ *\\|%%+ *\\)"
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
910 prolog-quoted-atom-regexp prolog-string-regexp))
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
911 (set (make-local-variable 'comment-indent-function) 'prolog-comment-indent)
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
912 (set (make-local-variable 'parens-require-spaces) nil)
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
913 ;; Initialize Prolog system specific variables
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
914 (dolist (var '(prolog-keywords prolog-types prolog-mode-specificators
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
915 prolog-determinism-specificators prolog-directives
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
916 prolog-program-name prolog-program-switches
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
917 prolog-consult-string prolog-compile-string prolog-eof-string
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
918 prolog-prompt-regexp prolog-continued-prompt-regexp
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
919 prolog-help-function))
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
920 (set (intern (concat (symbol-name var) "-i"))
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
921 (prolog-find-value-by-system (symbol-value var))))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
922 (when (null prolog-program-name-i)
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
923 (set (make-local-variable 'compile-command) prolog-compile-string-i))
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
924 (set (make-local-variable 'font-lock-defaults)
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
925 '(prolog-font-lock-keywords nil nil ((?_ . "w"))))
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
926 (set (make-local-variable 'syntax-propertize-function)
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
927 prolog-syntax-propertize-function)
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
928 )
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
929
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
930 (defun prolog-mode-keybindings-common (map)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
931 "Define keybindings common to both Prolog modes in MAP."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
932 (define-key map "\C-c?" 'prolog-help-on-predicate)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
933 (define-key map "\C-c/" 'prolog-help-apropos)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
934 (define-key map "\C-c\C-d" 'prolog-debug-on)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
935 (define-key map "\C-c\C-t" 'prolog-trace-on)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
936 (if (and (eq prolog-system 'sicstus)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
937 (prolog-atleast-version '(3 . 7)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
938 (define-key map "\C-c\C-z" 'prolog-zip-on))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
939 (define-key map "\C-c\r" 'run-prolog))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
940
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
941 (defun prolog-mode-keybindings-edit (map)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
942 "Define keybindings for Prolog mode in MAP."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
943 (define-key map "\M-a" 'prolog-beginning-of-clause)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
944 (define-key map "\M-e" 'prolog-end-of-clause)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
945 (define-key map "\M-q" 'prolog-fill-paragraph)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
946 (define-key map "\C-c\C-a" 'align)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
947 (define-key map "\C-\M-a" 'prolog-beginning-of-predicate)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
948 (define-key map "\C-\M-e" 'prolog-end-of-predicate)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
949 (define-key map "\M-\C-c" 'prolog-mark-clause)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
950 (define-key map "\M-\C-h" 'prolog-mark-predicate)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
951 (define-key map "\M-\C-n" 'prolog-forward-list)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
952 (define-key map "\M-\C-p" 'prolog-backward-list)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
953 (define-key map "\C-c\C-n" 'prolog-insert-predicate-template)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
954 (define-key map "\C-c\C-s" 'prolog-insert-predspec)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
955 (define-key map "\M-\r" 'prolog-insert-next-clause)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
956 (define-key map "\C-c\C-va" 'prolog-variables-to-anonymous)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
957 (define-key map "\C-c\C-v\C-s" 'prolog-view-predspec)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
958
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
959 (define-key map [Backspace] 'prolog-electric-delete)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
960 (define-key map "." 'prolog-electric-dot)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
961 (define-key map "_" 'prolog-electric-underscore)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
962 (define-key map "(" 'prolog-electric-if-then-else)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
963 (define-key map ";" 'prolog-electric-if-then-else)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
964 (define-key map ">" 'prolog-electric-if-then-else)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
965 (define-key map ":" 'prolog-electric-colon)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
966 (define-key map "-" 'prolog-electric-dash)
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
967 (if prolog-electric-newline-flag
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
968 (define-key map "\r" 'newline-and-indent))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
969
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
970 ;; If we're running SICStus, then map C-c C-c e/d to enabling
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
971 ;; and disabling of the source-level debugging facilities.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
972 ;(if (and (eq prolog-system 'sicstus)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
973 ; (prolog-atleast-version '(3 . 7)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
974 ; (progn
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
975 ; (define-key map "\C-c\C-ce" 'prolog-enable-sicstus-sd)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
976 ; (define-key map "\C-c\C-cd" 'prolog-disable-sicstus-sd)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
977 ; ))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
978
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
979 (if prolog-old-sicstus-keys-flag
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
980 (progn
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
981 (define-key map "\C-c\C-c" 'prolog-consult-predicate)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
982 (define-key map "\C-cc" 'prolog-consult-region)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
983 (define-key map "\C-cC" 'prolog-consult-buffer)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
984 (define-key map "\C-c\C-k" 'prolog-compile-predicate)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
985 (define-key map "\C-ck" 'prolog-compile-region)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
986 (define-key map "\C-cK" 'prolog-compile-buffer))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
987 (define-key map "\C-c\C-p" 'prolog-consult-predicate)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
988 (define-key map "\C-c\C-r" 'prolog-consult-region)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
989 (define-key map "\C-c\C-b" 'prolog-consult-buffer)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
990 (define-key map "\C-c\C-f" 'prolog-consult-file)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
991 (define-key map "\C-c\C-cp" 'prolog-compile-predicate)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
992 (define-key map "\C-c\C-cr" 'prolog-compile-region)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
993 (define-key map "\C-c\C-cb" 'prolog-compile-buffer)
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
994 (define-key map "\C-c\C-cf" 'prolog-compile-file))
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
995
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
996 ;; Inherited from the old prolog.el.
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
997 (define-key map "\e\C-x" 'prolog-consult-region)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
998 (define-key map "\C-c\C-l" 'prolog-consult-file)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
999 (define-key map "\C-c\C-z" 'switch-to-prolog))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1000
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1001 (defun prolog-mode-keybindings-inferior (map)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1002 "Define keybindings for inferior Prolog mode in MAP."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1003 ;; No inferior mode specific keybindings now.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1004 )
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1005
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
1006 (defvar prolog-mode-map
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
1007 (let ((map (make-sparse-keymap)))
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
1008 (prolog-mode-keybindings-common map)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
1009 (prolog-mode-keybindings-edit map)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
1010 map))
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1011
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1012
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1013 (defvar prolog-mode-hook nil
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1014 "List of functions to call after the prolog mode has initialised.")
41
467ee6fe6503 Initial revision
root <root>
parents:
diff changeset
1015
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
1016 (unless (fboundp 'prog-mode)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
1017 (defalias 'prog-mode 'fundamental-mode))
258
1e0bc00dca7a *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 242
diff changeset
1018 ;;;###autoload
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
1019 (define-derived-mode prolog-mode prog-mode "Prolog"
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1020 "Major mode for editing Prolog code.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1021
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1022 Blank lines and `%%...' separate paragraphs. `%'s starts a comment
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1023 line and comments can also be enclosed in /* ... */.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1024
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1025 If an optional argument SYSTEM is non-nil, set up mode for the given system.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1026
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1027 To find out what version of Prolog mode you are running, enter
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1028 `\\[prolog-mode-version]'.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1029
41
467ee6fe6503 Initial revision
root <root>
parents:
diff changeset
1030 Commands:
467ee6fe6503 Initial revision
root <root>
parents:
diff changeset
1031 \\{prolog-mode-map}
242
5647f2040009 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 41
diff changeset
1032 Entry to this mode calls the value of `prolog-mode-hook'
41
467ee6fe6503 Initial revision
root <root>
parents:
diff changeset
1033 if that value is non-nil."
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1034 (setq mode-name (concat "Prolog"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1035 (cond
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1036 ((eq prolog-system 'eclipse) "[ECLiPSe]")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1037 ((eq prolog-system 'sicstus) "[SICStus]")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1038 ((eq prolog-system 'swi) "[SWI]")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1039 ((eq prolog-system 'gnu) "[GNU]")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1040 (t ""))))
41
467ee6fe6503 Initial revision
root <root>
parents:
diff changeset
1041 (prolog-mode-variables)
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1042 (prolog-build-case-strings)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1043 (prolog-set-atom-regexps)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1044 (dolist (ar prolog-align-rules) (add-to-list 'align-rules-list ar))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1045
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1046 ;; imenu entry moved to the appropriate hook for consistency
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1047
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1048 ;; Load SICStus debugger if suitable
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1049 (if (and (eq prolog-system 'sicstus)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1050 (prolog-atleast-version '(3 . 7))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1051 prolog-use-sicstus-sd)
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1052 (prolog-enable-sicstus-sd))
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1053
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1054 (prolog-menu))
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
1055
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
1056 (defvar mercury-mode-map
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
1057 (let ((map (make-sparse-keymap)))
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
1058 (set-keymap-parent map prolog-mode-map)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
1059 map))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1060
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1061 ;;;###autoload
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
1062 (define-derived-mode mercury-mode prolog-mode "Prolog[Mercury]"
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1063 "Major mode for editing Mercury programs.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1064 Actually this is just customized `prolog-mode'."
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
1065 (set (make-local-variable 'prolog-system) 'mercury))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1066
41
467ee6fe6503 Initial revision
root <root>
parents:
diff changeset
1067
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1068 ;;-------------------------------------------------------------------
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1069 ;; Inferior prolog mode
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1070 ;;-------------------------------------------------------------------
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1071
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
1072 (defvar prolog-inferior-mode-map
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
1073 (let ((map (make-sparse-keymap)))
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
1074 (prolog-mode-keybindings-common map)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
1075 (prolog-mode-keybindings-inferior map)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
1076 map))
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1077
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1078 (defvar prolog-inferior-mode-hook nil
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1079 "List of functions to call after the inferior prolog mode has initialised.")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1080
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
1081 (define-derived-mode prolog-inferior-mode comint-mode "Inferior Prolog"
41
467ee6fe6503 Initial revision
root <root>
parents:
diff changeset
1082 "Major mode for interacting with an inferior Prolog process.
467ee6fe6503 Initial revision
root <root>
parents:
diff changeset
1083
467ee6fe6503 Initial revision
root <root>
parents:
diff changeset
1084 The following commands are available:
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1085 \\{prolog-inferior-mode-map}
41
467ee6fe6503 Initial revision
root <root>
parents:
diff changeset
1086
242
5647f2040009 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 41
diff changeset
1087 Entry to this mode calls the value of `prolog-mode-hook' with no arguments,
5647f2040009 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 41
diff changeset
1088 if that value is non-nil. Likewise with the value of `comint-mode-hook'.
5647f2040009 *** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents: 41
diff changeset
1089 `prolog-mode-hook' is called after `comint-mode-hook'.
41
467ee6fe6503 Initial revision
root <root>
parents:
diff changeset
1090
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1091 You can send text to the inferior Prolog from other buffers
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1092 using the commands `send-region', `send-string' and \\[prolog-consult-region].
41
467ee6fe6503 Initial revision
root <root>
parents:
diff changeset
1093
467ee6fe6503 Initial revision
root <root>
parents:
diff changeset
1094 Commands:
467ee6fe6503 Initial revision
root <root>
parents:
diff changeset
1095 Tab indents for Prolog; with argument, shifts rest
467ee6fe6503 Initial revision
root <root>
parents:
diff changeset
1096 of expression rigidly with the current line.
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1097 Paragraphs are separated only by blank lines and '%%'. '%'s start comments.
41
467ee6fe6503 Initial revision
root <root>
parents:
diff changeset
1098
467ee6fe6503 Initial revision
root <root>
parents:
diff changeset
1099 Return at end of buffer sends line as input.
467ee6fe6503 Initial revision
root <root>
parents:
diff changeset
1100 Return not at end copies rest of line to end and sends it.
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1101 \\[comint-delchar-or-maybe-eof] sends end-of-file as input.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1102 \\[comint-kill-input] and \\[backward-kill-word] are kill commands,
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1103 imitating normal Unix input editing.
41
467ee6fe6503 Initial revision
root <root>
parents:
diff changeset
1104 \\[comint-interrupt-subjob] interrupts the shell or its current subjob if any.
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1105 \\[comint-stop-subjob] stops, likewise.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1106 \\[comint-quit-subjob] sends quit signal, likewise.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1107
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1108 To find out what version of Prolog mode you are running, enter
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1109 `\\[prolog-mode-version]'."
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
1110 (setq comint-input-filter 'prolog-input-filter)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
1111 (setq mode-line-process '(": %s"))
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
1112 (prolog-mode-variables)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
1113 (setq comint-prompt-regexp prolog-prompt-regexp-i)
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1114 (set (make-local-variable 'shell-dirstack-query) "pwd.")
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1115 (prolog-inferior-menu))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1116
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1117 (defun prolog-input-filter (str)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1118 (cond ((string-match "\\`\\s *\\'" str) nil) ;whitespace
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1119 ((not (eq major-mode 'prolog-inferior-mode)) t)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1120 ((= (length str) 1) nil) ;one character
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1121 ((string-match "\\`[rf] *[0-9]*\\'" str) nil) ;r(edo) or f(ail)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1122 (t t)))
72696
560a2e73e11b (inferior-prolog-flavor): New var left out of previous commit.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 72684
diff changeset
1123
258
1e0bc00dca7a *** empty log message ***
Jim Blandy <jimb@redhat.com>
parents: 242
diff changeset
1124 ;;;###autoload
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1125 (defun run-prolog (arg)
72684
f65ec4fd2be1 Remove * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 68773
diff changeset
1126 "Run an inferior Prolog process, input and output via buffer *prolog*.
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1127 With prefix argument ARG, restart the Prolog process if running before."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1128 (interactive "P")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1129 (if (and arg (get-process "prolog"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1130 (progn
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1131 (process-send-string "prolog" "halt.\n")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1132 (while (get-process "prolog") (sit-for 0.1))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1133 (let ((buff (buffer-name)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1134 (if (not (string= buff "*prolog*"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1135 (prolog-goto-prolog-process-buffer))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1136 ;; Load SICStus debugger if suitable
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1137 (if (and (eq prolog-system 'sicstus)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1138 (prolog-atleast-version '(3 . 7))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1139 prolog-use-sicstus-sd)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1140 (prolog-enable-sicstus-sd))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1141 (prolog-mode-variables)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1142 (prolog-ensure-process)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1143 ))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1144
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1145 (defun prolog-ensure-process (&optional wait)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1146 "If Prolog process is not running, run it.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1147 If the optional argument WAIT is non-nil, wait for Prolog prompt specified by
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1148 the variable `prolog-prompt-regexp'."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1149 (if (null prolog-program-name-i)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1150 (error "This Prolog system has defined no interpreter."))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1151 (if (comint-check-proc "*prolog*")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1152 ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1153 (apply 'make-comint "prolog" prolog-program-name-i nil
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1154 prolog-program-switches-i)
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
1155 (with-current-buffer "*prolog*"
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1156 (prolog-inferior-mode)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1157 (if wait
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1158 (progn
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1159 (goto-char (point-max))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1160 (while
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1161 (save-excursion
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1162 (not
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1163 (re-search-backward
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1164 (concat "\\(" prolog-prompt-regexp-i "\\)" "\\=")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1165 nil t)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1166 (sit-for 0.1)))))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1167
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1168 (defun prolog-process-insert-string (process string)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1169 "Insert STRING into inferior Prolog buffer running PROCESS."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1170 ;; Copied from elisp manual, greek to me
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
1171 (with-current-buffer (process-buffer process)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
1172 ;; FIXME: Use window-point-insertion-type instead.
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
1173 (let ((moving (= (point) (process-mark process))))
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
1174 (save-excursion
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
1175 ;; Insert the text, moving the process-marker.
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
1176 (goto-char (process-mark process))
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
1177 (insert string)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
1178 (set-marker (process-mark process) (point)))
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
1179 (if moving (goto-char (process-mark process))))))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1180
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1181 ;;------------------------------------------------------------
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1182 ;; Old consulting and compiling functions
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1183 ;;------------------------------------------------------------
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1184
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1185 (defun prolog-old-process-region (compilep start end)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1186 "Process the region limited by START and END positions.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1187 If COMPILEP is non-nil then use compilation, otherwise consulting."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1188 (prolog-ensure-process)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1189 ;(let ((tmpfile prolog-temp-filename)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1190 (let ((tmpfile (prolog-bsts (prolog-temporary-file)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1191 ;(process (get-process "prolog"))
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1192 (first-line (1+ (count-lines
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1193 (point-min)
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1194 (save-excursion
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1195 (goto-char start)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1196 (point))))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1197 (write-region start end tmpfile)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1198 (process-send-string
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1199 "prolog" (prolog-build-prolog-command
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1200 compilep tmpfile (prolog-bsts buffer-file-name)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1201 first-line))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1202 (prolog-goto-prolog-process-buffer)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1203
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1204 (defun prolog-old-process-predicate (compilep)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1205 "Process the predicate around point.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1206 If COMPILEP is non-nil then use compilation, otherwise consulting."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1207 (prolog-old-process-region
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1208 compilep (prolog-pred-start) (prolog-pred-end)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1209
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1210 (defun prolog-old-process-buffer (compilep)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1211 "Process the entire buffer.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1212 If COMPILEP is non-nil then use compilation, otherwise consulting."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1213 (prolog-old-process-region compilep (point-min) (point-max)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1214
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1215 (defun prolog-old-process-file (compilep)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1216 "Process the file of the current buffer.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1217 If COMPILEP is non-nil then use compilation, otherwise consulting."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1218 (save-some-buffers)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1219 (prolog-ensure-process)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1220 (let ((filename (prolog-bsts buffer-file-name)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1221 (process-send-string
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1222 "prolog" (prolog-build-prolog-command
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1223 compilep filename filename))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1224 (prolog-goto-prolog-process-buffer)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1225
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1226
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1227 ;;------------------------------------------------------------
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1228 ;; Consulting and compiling
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1229 ;;------------------------------------------------------------
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1230
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1231 ;;; Interactive interface functions, used by both the standard
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1232 ;;; and the experimental consultation and compilation functions
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1233 (defun prolog-consult-file ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1234 "Consult file of current buffer."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1235 (interactive)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1236 (if prolog-use-standard-consult-compile-method-flag
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1237 (prolog-old-process-file nil)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1238 (prolog-consult-compile-file nil)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1239
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1240 (defun prolog-consult-buffer ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1241 "Consult buffer."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1242 (interactive)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1243 (if prolog-use-standard-consult-compile-method-flag
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1244 (prolog-old-process-buffer nil)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1245 (prolog-consult-compile-buffer nil)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1246
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1247 (defun prolog-consult-region (beg end)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1248 "Consult region between BEG and END."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1249 (interactive "r")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1250 (if prolog-use-standard-consult-compile-method-flag
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1251 (prolog-old-process-region nil beg end)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1252 (prolog-consult-compile-region nil beg end)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1253
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1254 (defun prolog-consult-predicate ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1255 "Consult the predicate around current point."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1256 (interactive)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1257 (if prolog-use-standard-consult-compile-method-flag
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1258 (prolog-old-process-predicate nil)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1259 (prolog-consult-compile-predicate nil)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1260
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1261 (defun prolog-compile-file ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1262 "Compile file of current buffer."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1263 (interactive)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1264 (if prolog-use-standard-consult-compile-method-flag
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1265 (prolog-old-process-file t)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1266 (prolog-consult-compile-file t)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1267
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1268 (defun prolog-compile-buffer ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1269 "Compile buffer."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1270 (interactive)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1271 (if prolog-use-standard-consult-compile-method-flag
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1272 (prolog-old-process-buffer t)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1273 (prolog-consult-compile-buffer t)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1274
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1275 (defun prolog-compile-region (beg end)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1276 "Compile region between BEG and END."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1277 (interactive "r")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1278 (if prolog-use-standard-consult-compile-method-flag
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1279 (prolog-old-process-region t beg end)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1280 (prolog-consult-compile-region t beg end)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1281
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1282 (defun prolog-compile-predicate ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1283 "Compile the predicate around current point."
72696
560a2e73e11b (inferior-prolog-flavor): New var left out of previous commit.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 72684
diff changeset
1284 (interactive)
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1285 (if prolog-use-standard-consult-compile-method-flag
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1286 (prolog-old-process-predicate t)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1287 (prolog-consult-compile-predicate t)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1288
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1289 (defun prolog-buffer-module ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1290 "Select Prolog module name appropriate for current buffer.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1291 Bases decision on buffer contents (-*- line)."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1292 ;; Look for -*- ... module: MODULENAME; ... -*-
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1293 (let (beg end)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1294 (save-excursion
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1295 (goto-char (point-min))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1296 (skip-chars-forward " \t")
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1297 (and (search-forward "-*-" (line-end-position) t)
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1298 (progn
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1299 (skip-chars-forward " \t")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1300 (setq beg (point))
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1301 (search-forward "-*-" (line-end-position) t))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1302 (progn
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1303 (forward-char -3)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1304 (skip-chars-backward " \t")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1305 (setq end (point))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1306 (goto-char beg)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1307 (and (let ((case-fold-search t))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1308 (search-forward "module:" end t))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1309 (progn
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1310 (skip-chars-forward " \t")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1311 (setq beg (point))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1312 (if (search-forward ";" end t)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1313 (forward-char -1)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1314 (goto-char end))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1315 (skip-chars-backward " \t")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1316 (buffer-substring beg (point)))))))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1317
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1318 (defun prolog-build-prolog-command (compilep file buffername
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1319 &optional first-line)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1320 "Make Prolog command for FILE compilation/consulting.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1321 If COMPILEP is non-nil, consider compilation, otherwise consulting."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1322 (let* ((compile-string
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1323 (if compilep prolog-compile-string-i prolog-consult-string-i))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1324 (module (prolog-buffer-module))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1325 (file-name (concat "'" file "'"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1326 (module-name (if module (concat "'" module "'")))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1327 (module-file (if module
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1328 (concat module-name ":" file-name)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1329 file-name))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1330 strbeg strend
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1331 (lineoffset (if first-line
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1332 (- first-line 1)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1333 0)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1334
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1335 ;; Assure that there is a buffer name
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1336 (if (not buffername)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1337 (error "The buffer is not saved"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1338
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1339 (if (not (string-match "\\`'.*'\\'" buffername)) ; Add quotes
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1340 (setq buffername (concat "'" buffername "'")))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1341 (while (string-match "%m" compile-string)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1342 (setq strbeg (substring compile-string 0 (match-beginning 0)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1343 (setq strend (substring compile-string (match-end 0)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1344 (setq compile-string (concat strbeg module-file strend)))
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1345 ;; FIXME: The code below will %-expand any %[fbl] that appears in
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1346 ;; module-file.
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1347 (while (string-match "%f" compile-string)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1348 (setq strbeg (substring compile-string 0 (match-beginning 0)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1349 (setq strend (substring compile-string (match-end 0)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1350 (setq compile-string (concat strbeg file-name strend)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1351 (while (string-match "%b" compile-string)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1352 (setq strbeg (substring compile-string 0 (match-beginning 0)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1353 (setq strend (substring compile-string (match-end 0)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1354 (setq compile-string (concat strbeg buffername strend)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1355 (while (string-match "%l" compile-string)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1356 (setq strbeg (substring compile-string 0 (match-beginning 0)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1357 (setq strend (substring compile-string (match-end 0)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1358 (setq compile-string (concat strbeg (format "%d" lineoffset) strend)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1359 (concat compile-string "\n")))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1360
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1361 ;;; The rest of this page is experimental code!
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1362
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1363 ;; Global variables for process filter function
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1364 (defvar prolog-process-flag nil
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1365 "Non-nil means that a prolog task (i.e. a consultation or compilation job)
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1366 is running.")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1367 (defvar prolog-consult-compile-output ""
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1368 "Hold the unprocessed output from the current prolog task.")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1369 (defvar prolog-consult-compile-first-line 1
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1370 "The number of the first line of the file to consult/compile.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1371 Used for temporary files.")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1372 (defvar prolog-consult-compile-file nil
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1373 "The file to compile/consult (can be a temporary file).")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1374 (defvar prolog-consult-compile-real-file nil
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1375 "The file name of the buffer to compile/consult.")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1376
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1377 (defun prolog-consult-compile (compilep file &optional first-line)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1378 "Consult/compile FILE.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1379 If COMPILEP is non-nil, perform compilation, otherwise perform CONSULTING.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1380 COMMAND is a string described by the variables `prolog-consult-string'
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1381 and `prolog-compile-string'.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1382 Optional argument FIRST-LINE is the number of the first line in the compiled
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1383 region.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1384
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1385 This function must be called from the source code buffer."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1386 (if prolog-process-flag
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1387 (error "Another Prolog task is running."))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1388 (prolog-ensure-process t)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1389 (let* ((buffer (get-buffer-create prolog-compilation-buffer))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1390 (real-file buffer-file-name)
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1391 (command-string (prolog-build-prolog-command compilep file
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1392 real-file first-line))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1393 (process (get-process "prolog"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1394 (old-filter (process-filter process)))
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
1395 (with-current-buffer buffer
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1396 (delete-region (point-min) (point-max))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1397 (compilation-mode)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1398 ;; Setting up font-locking for this buffer
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1399 (set (make-local-variable 'font-lock-defaults)
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1400 '(prolog-font-lock-keywords nil nil ((?_ . "w"))))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1401 (if (eq prolog-system 'sicstus)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1402 (progn
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1403 (set (make-local-variable 'compilation-parse-errors-function)
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1404 'prolog-parse-sicstus-compilation-errors)))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1405 (toggle-read-only 0)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1406 (insert command-string "\n"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1407 (save-selected-window
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1408 (pop-to-buffer buffer))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1409 (setq prolog-process-flag t
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1410 prolog-consult-compile-output ""
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1411 prolog-consult-compile-first-line (if first-line (1- first-line) 0)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1412 prolog-consult-compile-file file
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1413 prolog-consult-compile-real-file (if (string=
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1414 file buffer-file-name)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1415 nil
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1416 real-file))
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
1417 (with-current-buffer buffer
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1418 (goto-char (point-max))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1419 (set-process-filter process 'prolog-consult-compile-filter)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1420 (process-send-string "prolog" command-string)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1421 ;; (prolog-build-prolog-command compilep file real-file first-line))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1422 (while (and prolog-process-flag
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1423 (accept-process-output process 10)) ; 10 secs is ok?
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1424 (sit-for 0.1)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1425 (unless (get-process "prolog")
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1426 (setq prolog-process-flag nil)))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1427 (insert (if compilep
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1428 "\nCompilation finished.\n"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1429 "\nConsulted.\n"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1430 (set-process-filter process old-filter))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1431
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1432 (defun prolog-parse-sicstus-compilation-errors (limit)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1433 "Parse the prolog compilation buffer for errors.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1434 Argument LIMIT is a buffer position limiting searching.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1435 For use with the `compilation-parse-errors-function' variable."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1436 (setq compilation-error-list nil)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1437 (message "Parsing SICStus error messages...")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1438 (let (filepath dir file errorline)
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1439 (while
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1440 (re-search-backward
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1441 "{\\([a-zA-Z ]* ERROR\\|Warning\\):.* in line[s ]*\\([0-9]+\\)"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1442 limit t)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1443 (setq errorline (string-to-number (match-string 2)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1444 (save-excursion
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1445 (re-search-backward
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1446 "{\\(consulting\\|compiling\\|processing\\) \\(.*\\)\\.\\.\\.}"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1447 limit t)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1448 (setq filepath (match-string 2)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1449
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1450 ;; ###### Does this work with SICStus under Windows (i.e. backslahes and stuff?)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1451 (if (string-match "\\(.*/\\)\\([^/]*\\)$" filepath)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1452 (progn
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1453 (setq dir (match-string 1 filepath))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1454 (setq file (match-string 2 filepath))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1455
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1456 (setq compilation-error-list
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1457 (cons
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1458 (cons (save-excursion
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1459 (beginning-of-line)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1460 (point-marker))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1461 (list (list file dir) errorline))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1462 compilation-error-list)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1463 ))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1464 ))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1465
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1466 (defun prolog-consult-compile-filter (process output)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1467 "Filter function for Prolog compilation PROCESS.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1468 Argument OUTPUT is a name of the output file."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1469 ;;(message "start")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1470 (setq prolog-consult-compile-output
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1471 (concat prolog-consult-compile-output output))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1472 ;;(message "pccf1: %s" prolog-consult-compile-output)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1473 ;; Iterate through the lines of prolog-consult-compile-output
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1474 (let (outputtype)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1475 (while (and prolog-process-flag
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1476 (or
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1477 ;; Trace question
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1478 (progn
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1479 (setq outputtype 'trace)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1480 (and (eq prolog-system 'sicstus)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1481 (string-match
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1482 "^[ \t]*[0-9]+[ \t]*[0-9]+[ \t]*Call:.*? "
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1483 prolog-consult-compile-output)))
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1484
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1485 ;; Match anything
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1486 (progn
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1487 (setq outputtype 'normal)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1488 (string-match "^.*\n" prolog-consult-compile-output))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1489 ))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1490 ;;(message "outputtype: %s" outputtype)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1491
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1492 (setq output (match-string 0 prolog-consult-compile-output))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1493 ;; remove the text in output from prolog-consult-compile-output
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1494 (setq prolog-consult-compile-output
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1495 (substring prolog-consult-compile-output (length output)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1496 ;;(message "pccf2: %s" prolog-consult-compile-output)
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1497
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1498 ;; If temporary files were used, then we change the error
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1499 ;; messages to point to the original source file.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1500 (cond
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1501
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1502 ;; If the prolog process was in trace mode then it requires
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1503 ;; user input
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1504 ((and (eq prolog-system 'sicstus)
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1505 (eq outputtype 'trace))
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1506 (let ((input (concat (read-string output) "\n")))
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
1507 (process-send-string process input)
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1508 (setq output (concat output input))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1509
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1510 ((eq prolog-system 'sicstus)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1511 (if (and prolog-consult-compile-real-file
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1512 (string-match
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1513 "\\({.*:.* in line[s ]*\\)\\([0-9]+\\)-\\([0-9]+\\)" output))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1514 (setq output (replace-match
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1515 ;; Adds a {processing ...} line so that
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1516 ;; `prolog-parse-sicstus-compilation-errors'
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1517 ;; finds the real file instead of the temporary one.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1518 ;; Also fixes the line numbers.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1519 (format "Added by Emacs: {processing %s...}\n%s%d-%d"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1520 prolog-consult-compile-real-file
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1521 (match-string 1 output)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1522 (+ prolog-consult-compile-first-line
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1523 (string-to-number
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1524 (match-string 2 output)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1525 (+ prolog-consult-compile-first-line
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1526 (string-to-number
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1527 (match-string 3 output))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1528 t t output)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1529 )
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1530
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1531 ((eq prolog-system 'swi)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1532 (if (and prolog-consult-compile-real-file
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1533 (string-match (format
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1534 "%s\\([ \t]*:[ \t]*\\)\\([0-9]+\\)"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1535 prolog-consult-compile-file)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1536 output))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1537 (setq output (replace-match
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1538 ;; Real filename + text + fixed linenum
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1539 (format "%s%s%d"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1540 prolog-consult-compile-real-file
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1541 (match-string 1 output)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1542 (+ prolog-consult-compile-first-line
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1543 (string-to-number
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1544 (match-string 2 output))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1545 t t output)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1546 )
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1547
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1548 (t ())
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1549 )
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1550 ;; Write the output in the *prolog-compilation* buffer
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1551 (insert output)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1552
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1553 ;; If the prompt is visible, then the task is finished
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1554 (if (string-match prolog-prompt-regexp-i prolog-consult-compile-output)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1555 (setq prolog-process-flag nil)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1556
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1557 (defun prolog-consult-compile-file (compilep)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1558 "Consult/compile file of current buffer.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1559 If COMPILEP is non-nil, compile, otherwise consult."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1560 (let ((file buffer-file-name))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1561 (if file
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1562 (progn
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1563 (save-some-buffers)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1564 (prolog-consult-compile compilep file))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1565 (prolog-consult-compile-region compilep (point-min) (point-max)))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1566
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1567 (defun prolog-consult-compile-buffer (compilep)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1568 "Consult/compile current buffer.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1569 If COMPILEP is non-nil, compile, otherwise consult."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1570 (prolog-consult-compile-region compilep (point-min) (point-max)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1571
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1572 (defun prolog-consult-compile-region (compilep beg end)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1573 "Consult/compile region between BEG and END.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1574 If COMPILEP is non-nil, compile, otherwise consult."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1575 ;(let ((file prolog-temp-filename)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1576 (let ((file (prolog-bsts (prolog-temporary-file)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1577 (lines (count-lines 1 beg)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1578 (write-region beg end file nil 'no-message)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1579 (write-region "\n" nil file t 'no-message)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1580 (prolog-consult-compile compilep file
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1581 (if (looking-at "^") (1+ lines) lines))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1582 (delete-file file)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1583
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1584 (defun prolog-consult-compile-predicate (compilep)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1585 "Consult/compile the predicate around current point.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1586 If COMPILEP is non-nil, compile, otherwise consult."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1587 (prolog-consult-compile-region
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1588 compilep (prolog-pred-start) (prolog-pred-end)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1589
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1590
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1591 ;;-------------------------------------------------------------------
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1592 ;; Font-lock stuff
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1593 ;;-------------------------------------------------------------------
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1594
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1595 ;; Auxilliary functions
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1596 (defun prolog-make-keywords-regexp (keywords &optional protect)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1597 "Create regexp from the list of strings KEYWORDS.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1598 If PROTECT is non-nil, surround the result regexp by word breaks."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1599 (let ((regexp
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1600 (if (fboundp 'regexp-opt)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1601 ;; Emacs 20
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1602 ;; Avoid compile warnings under earlier versions by using eval
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1603 (eval '(regexp-opt keywords))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1604 ;; Older Emacsen
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1605 (concat (mapconcat 'regexp-quote keywords "\\|")))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1606 ))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1607 (if protect
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1608 (concat "\\<\\(" regexp "\\)\\>")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1609 regexp)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1610
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1611 (defun prolog-font-lock-object-matcher (bound)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1612 "Find SICStus objects method name for font lock.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1613 Argument BOUND is a buffer position limiting searching."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1614 (let (point
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1615 (case-fold-search nil))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1616 (while (and (not point)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1617 (re-search-forward "\\(::[ \t\n]*{\\|&\\)[ \t]*"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1618 bound t))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1619 (while (or (re-search-forward "\\=\n[ \t]*" bound t)
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1620 (re-search-forward "\\=%.*" bound t)
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1621 (and (re-search-forward "\\=/\\*" bound t)
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1622 (re-search-forward "\\*/[ \t]*" bound t))))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1623 (setq point (re-search-forward
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1624 (format "\\=\\(%s\\)" prolog-atom-regexp)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1625 bound t)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1626 point))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1627
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1628 (defsubst prolog-face-name-p (facename)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1629 ;; Return t if FACENAME is the name of a face. This method is
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1630 ;; necessary since facep in XEmacs only returns t for the actual
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1631 ;; face objects (while it's only their names that are used just
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1632 ;; about anywhere else) without providing a predicate that tests
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1633 ;; face names. This function (including the above commentary) is
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1634 ;; borrowed from cc-mode.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1635 (memq facename (face-list)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1636
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1637 ;; Set everything up
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1638 (defun prolog-font-lock-keywords ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1639 "Set up font lock keywords for the current Prolog system."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1640 ;(when window-system
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1641 (require 'font-lock)
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1642
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1643 ;; Define Prolog faces
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1644 (defface prolog-redo-face
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1645 '((((class grayscale)) (:italic t))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1646 (((class color)) (:foreground "darkorchid"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1647 (t (:italic t)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1648 "Prolog mode face for highlighting redo trace lines."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1649 :group 'prolog-faces)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1650 (defface prolog-exit-face
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1651 '((((class grayscale)) (:underline t))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1652 (((class color) (background dark)) (:foreground "green"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1653 (((class color) (background light)) (:foreground "ForestGreen"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1654 (t (:underline t)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1655 "Prolog mode face for highlighting exit trace lines."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1656 :group 'prolog-faces)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1657 (defface prolog-exception-face
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1658 '((((class grayscale)) (:bold t :italic t :underline t))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1659 (((class color)) (:bold t :foreground "black" :background "Khaki"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1660 (t (:bold t :italic t :underline t)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1661 "Prolog mode face for highlighting exception trace lines."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1662 :group 'prolog-faces)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1663 (defface prolog-warning-face
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1664 '((((class grayscale)) (:underline t))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1665 (((class color) (background dark)) (:foreground "blue"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1666 (((class color) (background light)) (:foreground "MidnightBlue"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1667 (t (:underline t)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1668 "Face name to use for compiler warnings."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1669 :group 'prolog-faces)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1670 (defface prolog-builtin-face
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1671 '((((class color) (background light)) (:foreground "Purple"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1672 (((class color) (background dark)) (:foreground "Cyan"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1673 (((class grayscale) (background light)) (:foreground "LightGray" :bold t))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1674 (((class grayscale) (background dark)) (:foreground "DimGray" :bold t))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1675 (t (:bold t)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1676 "Face name to use for compiler warnings."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1677 :group 'prolog-faces)
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1678 (defvar prolog-warning-face
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1679 (if (prolog-face-name-p 'font-lock-warning-face)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1680 'font-lock-warning-face
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1681 'prolog-warning-face)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1682 "Face name to use for built in predicates.")
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1683 (defvar prolog-builtin-face
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1684 (if (prolog-face-name-p 'font-lock-builtin-face)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1685 'font-lock-builtin-face
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1686 'prolog-builtin-face)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1687 "Face name to use for built in predicates.")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1688 (defvar prolog-redo-face 'prolog-redo-face
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1689 "Face name to use for redo trace lines.")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1690 (defvar prolog-exit-face 'prolog-exit-face
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1691 "Face name to use for exit trace lines.")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1692 (defvar prolog-exception-face 'prolog-exception-face
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1693 "Face name to use for exception trace lines.")
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1694
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1695 ;; Font Lock Patterns
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1696 (let (
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1697 ;; "Native" Prolog patterns
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1698 (head-predicates
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1699 (list (format "^\\(%s\\)\\((\\|[ \t]*:-\\)" prolog-atom-regexp)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1700 1 font-lock-function-name-face))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1701 ;(list (format "^%s" prolog-atom-regexp)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1702 ; 0 font-lock-function-name-face))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1703 (head-predicates-1
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1704 (list (format "\\.[ \t]*\\(%s\\)" prolog-atom-regexp)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1705 1 font-lock-function-name-face) )
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1706 (variables
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1707 '("\\<\\([_A-Z][a-zA-Z0-9_]*\\)"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1708 1 font-lock-variable-name-face))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1709 (important-elements
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1710 (list (if (eq prolog-system 'mercury)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1711 "[][}{;|]\\|\\\\[+=]\\|<?=>?"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1712 "[][}{!;|]\\|\\*->")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1713 0 'font-lock-keyword-face))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1714 (important-elements-1
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1715 '("[^-*]\\(->\\)" 1 font-lock-keyword-face))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1716 (predspecs ; module:predicate/cardinality
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1717 (list (format "\\<\\(%s:\\|\\)%s/[0-9]+"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1718 prolog-atom-regexp prolog-atom-regexp)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1719 0 font-lock-function-name-face 'prepend))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1720 (keywords ; directives (queries)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1721 (list
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1722 (if (eq prolog-system 'mercury)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1723 (concat
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1724 "\\<\\("
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1725 (prolog-make-keywords-regexp prolog-keywords-i)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1726 "\\|"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1727 (prolog-make-keywords-regexp
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1728 prolog-determinism-specificators-i)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1729 "\\)\\>")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1730 (concat
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1731 "^[?:]- *\\("
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1732 (prolog-make-keywords-regexp prolog-keywords-i)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1733 "\\)\\>"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1734 1 prolog-builtin-face))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1735 (quoted_atom (list prolog-quoted-atom-regexp
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1736 2 'font-lock-string-face 'append))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1737 (string (list prolog-string-regexp
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1738 1 'font-lock-string-face 'append))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1739 ;; SICStus specific patterns
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1740 (sicstus-object-methods
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1741 (if (eq prolog-system 'sicstus)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1742 '(prolog-font-lock-object-matcher
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1743 1 font-lock-function-name-face)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1744 ;; Mercury specific patterns
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1745 (types
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1746 (if (eq prolog-system 'mercury)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1747 (list
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1748 (prolog-make-keywords-regexp prolog-types-i t)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1749 0 'font-lock-type-face)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1750 (modes
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1751 (if (eq prolog-system 'mercury)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1752 (list
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1753 (prolog-make-keywords-regexp prolog-mode-specificators-i t)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1754 0 'font-lock-reference-face)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1755 (directives
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1756 (if (eq prolog-system 'mercury)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1757 (list
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1758 (prolog-make-keywords-regexp prolog-directives-i t)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1759 0 'prolog-warning-face)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1760 ;; Inferior mode specific patterns
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1761 (prompt
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1762 (list prolog-prompt-regexp-i 0 'font-lock-keyword-face))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1763 (trace-exit
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1764 (cond
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1765 ((eq prolog-system 'sicstus)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1766 '("[ \t]*[0-9]+[ \t]+[0-9]+[ \t]*\\(Exit\\):"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1767 1 prolog-exit-face))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1768 ((eq prolog-system 'swi)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1769 '("[ \t]*\\(Exit\\):[ \t]*([ \t0-9]*)" 1 prolog-exit-face))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1770 (t nil)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1771 (trace-fail
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1772 (cond
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1773 ((eq prolog-system 'sicstus)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1774 '("[ \t]*[0-9]+[ \t]+[0-9]+[ \t]*\\(Fail\\):"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1775 1 prolog-warning-face))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1776 ((eq prolog-system 'swi)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1777 '("[ \t]*\\(Fail\\):[ \t]*([ \t0-9]*)" 1 prolog-warning-face))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1778 (t nil)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1779 (trace-redo
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1780 (cond
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1781 ((eq prolog-system 'sicstus)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1782 '("[ \t]*[0-9]+[ \t]+[0-9]+[ \t]*\\(Redo\\):"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1783 1 prolog-redo-face))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1784 ((eq prolog-system 'swi)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1785 '("[ \t]*\\(Redo\\):[ \t]*([ \t0-9]*)" 1 prolog-redo-face))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1786 (t nil)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1787 (trace-call
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1788 (cond
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1789 ((eq prolog-system 'sicstus)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1790 '("[ \t]*[0-9]+[ \t]+[0-9]+[ \t]*\\(Call\\):"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1791 1 font-lock-function-name-face))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1792 ((eq prolog-system 'swi)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1793 '("[ \t]*\\(Call\\):[ \t]*([ \t0-9]*)"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1794 1 font-lock-function-name-face))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1795 (t nil)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1796 (trace-exception
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1797 (cond
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1798 ((eq prolog-system 'sicstus)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1799 '("[ \t]*[0-9]+[ \t]+[0-9]+[ \t]*\\(Exception\\):"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1800 1 prolog-exception-face))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1801 ((eq prolog-system 'swi)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1802 '("[ \t]*\\(Exception\\):[ \t]*([ \t0-9]*)"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1803 1 prolog-exception-face))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1804 (t nil)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1805 (error-message-identifier
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1806 (cond
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1807 ((eq prolog-system 'sicstus)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1808 '("{\\([A-Z]* ?ERROR:\\)" 1 prolog-exception-face prepend))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1809 ((eq prolog-system 'swi)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1810 '("^[[]\\(WARNING:\\)" 1 prolog-builtin-face prepend))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1811 (t nil)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1812 (error-whole-messages
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1813 (cond
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1814 ((eq prolog-system 'sicstus)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1815 '("{\\([A-Z]* ?ERROR:.*\\)}[ \t]*$"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1816 1 font-lock-comment-face append))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1817 ((eq prolog-system 'swi)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1818 '("^[[]WARNING:[^]]*[]]$" 0 font-lock-comment-face append))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1819 (t nil)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1820 (error-warning-messages
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1821 ;; Mostly errors that SICStus asks the user about how to solve,
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1822 ;; such as "NAME CLASH:" for example.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1823 (cond
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1824 ((eq prolog-system 'sicstus)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1825 '("^[A-Z ]*[A-Z]+:" 0 prolog-warning-face))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1826 (t nil)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1827 (warning-messages
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1828 (cond
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1829 ((eq prolog-system 'sicstus)
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1830 '("\\({ ?\\(Warning\\|WARNING\\) ?:.*}\\)[ \t]*$"
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1831 2 prolog-warning-face prepend))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1832 (t nil))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1833
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1834 ;; Make font lock list
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1835 (delq
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1836 nil
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1837 (cond
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1838 ((eq major-mode 'prolog-mode)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1839 (list
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1840 head-predicates
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1841 head-predicates-1
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1842 quoted_atom
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1843 string
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1844 variables
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1845 important-elements
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1846 important-elements-1
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1847 predspecs
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1848 keywords
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1849 sicstus-object-methods
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1850 types
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1851 modes
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1852 directives))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1853 ((eq major-mode 'prolog-inferior-mode)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1854 (list
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1855 prompt
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1856 error-message-identifier
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1857 error-whole-messages
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1858 error-warning-messages
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1859 warning-messages
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1860 predspecs
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1861 trace-exit
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1862 trace-fail
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1863 trace-redo
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1864 trace-call
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1865 trace-exception))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1866 ((eq major-mode 'compilation-mode)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1867 (list
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1868 error-message-identifier
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1869 error-whole-messages
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1870 error-warning-messages
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1871 warning-messages
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1872 predspecs))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1873 ))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1874
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1875
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1876 ;;-------------------------------------------------------------------
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1877 ;; Indentation stuff
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1878 ;;-------------------------------------------------------------------
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1879
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1880 ;; NB: This function *MUST* have this optional argument since XEmacs
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1881 ;; assumes it. This does not mean we have to use it...
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1882 (defun prolog-indent-line (&optional whole-exp)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1883 "Indent current line as Prolog code.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1884 With argument, indent any additional lines of the same clause
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1885 rigidly along with this one (not yet)."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1886 (interactive "p")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1887 (let ((indent (prolog-indent-level))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1888 (pos (- (point-max) (point))) beg)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1889 (beginning-of-line)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1890 (setq beg (point))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1891 (skip-chars-forward " \t")
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1892 (indent-line-to indent)
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1893 (if (> (- (point-max) pos) (point))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1894 (goto-char (- (point-max) pos)))
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1895
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1896 ;; Align comments
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1897 (if (and prolog-align-comments-flag
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1898 (save-excursion
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1899 (line-beginning-position)
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1900 ;; (let ((start (comment-search-forward (line-end-position) t)))
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1901 ;; (and start ;There's a comment to indent.
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1902 ;; ;; If it's first on the line, we've indented it already
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1903 ;; ;; and prolog-goto-comment-column would inf-loop.
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1904 ;; (progn (goto-char start) (skip-chars-backward " \t")
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1905 ;; (not (bolp)))))))
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1906 (and (looking-at comment-start-skip)
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1907 ;; The definition of comment-start-skip used in this
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1908 ;; mode is unusual in that it only matches at BOL.
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1909 (progn (skip-chars-forward " \t")
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1910 (not (eq (point) (match-end 1)))))))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1911 (save-excursion
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1912 (prolog-goto-comment-column t)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1913
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1914 ;; Insert spaces if needed
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1915 (if (or prolog-electric-tab-flag prolog-electric-if-then-else-flag)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1916 (prolog-insert-spaces-after-paren))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1917 ))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1918
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1919 (defun prolog-comment-indent ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1920 "Compute prolog comment indentation."
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1921 ;; FIXME: Only difference with default behavior is that %%% is not
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1922 ;; flushed to column 0 but just left where the user put it.
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1923 (cond ((looking-at "%%%") (prolog-indentation-level-of-line))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1924 ((looking-at "%%") (prolog-indent-level))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1925 (t
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1926 (save-excursion
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1927 (skip-chars-backward " \t")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1928 ;; Insert one space at least, except at left margin.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1929 (max (+ (current-column) (if (bolp) 0 1))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1930 comment-column)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1931 ))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1932
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1933 (defun prolog-indent-level ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1934 "Compute prolog indentation level."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1935 (save-excursion
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1936 (beginning-of-line)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1937 (let ((totbal (prolog-region-paren-balance
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1938 (prolog-clause-start t) (point)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1939 (oldpoint (point)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1940 (skip-chars-forward " \t")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1941 (cond
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1942 ((looking-at "%%%") (prolog-indentation-level-of-line))
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1943 ;Large comment starts
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1944 ((looking-at "%[^%]") comment-column) ;Small comment starts
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1945 ((bobp) 0) ;Beginning of buffer
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1946
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1947 ;; If we found '}' then we must check if it's the
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1948 ;; end of an object declaration or something else.
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1949 ((and (looking-at "}")
72696
560a2e73e11b (inferior-prolog-flavor): New var left out of previous commit.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 72684
diff changeset
1950 (save-excursion
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1951 (forward-char 1)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1952 ;; Goto to matching {
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1953 (if prolog-use-prolog-tokenizer-flag
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1954 (prolog-backward-list)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1955 (backward-list))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1956 (skip-chars-backward " \t")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1957 (backward-char 2)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1958 (looking-at "::")))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1959 ;; It was an object
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1960 (if prolog-object-end-to-0-flag
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1961 0
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1962 prolog-indent-width))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1963
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1964 ;;End of /* */ comment
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1965 ((looking-at "\\*/")
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1966 (save-excursion
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1967 (prolog-find-start-of-mline-comment)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1968 (skip-chars-backward " \t")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1969 (- (current-column) 2)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1970
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1971 ;; Here we check if the current line is within a /* */ pair
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1972 ((and (looking-at "[^%/]")
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1973 (eq (prolog-in-string-or-comment) 'cmt))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1974 (if prolog-indent-mline-comments-flag
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1975 (prolog-find-start-of-mline-comment)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1976 ;; Same as before
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1977 (prolog-indentation-level-of-line)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1978
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1979 (t
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1980 (let ((empty t) ind linebal)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1981 ;; See previous indentation
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1982 (while empty
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1983 (forward-line -1)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1984 (beginning-of-line)
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1985 (if (bobp)
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1986 (setq empty nil)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1987 (skip-chars-forward " \t")
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1988 (if (not (or (not (member (prolog-in-string-or-comment)
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1989 '(nil txt)))
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1990 (looking-at "%")
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1991 (looking-at "\n")))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1992 (setq empty nil))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1993
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1994 ;; Store this line's indentation
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1995 (setq ind (if (bobp)
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1996 0 ;Beginning of buffer.
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
1997 (current-column))) ;Beginning of clause.
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1998
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
1999 ;; Compute the balance of the line
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2000 (setq linebal (prolog-paren-balance))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2001 ;;(message "bal of previous line %d totbal %d" linebal totbal)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2002 (if (< linebal 0)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2003 (progn
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2004 ;; Add 'indent-level' mode to find-unmatched-paren instead?
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2005 (end-of-line)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2006 (setq ind (prolog-find-indent-of-matching-paren))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2007
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2008 ;;(message "ind %d" ind)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2009 (beginning-of-line)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2010
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2011 ;; Check if the line ends with ":-", ".", ":: {", "}" (might be
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2012 ;; unnecessary), "&" or ")" (The last four concerns SICStus objects)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2013 (cond
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2014 ;; If the last char of the line is a '&' then set the indent level
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2015 ;; to prolog-indent-width (used in SICStus objects)
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2016 ((and (eq prolog-system 'sicstus)
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2017 (looking-at ".+&[ \t]*\\(%.*\\|\\)$"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2018 (setq ind prolog-indent-width))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2019
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2020 ;; Increase indentation if the previous line was the head of a rule
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2021 ;; and does not contain a '.'
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2022 ((and (looking-at (format ".*%s[^\\.]*[ \t]*\\(%%.*\\|\\)$"
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2023 prolog-head-delimiter))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2024 ;; We must check that the match is at a paren balance of 0.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2025 (save-excursion
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2026 (let ((p (point)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2027 (re-search-forward prolog-head-delimiter)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2028 (>= 0 (prolog-region-paren-balance p (point))))))
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2029 (let ((headindent
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2030 (if (< (prolog-paren-balance) 0)
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2031 (save-excursion
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2032 (end-of-line)
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2033 (prolog-find-indent-of-matching-paren))
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2034 (prolog-indentation-level-of-line))))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2035 (setq ind (+ headindent prolog-indent-width))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2036
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2037 ;; The previous line was the head of an object
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2038 ((looking-at ".+ *::.*{[ \t]*$")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2039 (setq ind prolog-indent-width))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2040
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2041 ;; If a '.' is found at the end of the previous line, then
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2042 ;; decrease the indentation. (The \\(%.*\\|\\) part of the
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2043 ;; regexp is for comments at the end of the line)
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2044 ((and (looking-at "^.+\\.[ \t]*\\(%.*\\|\\)$")
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2045 ;; Make sure that the '.' found is not in a comment or string
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2046 (save-excursion
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2047 (end-of-line)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2048 (re-search-backward "\\.[ \t]*\\(%.*\\|\\)$" (point-min))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2049 ;; Guard against the real '.' being followed by a
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2050 ;; commented '.'.
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2051 (if (eq (prolog-in-string-or-comment) 'cmt)
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2052 ;; commented out '.'
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2053 (let ((here (line-beginning-position)))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2054 (end-of-line)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2055 (re-search-backward "\\.[ \t]*%.*$" here t))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2056 (not (prolog-in-string-or-comment))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2057 )
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2058 ))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2059 (setq ind 0))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2060
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2061 ;; If a '.' is found at the end of the previous line, then
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2062 ;; decrease the indentation. (The /\\*.*\\*/ part of the
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2063 ;; regexp is for C-like comments at the end of the
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2064 ;; line--can we merge with the case above?).
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2065 ((and (looking-at "^.+\\.[ \t]*\\(/\\*.*\\|\\)$")
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2066 ;; Make sure that the '.' found is not in a comment or string
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2067 (save-excursion
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2068 (end-of-line)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2069 (re-search-backward "\\.[ \t]*\\(/\\*.*\\|\\)$" (point-min))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2070 ;; Guard against the real '.' being followed by a
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2071 ;; commented '.'.
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2072 (if (eq (prolog-in-string-or-comment) 'cmt)
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2073 ;; commented out '.'
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2074 (let ((here (line-beginning-position)))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2075 (end-of-line)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2076 (re-search-backward "\\.[ \t]*/\\*.*$" here t))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2077 (not (prolog-in-string-or-comment))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2078 )
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2079 ))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2080 (setq ind 0))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2081
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2082 )
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2083
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2084 ;; If the last non comment char is a ',' or left paren or a left-
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2085 ;; indent-regexp then indent to open parenthesis level
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2086 (if (and
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2087 (> totbal 0)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2088 ;; SICStus objects have special syntax rules if point is
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2089 ;; not inside additional parens (objects are defined
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2090 ;; within {...})
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2091 (not (and (eq prolog-system 'sicstus)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2092 (= totbal 1)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2093 (prolog-in-object))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2094 (if (looking-at
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2095 (format "\\(%s\\|%s\\|0'.\\|[0-9]+'[0-9a-zA-Z]+\\|[^\n\'\"%%]\\)*\\(,\\|%s\\|%s\\)\[ \t]*\\(%%.*\\|\\)$"
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2096 prolog-quoted-atom-regexp prolog-string-regexp
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2097 prolog-left-paren prolog-left-indent-regexp))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2098 (progn
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2099 (goto-char oldpoint)
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2100 (setq ind (prolog-find-unmatched-paren
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2101 (if prolog-paren-indent-p
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2102 'termdependent
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2103 'skipwhite)))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2104 ;;(setq ind (prolog-find-unmatched-paren 'termdependent))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2105 )
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2106 (goto-char oldpoint)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2107 (setq ind (prolog-find-unmatched-paren nil))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2108 ))
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2109
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2110
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2111 ;; Return the indentation level
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2112 ind
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2113 ))))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2114
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2115 (defun prolog-find-indent-of-matching-paren ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2116 "Find the indentation level based on the matching parenthesis.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2117 Indentation level is set to the one the point is after when the function is
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2118 called."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2119 (save-excursion
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2120 ;; Go to the matching paren
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2121 (if prolog-use-prolog-tokenizer-flag
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2122 (prolog-backward-list)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2123 (backward-list))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2124
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2125 ;; If this was the first paren on the line then return this line's
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2126 ;; indentation level
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2127 (if (prolog-paren-is-the-first-on-line-p)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2128 (prolog-indentation-level-of-line)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2129 ;; It was not the first one
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2130 (progn
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2131 ;; Find the next paren
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2132 (prolog-goto-next-paren 0)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2133
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2134 ;; If this paren is a left one then use its column as indent level,
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2135 ;; if not then recurse this function
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2136 (if (looking-at prolog-left-paren)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2137 (+ (current-column) 1)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2138 (progn
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2139 (forward-char 1)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2140 (prolog-find-indent-of-matching-paren)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2141 ))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2142 ))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2143
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2144 (defun prolog-indentation-level-of-line ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2145 "Return the indentation level of the current line."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2146 (save-excursion
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2147 (beginning-of-line)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2148 (skip-chars-forward " \t")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2149 (current-column)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2150
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2151 (defun prolog-paren-is-the-first-on-line-p ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2152 "Return t if the parenthesis under the point is the first one on the line.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2153 Return nil otherwise.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2154 Note: does not check if the point is actually at a parenthesis!"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2155 (save-excursion
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2156 (let ((begofline (line-beginning-position)))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2157 (if (= begofline (point))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2158 t
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2159 (if (prolog-goto-next-paren begofline)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2160 nil
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2161 t)))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2162
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2163 (defun prolog-find-unmatched-paren (&optional mode)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2164 "Return the column of the last unmatched left parenthesis.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2165 If MODE is `skipwhite' then any white space after the parenthesis is added to
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2166 the answer.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2167 If MODE is `plusone' then the parenthesis' column +1 is returned.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2168 If MODE is `termdependent' then if the unmatched parenthesis is part of
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2169 a compound term the function will work as `skipwhite', otherwise
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2170 it will return the column paren plus the value of `prolog-paren-indent'.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2171 If MODE is nil or not set then the parenthesis' exact column is returned."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2172 (save-excursion
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2173 ;; If the next paren we find is a left one we're finished, if it's
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2174 ;; a right one then we go back one step and recurse
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2175 (prolog-goto-next-paren 0)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2176
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2177 (let ((roundparen (looking-at "(")))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2178 (if (looking-at prolog-left-paren)
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2179 (let ((not-part-of-term
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2180 (save-excursion
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2181 (backward-char 1)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2182 (looking-at "[ \t]"))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2183 (if (eq mode nil)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2184 (current-column)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2185 (if (and roundparen
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2186 (eq mode 'termdependent)
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2187 not-part-of-term)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2188 (+ (current-column)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2189 (if prolog-electric-tab-flag
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2190 ;; Electric TAB
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2191 prolog-paren-indent
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2192 ;; Not electric TAB
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2193 (if (looking-at ".[ \t]*$")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2194 2
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2195 prolog-paren-indent))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2196 )
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2197
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2198 (forward-char 1)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2199 (if (or (eq mode 'skipwhite) (eq mode 'termdependent) )
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2200 (skip-chars-forward " \t"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2201 (current-column))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2202 ;; Not looking at left paren
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2203 (progn
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2204 (forward-char 1)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2205 ;; Go to the matching paren. When we get there we have a total
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2206 ;; balance of 0.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2207 (if prolog-use-prolog-tokenizer-flag
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2208 (prolog-backward-list)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2209 (backward-list))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2210 (prolog-find-unmatched-paren mode)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2211 )))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2212
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2213
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2214 (defun prolog-paren-balance ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2215 "Return the parenthesis balance of the current line.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2216 A return value of n means n more left parentheses than right ones."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2217 (save-excursion
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2218 (end-of-line)
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2219 (prolog-region-paren-balance (line-beginning-position) (point))))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2220
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2221 (defun prolog-region-paren-balance (beg end)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2222 "Return the summed parenthesis balance in the region.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2223 The region is limited by BEG and END positions."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2224 (save-excursion
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2225 (let ((state (if prolog-use-prolog-tokenizer-flag
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2226 (prolog-tokenize beg end)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2227 (parse-partial-sexp beg end))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2228 (nth 0 state))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2229
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2230 (defun prolog-goto-next-paren (limit-pos)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2231 "Move the point to the next parenthesis earlier in the buffer.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2232 Return t if a match was found before LIMIT-POS. Return nil otherwise."
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2233 (let ((retval (re-search-backward
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2234 (concat prolog-left-paren "\\|" prolog-right-paren)
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2235 limit-pos t)))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2236
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2237 ;; If a match was found but it was in a string or comment, then recurse
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2238 (if (and retval (prolog-in-string-or-comment))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2239 (prolog-goto-next-paren limit-pos)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2240 retval)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2241 ))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2242
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2243 (defun prolog-in-string-or-comment ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2244 "Check whether string, atom, or comment is under current point.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2245 Return:
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2246 `txt' if the point is in a string, atom, or character code expression
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2247 `cmt' if the point is in a comment
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2248 nil otherwise."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2249 (save-excursion
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2250 (let* ((start
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2251 (if (eq prolog-parse-mode 'beg-of-line)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2252 ;; 'beg-of-line
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2253 (save-excursion
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2254 (let (safepoint)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2255 (beginning-of-line)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2256 (setq safepoint (point))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2257 (while (and (> (point) (point-min))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2258 (progn
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2259 (forward-line -1)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2260 (end-of-line)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2261 (if (not (bobp))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2262 (backward-char 1))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2263 (looking-at "\\\\"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2264 )
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2265 (beginning-of-line)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2266 (setq safepoint (point)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2267 safepoint))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2268 ;; 'beg-of-clause
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2269 (prolog-clause-start)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2270 (end (point))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2271 (state (if prolog-use-prolog-tokenizer-flag
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2272 (prolog-tokenize start end)
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2273 (if (fboundp 'syntax-ppss)
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2274 (syntax-ppss)
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2275 (parse-partial-sexp start end)))))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2276 (cond
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2277 ((nth 3 state) 'txt) ; String
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2278 ((nth 4 state) 'cmt) ; Comment
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2279 (t
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2280 (cond
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2281 ((looking-at "%") 'cmt) ; Start of a comment
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2282 ((looking-at "/\\*") 'cmt) ; Start of a comment
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2283 ((looking-at "\'") 'txt) ; Start of an atom
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2284 ((looking-at "\"") 'txt) ; Start of a string
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2285 (t nil)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2286 ))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2287 ))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2288
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2289 (defun prolog-find-start-of-mline-comment ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2290 "Return the start column of a /* */ comment.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2291 This assumes that the point is inside a comment."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2292 (re-search-backward "/\\*" (point-min) t)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2293 (forward-char 2)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2294 (skip-chars-forward " \t")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2295 (current-column))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2296
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2297 (defun prolog-insert-spaces-after-paren ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2298 "Insert spaces after the opening parenthesis, \"then\" (->) and \"else\" (;) branches.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2299 Spaces are inserted if all preceding objects on the line are
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2300 whitespace characters, parentheses, or then/else branches."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2301 (save-excursion
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2302 (let ((regexp (concat "(\\|" prolog-left-indent-regexp))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2303 level)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2304 (beginning-of-line)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2305 (skip-chars-forward " \t")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2306 (when (looking-at regexp)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2307 ;; Treat "( If -> " lines specially.
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2308 ;;(setq incr (if (looking-at "(.*->")
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2309 ;; 2
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2310 ;; prolog-paren-indent))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2311
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2312 ;; work on all subsequent "->", "(", ";"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2313 (while (looking-at regexp)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2314 (goto-char (match-end 0))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2315 (setq level (+ (prolog-find-unmatched-paren) prolog-paren-indent))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2316
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2317 ;; Remove old white space
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2318 (let ((start (point)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2319 (skip-chars-forward " \t")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2320 (delete-region start (point)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2321 (indent-to level)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2322 (skip-chars-forward " \t"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2323 )))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2324 (when (save-excursion
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2325 (backward-char 2)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2326 (looking-at "\\s ;\\|\\s (\\|->")) ; (looking-at "\\s \\((\\|;\\)"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2327 (skip-chars-forward " \t"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2328 )
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2329
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2330 ;;;; Comment filling
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2331
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2332 (defun prolog-comment-limits ()
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2333 "Return the current comment limits plus the comment type (block or line).
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2334 The comment limits are the range of a block comment or the range that
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2335 contains all adjacent line comments (i.e. all comments that starts in
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2336 the same column with no empty lines or non-whitespace characters
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2337 between them)."
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2338 (let ((here (point))
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2339 lit-limits-b lit-limits-e lit-type beg end
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2340 )
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2341 (save-restriction
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2342 ;; Widen to catch comment limits correctly.
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2343 (widen)
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2344 (setq end (line-end-position)
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2345 beg (line-beginning-position))
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2346 (save-excursion
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2347 (beginning-of-line)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2348 (setq lit-type (if (search-forward-regexp "%" end t) 'line 'block))
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2349 ; (setq lit-type 'line)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2350 ;(if (search-forward-regexp "^[ \t]*%" end t)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2351 ; (setq lit-type 'line)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2352 ; (if (not (search-forward-regexp "%" end t))
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2353 ; (setq lit-type 'block)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2354 ; (if (not (= (forward-line 1) 0))
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2355 ; (setq lit-type 'block)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2356 ; (setq done t
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2357 ; ret (prolog-comment-limits)))
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2358 ; ))
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2359 (if (eq lit-type 'block)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2360 (progn
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2361 (goto-char here)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2362 (when (looking-at "/\\*") (forward-char 2))
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2363 (when (and (looking-at "\\*") (> (point) (point-min))
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2364 (forward-char -1) (looking-at "/"))
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2365 (forward-char 1))
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2366 (when (save-excursion (search-backward "/*" nil t))
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2367 (list (save-excursion (search-backward "/*") (point))
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2368 (or (search-forward "*/" nil t) (point-max)) lit-type)))
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2369 ;; line comment
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2370 (setq lit-limits-b (- (point) 1)
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2371 lit-limits-e end)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2372 (condition-case nil
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2373 (if (progn (goto-char lit-limits-b)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2374 (looking-at "%"))
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2375 (let ((col (current-column)) done)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2376 (setq beg (point)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2377 end lit-limits-e)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2378 ;; Always at the beginning of the comment
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2379 ;; Go backward now
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2380 (beginning-of-line)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2381 (while (and (zerop (setq done (forward-line -1)))
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2382 (search-forward-regexp "^[ \t]*%"
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2383 (line-end-position) t)
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2384 (= (+ 1 col) (current-column)))
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2385 (setq beg (- (point) 1)))
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2386 (when (= done 0)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2387 (forward-line 1))
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2388 ;; We may have a line with code above...
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2389 (when (and (zerop (setq done (forward-line -1)))
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2390 (search-forward "%" (line-end-position) t)
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2391 (= (+ 1 col) (current-column)))
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2392 (setq beg (- (point) 1)))
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2393 (when (= done 0)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2394 (forward-line 1))
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2395 ;; Go forward
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2396 (goto-char lit-limits-b)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2397 (beginning-of-line)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2398 (while (and (zerop (forward-line 1))
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2399 (search-forward-regexp "^[ \t]*%"
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2400 (line-end-position) t)
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2401 (= (+ 1 col) (current-column)))
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2402 (setq end (line-end-position)))
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2403 (list beg end lit-type))
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2404 (list lit-limits-b lit-limits-e lit-type)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2405 )
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2406 (error (list lit-limits-b lit-limits-e lit-type))))
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2407 ))))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2408
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2409 (defun prolog-guess-fill-prefix ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2410 ;; fill 'txt entities?
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2411 (when (save-excursion
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2412 (end-of-line)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2413 (equal (prolog-in-string-or-comment) 'cmt))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2414 (let* ((bounds (prolog-comment-limits))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2415 (cbeg (car bounds))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2416 (type (nth 2 bounds))
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2417 beg end)
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2418 (save-excursion
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2419 (end-of-line)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2420 (setq end (point))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2421 (beginning-of-line)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2422 (setq beg (point))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2423 (if (and (eq type 'line)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2424 (> cbeg beg)
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2425 (save-excursion (not (search-forward-regexp "^[ \t]*%"
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2426 cbeg t))))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2427 (progn
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2428 (goto-char cbeg)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2429 (search-forward-regexp "%+[ \t]*" end t)
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2430 (prolog-replace-in-string (buffer-substring beg (point))
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2431 "[^ \t%]" " "))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2432 ;(goto-char beg)
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2433 (if (search-forward-regexp "^[ \t]*\\(%+\\|\\*+\\|/\\*+\\)[ \t]*"
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2434 end t)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2435 (prolog-replace-in-string (buffer-substring beg (point)) "/" " ")
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2436 (beginning-of-line)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2437 (when (search-forward-regexp "^[ \t]+" end t)
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2438 (buffer-substring beg (point)))))))))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2439
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2440 (defun prolog-fill-paragraph ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2441 "Fill paragraph comment at or after point."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2442 (interactive)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2443 (let* ((bounds (prolog-comment-limits))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2444 (type (nth 2 bounds)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2445 (if (eq type 'line)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2446 (let ((fill-prefix (prolog-guess-fill-prefix)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2447 (fill-paragraph nil))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2448 (save-excursion
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2449 (save-restriction
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2450 ;; exclude surrounding lines that delimit a multiline comment
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2451 ;; and don't contain alphabetic characters, like "/*******",
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2452 ;; "- - - */" etc.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2453 (save-excursion
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2454 (backward-paragraph)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2455 (unless (bobp) (forward-line))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2456 (if (string-match "^/\\*[^a-zA-Z]*$" (thing-at-point 'line))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2457 (narrow-to-region (point-at-eol) (point-max))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2458 (save-excursion
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2459 (forward-paragraph)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2460 (forward-line -1)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2461 (if (string-match "^[^a-zA-Z]*\\*/$" (thing-at-point 'line))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2462 (narrow-to-region (point-min) (point-at-bol))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2463 (let ((fill-prefix (prolog-guess-fill-prefix)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2464 (fill-paragraph nil))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2465 )))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2466
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2467 (defun prolog-do-auto-fill ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2468 "Carry out Auto Fill for Prolog mode.
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2469 In effect it sets the `fill-prefix' when inside comments and then calls
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2470 `do-auto-fill'."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2471 (let ((fill-prefix (prolog-guess-fill-prefix)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2472 (do-auto-fill)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2473 ))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2474
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2475 (defalias 'prolog-replace-in-string
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2476 (if (fboundp 'replace-in-string)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2477 #'replace-in-string
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2478 (lambda (str regexp newtext &optional literal)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2479 (replace-regexp-in-string regexp newtext str nil literal))))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2480
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2481 ;;-------------------------------------------------------------------
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2482 ;; The tokenizer
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2483 ;;-------------------------------------------------------------------
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2484
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2485 (defconst prolog-tokenize-searchkey
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2486 (concat "[0-9]+'"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2487 "\\|"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2488 "['\"]"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2489 "\\|"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2490 prolog-left-paren
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2491 "\\|"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2492 prolog-right-paren
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2493 "\\|"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2494 "%"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2495 "\\|"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2496 "/\\*"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2497 ))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2498
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2499 (defun prolog-tokenize (beg end &optional stopcond)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2500 "Tokenize a region of prolog code between BEG and END.
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2501 STOPCOND decides the stop condition of the parsing. Valid values
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2502 are 'zerodepth which stops the parsing at the first right parenthesis
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2503 where the parenthesis depth is zero, 'skipover which skips over
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2504 the current entity (e.g. a list, a string, etc.) and nil.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2505
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2506 The function returns a list with the following information:
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2507 0. parenthesis depth
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2508 3. 'atm if END is inside an atom
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2509 'str if END is inside a string
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2510 'chr if END is in a character code expression (0'x)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2511 nil otherwise
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2512 4. non-nil if END is inside a comment
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2513 5. end position (always equal to END if STOPCOND is nil)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2514 The rest of the elements are undefined."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2515 (save-excursion
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2516 (let* ((end2 (1+ end))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2517 oldp
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2518 (depth 0)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2519 (quoted nil)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2520 inside_cmt
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2521 (endpos end2)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2522 skiptype ; The type of entity we'll skip over
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2523 )
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2524 (goto-char beg)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2525
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2526 (if (and (eq stopcond 'skipover)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2527 (looking-at "[^[({'\"]"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2528 (setq endpos (point)) ; Stay where we are
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2529 (while (and
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2530 (re-search-forward prolog-tokenize-searchkey end2 t)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2531 (< (point) end2))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2532 (progn
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2533 (setq oldp (point))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2534 (goto-char (match-beginning 0))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2535 (cond
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2536 ;; Atoms and strings
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2537 ((looking-at "'")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2538 ;; Find end of atom
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2539 (if (re-search-forward "[^\\]'" end2 'limit)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2540 ;; Found end of atom
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2541 (progn
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2542 (setq oldp end2)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2543 (if (and (eq stopcond 'skipover)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2544 (not skiptype))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2545 (setq endpos (point))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2546 (setq oldp (point)))) ; Continue tokenizing
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2547 (setq quoted 'atm)))
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2548
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2549 ((looking-at "\"")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2550 ;; Find end of string
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2551 (if (re-search-forward "[^\\]\"" end2 'limit)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2552 ;; Found end of string
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2553 (progn
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2554 (setq oldp end2)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2555 (if (and (eq stopcond 'skipover)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2556 (not skiptype))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2557 (setq endpos (point))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2558 (setq oldp (point)))) ; Continue tokenizing
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2559 (setq quoted 'str)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2560
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2561 ;; Paren stuff
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2562 ((looking-at prolog-left-paren)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2563 (setq depth (1+ depth))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2564 (setq skiptype 'paren))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2565
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2566 ((looking-at prolog-right-paren)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2567 (setq depth (1- depth))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2568 (if (and
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2569 (or (eq stopcond 'zerodepth)
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2570 (and (eq stopcond 'skipover)
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2571 (eq skiptype 'paren)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2572 (= depth 0))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2573 (progn
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2574 (setq endpos (1+ (point)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2575 (setq oldp end2))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2576
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2577 ;; Comment stuff
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2578 ((looking-at comment-start)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2579 (end-of-line)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2580 ;; (if (>= (point) end2)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2581 (if (>= (point) end)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2582 (progn
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2583 (setq inside_cmt t)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2584 (setq oldp end2))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2585 (setq oldp (point))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2586
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2587 ((looking-at "/\\*")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2588 (if (re-search-forward "\\*/" end2 'limit)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2589 (setq oldp (point))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2590 (setq inside_cmt t)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2591 (setq oldp end2)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2592
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2593 ;; 0'char
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2594 ((looking-at "0'")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2595 (setq oldp (1+ (match-end 0)))
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2596 (if (> oldp end)
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2597 (setq quoted 'chr)))
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2598
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2599 ;; base'number
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2600 ((looking-at "[0-9]+'")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2601 (goto-char (match-end 0))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2602 (skip-chars-forward "0-9a-zA-Z")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2603 (setq oldp (point)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2604
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2605
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2606 )
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2607 (goto-char oldp)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2608 )) ; End of while
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2609 )
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2610
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2611 ;; Deal with multi-line comments
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2612 (and (prolog-inside-mline-comment end)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2613 (setq inside_cmt t))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2614
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2615 ;; Create return list
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2616 (list depth nil nil quoted inside_cmt endpos)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2617 )))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2618
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2619 (defun prolog-inside-mline-comment (here)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2620 (save-excursion
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2621 (goto-char here)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2622 (let* ((next-close (save-excursion (search-forward "*/" nil t)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2623 (next-open (save-excursion (search-forward "/*" nil t)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2624 (prev-open (save-excursion (search-backward "/*" nil t)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2625 (prev-close (save-excursion (search-backward "*/" nil t)))
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2626 (unmatched-next-close (and next-close
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2627 (or (not next-open)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2628 (> next-open next-close))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2629 (unmatched-prev-open (and prev-open
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2630 (or (not prev-close)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2631 (> prev-open prev-close))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2632 )
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2633 (or unmatched-next-close unmatched-prev-open)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2634 )))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2635
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2636
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2637 ;;-------------------------------------------------------------------
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2638 ;; Online help
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2639 ;;-------------------------------------------------------------------
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2640
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2641 (defvar prolog-help-function
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2642 '((mercury nil)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2643 (eclipse prolog-help-online)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2644 ;; (sicstus prolog-help-info)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2645 (sicstus prolog-find-documentation)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2646 (swi prolog-help-online)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2647 (t prolog-help-online))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2648 "Alist for the name of the function for finding help on a predicate.")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2649
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2650 (defun prolog-help-on-predicate ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2651 "Invoke online help on the atom under cursor."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2652 (interactive)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2653
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2654 (cond
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2655 ;; Redirect help for SICStus to `prolog-find-documentation'.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2656 ((eq prolog-help-function-i 'prolog-find-documentation)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2657 (prolog-find-documentation))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2658
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2659 ;; Otherwise, ask for the predicate name and then call the function
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2660 ;; in prolog-help-function-i
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2661 (t
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2662 (let* ((word (prolog-atom-under-point))
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2663 (predicate (read-string
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2664 (format "Help on predicate%s: "
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2665 (if word
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2666 (concat " (default " word ")")
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2667 ""))
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2668 nil nil word))
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2669 ;;point
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2670 )
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2671 (if prolog-help-function-i
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2672 (funcall prolog-help-function-i predicate)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2673 (error "Sorry, no help method defined for this Prolog system."))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2674 ))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2675
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2676 (defun prolog-help-info (predicate)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2677 (let ((buffer (current-buffer))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2678 oldp
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2679 (str (concat "^\\* " (regexp-quote predicate) " */")))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2680 (require 'info)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2681 (pop-to-buffer nil)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2682 (Info-goto-node prolog-info-predicate-index)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2683 (if (not (re-search-forward str nil t))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2684 (error (format "Help on predicate `%s' not found." predicate)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2685
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2686 (setq oldp (point))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2687 (if (re-search-forward str nil t)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2688 ;; Multiple matches, ask user
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2689 (let ((max 2)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2690 n)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2691 ;; Count matches
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2692 (while (re-search-forward str nil t)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2693 (setq max (1+ max)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2694
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2695 (goto-char oldp)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2696 (re-search-backward "[^ /]" nil t)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2697 (recenter 0)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2698 (setq n (read-string ;; was read-input, which is obsolete
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2699 (format "Several matches, choose (1-%d): " max) "1"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2700 (forward-line (- (string-to-number n) 1)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2701 ;; Single match
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2702 (re-search-backward "[^ /]" nil t))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2703
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2704 ;; (Info-follow-nearest-node (point))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2705 (prolog-Info-follow-nearest-node)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2706 (re-search-forward (concat "^`" (regexp-quote predicate)) nil t)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2707 (beginning-of-line)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2708 (recenter 0)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2709 (pop-to-buffer buffer)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2710
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2711 (defun prolog-Info-follow-nearest-node ()
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2712 (if (featurep 'xemacs)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2713 (Info-follow-nearest-node (point))
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2714 (Info-follow-nearest-node)))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2715
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2716 (defun prolog-help-online (predicate)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2717 (prolog-ensure-process)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2718 (process-send-string "prolog" (concat "help(" predicate ").\n"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2719 (display-buffer "*prolog*"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2720
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2721 (defun prolog-help-apropos (string)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2722 "Find Prolog apropos on given STRING.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2723 This function is only available when `prolog-system' is set to `swi'."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2724 (interactive "sApropos: ")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2725 (cond
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2726 ((eq prolog-system 'swi)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2727 (prolog-ensure-process)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2728 (process-send-string "prolog" (concat "apropos(" string ").\n"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2729 (display-buffer "*prolog*"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2730 (t
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2731 (error "Sorry, no Prolog apropos available for this Prolog system."))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2732
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2733 (defun prolog-atom-under-point ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2734 "Return the atom under or left to the point."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2735 (save-excursion
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2736 (let ((nonatom_chars "[](){},\. \t\n")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2737 start)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2738 (skip-chars-forward (concat "^" nonatom_chars))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2739 (skip-chars-backward nonatom_chars)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2740 (skip-chars-backward (concat "^" nonatom_chars))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2741 (setq start (point))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2742 (skip-chars-forward (concat "^" nonatom_chars))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2743 (buffer-substring-no-properties start (point))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2744 )))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2745
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2746
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2747 ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2748 ;; Help function with completion
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2749 ;; Stolen from Per Mildner's SICStus debugger mode and modified
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2750
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2751 (defun prolog-find-documentation ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2752 "Go to the Info node for a predicate in the SICStus Info manual."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2753 (interactive)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2754 (let ((pred (prolog-read-predicate)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2755 (prolog-goto-predicate-info pred)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2756
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2757 (defvar prolog-info-alist nil
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2758 "Alist with all builtin predicates.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2759 Only for internal use by `prolog-find-documentation'")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2760
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2761 ;; Very similar to prolog-help-info except that that function cannot
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2762 ;; cope with arity and that it asks the user if there are several
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2763 ;; functors with different arity. This function also uses
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2764 ;; prolog-info-alist for finding the info node, rather than parsing
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2765 ;; the predicate index.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2766 (defun prolog-goto-predicate-info (predicate)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2767 "Go to the info page for PREDICATE, which is a PredSpec."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2768 (interactive)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2769 (require 'info)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2770 (string-match "\\(.*\\)/\\([0-9]+\\).*$" predicate)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2771 (let ((buffer (current-buffer))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2772 (name (match-string 1 predicate))
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2773 (arity (string-to-number (match-string 2 predicate)))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2774 ;oldp
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2775 ;(str (regexp-quote predicate))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2776 )
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2777 (pop-to-buffer nil)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2778
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2779 (Info-goto-node
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2780 prolog-info-predicate-index) ;; We must be in the SICStus pages
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2781 (Info-goto-node (car (cdr (assoc predicate prolog-info-alist))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2782
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2783 (prolog-find-term (regexp-quote name) arity "^`")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2784
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2785 (recenter 0)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2786 (pop-to-buffer buffer))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2787 )
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2788
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2789 (defun prolog-read-predicate ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2790 "Read a PredSpec from the user.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2791 Returned value is a string \"FUNCTOR/ARITY\".
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2792 Interaction supports completion."
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2793 (let ((default (prolog-atom-under-point)))
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2794 ;; If the predicate index is not yet built, do it now
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2795 (if (not prolog-info-alist)
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2796 (prolog-build-info-alist))
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2797 ;; Test if the default string could be the base for completion.
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2798 ;; Discard it if not.
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2799 (if (eq (try-completion default prolog-info-alist) nil)
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2800 (setq default nil))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2801 ;; Read the PredSpec from the user
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2802 (completing-read
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2803 (if (zerop (length default))
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2804 "Help on predicate: "
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2805 (concat "Help on predicate (default " default "): "))
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2806 prolog-info-alist nil t nil nil default)))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2807
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2808 (defun prolog-build-info-alist (&optional verbose)
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2809 "Build an alist of all builtins and library predicates.
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2810 Each element is of the form (\"NAME/ARITY\" . (INFO-NODE1 INFO-NODE2 ...)).
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2811 Typically there is just one Info node associated with each name
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2812 If an optional argument VERBOSE is non-nil, print messages at the beginning
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2813 and end of list building."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2814 (if verbose
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2815 (message "Building info alist..."))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2816 (setq prolog-info-alist
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2817 (let ((l ())
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2818 (last-entry (cons "" ())))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2819 (save-excursion
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2820 (save-window-excursion
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2821 ;; select any window but the minibuffer (as we cannot switch
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2822 ;; buffers in minibuffer window.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2823 ;; I am not sure this is the right/best way
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2824 (if (active-minibuffer-window) ; nil if none active
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2825 (select-window (next-window)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2826 ;; Do this after going away from minibuffer window
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2827 (save-window-excursion
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2828 (info))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2829 (Info-goto-node prolog-info-predicate-index)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2830 (goto-char (point-min))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2831 (while (re-search-forward
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2832 "^\\* \\(.+\\)/\\([0-9]+\\)\\([^\n:*]*\\):" nil t)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2833 (let* ((name (match-string 1))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2834 (arity (string-to-number (match-string 2)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2835 (comment (match-string 3))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2836 (fa (format "%s/%d%s" name arity comment))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2837 info-node)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2838 (beginning-of-line)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2839 ;; Extract the info node name
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2840 (setq info-node (progn
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2841 (re-search-forward ":[ \t]*\\([^:]+\\).$")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2842 (match-string 1)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2843 ))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2844 ;; ###### Easier? (from Milan version 0.1.28)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2845 ;; (setq info-node (Info-extract-menu-node-name))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2846 (if (equal fa (car last-entry))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2847 (setcdr last-entry (cons info-node (cdr last-entry)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2848 (setq last-entry (cons fa (list info-node))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2849 l (cons last-entry l)))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2850 (nreverse l)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2851 ))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2852 (if verbose
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2853 (message "Building info alist... done.")))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2854
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2855
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2856 ;;-------------------------------------------------------------------
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2857 ;; Miscellaneous functions
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2858 ;;-------------------------------------------------------------------
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2859
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2860 ;; For Windows. Change backslash to slash. SICStus handles either
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2861 ;; path separator but backslash must be doubled, therefore use slash.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2862 (defun prolog-bsts (string)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2863 "Change backslashes to slashes in STRING."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2864 (let ((str1 (copy-sequence string))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2865 (len (length string))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2866 (i 0))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2867 (while (< i len)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2868 (if (char-equal (aref str1 i) ?\\)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2869 (aset str1 i ?/))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2870 (setq i (1+ i)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2871 str1))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2872
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2873 ;;(defun prolog-temporary-file ()
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2874 ;; "Make temporary file name for compilation."
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2875 ;; (make-temp-name
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2876 ;; (concat
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2877 ;; (or
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2878 ;; (getenv "TMPDIR")
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2879 ;; (getenv "TEMP")
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2880 ;; (getenv "TMP")
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2881 ;; (getenv "SYSTEMP")
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2882 ;; "/tmp")
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2883 ;; "/prolcomp")))
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2884 ;;(setq prolog-temp-filename (prolog-bsts (prolog-temporary-file)))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2885
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2886 (defun prolog-temporary-file ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2887 "Make temporary file name for compilation."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2888 (if prolog-temporary-file-name
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2889 ;; We already have a file, erase content and continue
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2890 (progn
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2891 (write-region "" nil prolog-temporary-file-name nil 'silent)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2892 prolog-temporary-file-name)
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2893 ;; Actually create the file and set `prolog-temporary-file-name'
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2894 ;; accordingly.
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2895 (setq prolog-temporary-file-name
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2896 (make-temp-file "prolcomp" nil ".pl"))))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2897
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2898 (defun prolog-goto-prolog-process-buffer ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2899 "Switch to the prolog process buffer and go to its end."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2900 (switch-to-buffer-other-window "*prolog*")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2901 (goto-char (point-max))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2902 )
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2903
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2904 (defun prolog-enable-sicstus-sd ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2905 "Enable the source level debugging facilities of SICStus 3.7 and later."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2906 (interactive)
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2907 (require 'pltrace) ; Load the SICStus debugger code
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2908 ;; Turn on the source level debugging by default
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2909 (add-hook 'prolog-inferior-mode-hook 'pltrace-on)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2910 (if (not prolog-use-sicstus-sd)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2911 (progn
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2912 ;; If there is a *prolog* buffer, then call pltrace-on
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2913 (if (get-buffer "*prolog*")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2914 ;; Avoid compilation warnings by using eval
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2915 (eval '(pltrace-on)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2916 (setq prolog-use-sicstus-sd t)
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
2917 )))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2918
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2919 (defun prolog-disable-sicstus-sd ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2920 "Disable the source level debugging facilities of SICStus 3.7 and later."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2921 (interactive)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2922 (setq prolog-use-sicstus-sd nil)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2923 ;; Remove the hook
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2924 (remove-hook 'prolog-inferior-mode-hook 'pltrace-on)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2925 ;; If there is a *prolog* buffer, then call pltrace-off
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2926 (if (get-buffer "*prolog*")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2927 ;; Avoid compile warnings by using eval
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2928 (eval '(pltrace-off))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2929
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2930 (defun prolog-toggle-sicstus-sd ()
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2931 ;; FIXME: Use define-minor-mode.
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2932 "Toggle the source level debugging facilities of SICStus 3.7 and later."
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2933 (interactive)
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2934 (if prolog-use-sicstus-sd
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2935 (prolog-disable-sicstus-sd)
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2936 (prolog-enable-sicstus-sd)))
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2937
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2938 (defun prolog-debug-on (&optional arg)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2939 "Enable debugging.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2940 When called with prefix argument ARG, disable debugging instead."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2941 (interactive "P")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2942 (if arg
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2943 (prolog-debug-off)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2944 (prolog-process-insert-string (get-process "prolog")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2945 prolog-debug-on-string)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2946 (process-send-string "prolog" prolog-debug-on-string)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2947
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2948 (defun prolog-debug-off ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2949 "Disable debugging."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2950 (interactive)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2951 (prolog-process-insert-string (get-process "prolog")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2952 prolog-debug-off-string)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2953 (process-send-string "prolog" prolog-debug-off-string))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2954
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2955 (defun prolog-trace-on (&optional arg)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2956 "Enable tracing.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2957 When called with prefix argument ARG, disable tracing instead."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2958 (interactive "P")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2959 (if arg
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2960 (prolog-trace-off)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2961 (prolog-process-insert-string (get-process "prolog")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2962 prolog-trace-on-string)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2963 (process-send-string "prolog" prolog-trace-on-string)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2964
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2965 (defun prolog-trace-off ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2966 "Disable tracing."
72684
f65ec4fd2be1 Remove * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 68773
diff changeset
2967 (interactive)
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2968 (prolog-process-insert-string (get-process "prolog")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2969 prolog-trace-off-string)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2970 (process-send-string "prolog" prolog-trace-off-string))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2971
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2972 (defun prolog-zip-on (&optional arg)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2973 "Enable zipping (for SICStus 3.7 and later).
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2974 When called with prefix argument ARG, disable zipping instead."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2975 (interactive "P")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2976 (if arg
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2977 (prolog-zip-off)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2978 (prolog-process-insert-string (get-process "prolog")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2979 prolog-zip-on-string)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2980 (process-send-string "prolog" prolog-zip-on-string)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2981
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2982 (defun prolog-zip-off ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2983 "Disable zipping (for SICStus 3.7 and later)."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2984 (interactive)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2985 (prolog-process-insert-string (get-process "prolog")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2986 prolog-zip-off-string)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2987 (process-send-string "prolog" prolog-zip-off-string))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2988
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2989 ;; (defun prolog-create-predicate-index ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2990 ;; "Create an index for all predicates in the buffer."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2991 ;; (let ((predlist '())
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
2992 ;; clauseinfo
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2993 ;; object
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2994 ;; pos
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2995 ;; )
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2996 ;; (goto-char (point-min))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2997 ;; ;; Replace with prolog-clause-start!
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2998 ;; (while (re-search-forward "^.+:-" nil t)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
2999 ;; (setq pos (match-beginning 0))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3000 ;; (setq clauseinfo (prolog-clause-info))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3001 ;; (setq object (prolog-in-object))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3002 ;; (setq predlist (append
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3003 ;; predlist
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3004 ;; (list (cons
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3005 ;; (if (and (eq prolog-system 'sicstus)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3006 ;; (prolog-in-object))
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3007 ;; (format "%s::%s/%d"
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3008 ;; object
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3009 ;; (nth 0 clauseinfo)
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3010 ;; (nth 1 clauseinfo))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3011 ;; (format "%s/%d"
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3012 ;; (nth 0 clauseinfo)
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3013 ;; (nth 1 clauseinfo)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3014 ;; pos
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3015 ;; ))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3016 ;; (prolog-end-of-predicate))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3017 ;; predlist))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3018
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3019 (defun prolog-get-predspec ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3020 (save-excursion
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3021 (let ((state (prolog-clause-info))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3022 (object (prolog-in-object)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3023 (if (or (equal (nth 0 state) "") (equal (prolog-in-string-or-comment) 'cmt))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3024 nil
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3025 (if (and (eq prolog-system 'sicstus)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3026 object)
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3027 (format "%s::%s/%d"
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3028 object
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3029 (nth 0 state)
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3030 (nth 1 state))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3031 (format "%s/%d"
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3032 (nth 0 state)
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3033 (nth 1 state)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3034 ))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3035
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3036 ;; For backward compatibility. Stolen from custom.el.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3037 (or (fboundp 'match-string)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3038 ;; Introduced in Emacs 19.29.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3039 (defun match-string (num &optional string)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3040 "Return string of text matched by last search.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3041 NUM specifies which parenthesized expression in the last regexp.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3042 Value is nil if NUMth pair didn't match, or there were less than NUM pairs.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3043 Zero means the entire text matched by the whole regexp or whole string.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3044 STRING should be given if the last search was by `string-match' on STRING."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3045 (if (match-beginning num)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3046 (if string
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3047 (substring string (match-beginning num) (match-end num))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3048 (buffer-substring (match-beginning num) (match-end num))))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3049
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3050 (defun prolog-pred-start ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3051 "Return the starting point of the first clause of the current predicate."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3052 (save-excursion
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3053 (goto-char (prolog-clause-start))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3054 ;; Find first clause, unless it was a directive
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3055 (if (and (not (looking-at "[:?]-"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3056 (not (looking-at "[ \t]*[%/]")) ; Comment
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3057
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3058 )
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3059 (let* ((pinfo (prolog-clause-info))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3060 (predname (nth 0 pinfo))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3061 (arity (nth 1 pinfo))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3062 (op (point)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3063 (while (and (re-search-backward
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3064 (format "^%s\\([(\\.]\\| *%s\\)"
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3065 predname prolog-head-delimiter) nil t)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3066 (= arity (nth 1 (prolog-clause-info)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3067 )
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3068 (setq op (point)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3069 (if (eq prolog-system 'mercury)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3070 ;; Skip to the beginning of declarations of the predicate
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3071 (progn
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3072 (goto-char (prolog-beginning-of-clause))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3073 (while (and (not (eq (point) op))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3074 (looking-at
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3075 (format ":-[ \t]*\\(pred\\|mode\\)[ \t]+%s"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3076 predname)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3077 (setq op (point))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3078 (goto-char (prolog-beginning-of-clause)))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3079 op)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3080 (point))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3081
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3082 (defun prolog-pred-end ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3083 "Return the position at the end of the last clause of the current predicate."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3084 (save-excursion
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3085 (goto-char (prolog-clause-end)) ; if we are before the first predicate
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3086 (goto-char (prolog-clause-start))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3087 (let* ((pinfo (prolog-clause-info))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3088 (predname (nth 0 pinfo))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3089 (arity (nth 1 pinfo))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3090 oldp
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3091 (notdone t)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3092 (op (point)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3093 (if (looking-at "[:?]-")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3094 ;; This was a directive
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3095 (progn
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3096 (if (and (eq prolog-system 'mercury)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3097 (looking-at
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3098 (format ":-[ \t]*\\(pred\\|mode\\)[ \t]+\\(%s+\\)"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3099 prolog-atom-regexp)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3100 ;; Skip predicate declarations
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3101 (progn
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3102 (setq predname (buffer-substring-no-properties
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3103 (match-beginning 2) (match-end 2)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3104 (while (re-search-forward
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3105 (format
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3106 "\n*\\(:-[ \t]*\\(pred\\|mode\\)[ \t]+\\)?%s[( \t]"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3107 predname)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3108 nil t))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3109 (goto-char (prolog-clause-end))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3110 (setq op (point)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3111 ;; It was not a directive, find the last clause
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3112 (while (and notdone
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3113 (re-search-forward
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3114 (format "^%s\\([(\\.]\\| *%s\\)"
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3115 predname prolog-head-delimiter) nil t)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3116 (= arity (nth 1 (prolog-clause-info))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3117 (setq oldp (point))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3118 (setq op (prolog-clause-end))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3119 (if (>= oldp op)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3120 ;; End of clause not found.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3121 (setq notdone nil)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3122 ;; Continue while loop
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3123 (goto-char op))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3124 op)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3125
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3126 (defun prolog-clause-start (&optional not-allow-methods)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3127 "Return the position at the start of the head of the current clause.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3128 If NOTALLOWMETHODS is non-nil then do not match on methods in
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3129 objects (relevent only if 'prolog-system' is set to 'sicstus)."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3130 (save-excursion
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3131 (let ((notdone t)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3132 (retval (point-min)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3133 (end-of-line)
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3134
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3135 ;; SICStus object?
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3136 (if (and (not not-allow-methods)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3137 (eq prolog-system 'sicstus)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3138 (prolog-in-object))
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3139 (while (and
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3140 notdone
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3141 ;; Search for a head or a fact
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3142 (re-search-backward
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3143 ;; If in object, then find method start.
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3144 ;; "^[ \t]+[a-z$].*\\(:-\\|&\\|:: {\\|,\\)"
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3145 "^[ \t]+[a-z$].*\\(:-\\|&\\|:: {\\)" ; The comma causes
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3146 ; problems since we cannot assume
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3147 ; that the line starts at column 0,
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3148 ; thus we don't know if the line
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3149 ; is a head or a subgoal
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3150 (point-min) t))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3151 (if (>= (prolog-paren-balance) 0) ; To no match on " a) :-"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3152 ;; Start of method found
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3153 (progn
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3154 (setq retval (point))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3155 (setq notdone nil)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3156 ) ; End of while
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3157
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3158 ;; Not in object
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3159 (while (and
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3160 notdone
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3161 ;; Search for a text at beginning of a line
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3162 ;; ######
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3163 ;; (re-search-backward "^[a-z$']" nil t))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3164 (let ((case-fold-search nil))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3165 (re-search-backward
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3166 ;; (format "^[%s$']" prolog-lower-case-string)
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
3167 ;; FIXME: Use [:lower:]
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3168 (format "^\\([%s$']\\|[:?]-\\)" prolog-lower-case-string)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3169 nil t)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3170 (let ((bal (prolog-paren-balance)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3171 (cond
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3172 ((> bal 0)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3173 ;; Start of clause found
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3174 (progn
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3175 (setq retval (point))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3176 (setq notdone nil)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3177 ((and (= bal 0)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3178 (looking-at
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3179 (format ".*\\(\\.\\|%s\\|!,\\)[ \t]*\\(%%.*\\|\\)$"
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3180 prolog-head-delimiter)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3181 ;; Start of clause found if the line ends with a '.' or
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3182 ;; a prolog-head-delimiter
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3183 (progn
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3184 (setq retval (point))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3185 (setq notdone nil))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3186 )
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3187 (t nil) ; Do nothing
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3188 ))))
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3189
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3190 retval)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3191
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3192 (defun prolog-clause-end (&optional not-allow-methods)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3193 "Return the position at the end of the current clause.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3194 If NOTALLOWMETHODS is non-nil then do not match on methods in
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3195 objects (relevent only if 'prolog-system' is set to 'sicstus)."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3196 (save-excursion
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3197 (beginning-of-line) ; Necessary since we use "^...." for the search.
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3198 (if (re-search-forward
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3199 (if (and (not not-allow-methods)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3200 (eq prolog-system 'sicstus)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3201 (prolog-in-object))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3202 (format
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3203 "^\\(%s\\|%s\\|[^\n\'\"%%]\\)*&[ \t]*\\(\\|%%.*\\)$\\|[ \t]*}"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3204 prolog-quoted-atom-regexp prolog-string-regexp)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3205 (format
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3206 "^\\(%s\\|%s\\|[^\n\'\"%%]\\)*\\.[ \t]*\\(\\|%%.*\\)$"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3207 prolog-quoted-atom-regexp prolog-string-regexp))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3208 nil t)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3209 (if (and (prolog-in-string-or-comment)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3210 (not (eobp)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3211 (progn
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3212 (forward-char)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3213 (prolog-clause-end))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3214 (point))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3215 (point))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3216
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3217 (defun prolog-clause-info ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3218 "Return a (name arity) list for the current clause."
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3219 (save-excursion
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3220 (goto-char (prolog-clause-start))
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3221 (let* ((op (point))
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3222 (predname
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3223 (if (looking-at prolog-atom-char-regexp)
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3224 (progn
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3225 (skip-chars-forward "^ (\\.")
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3226 (buffer-substring op (point)))
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3227 ""))
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3228 (arity 0))
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3229 ;; Retrieve the arity.
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3230 (if (looking-at prolog-left-paren)
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3231 (let ((endp (save-excursion
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3232 (prolog-forward-list) (point))))
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3233 (setq arity 1)
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3234 (forward-char 1) ; Skip the opening paren.
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3235 (while (progn
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3236 (skip-chars-forward "^[({,'\"")
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3237 (< (point) endp))
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3238 (if (looking-at ",")
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3239 (progn
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3240 (setq arity (1+ arity))
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3241 (forward-char 1) ; Skip the comma.
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3242 )
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3243 ;; We found a string, list or something else we want
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3244 ;; to skip over. Always use prolog-tokenize,
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3245 ;; parse-partial-sexp does not have a 'skipover mode.
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3246 (goto-char (nth 5 (prolog-tokenize (point) endp 'skipover))))
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3247 )))
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3248 (list predname arity))))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3249
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3250 (defun prolog-in-object ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3251 "Return object name if the point is inside a SICStus object definition."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3252 ;; Return object name if the last line that starts with a character
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3253 ;; that is neither white space nor a comment start
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3254 (save-excursion
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3255 (if (save-excursion
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3256 (beginning-of-line)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3257 (looking-at "\\([^\n ]+\\)[ \t]*::[ \t]*{"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3258 ;; We were in the head of the object
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3259 (match-string 1)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3260 ;; We were not in the head
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3261 (if (and (re-search-backward "^[a-z$'}]" nil t)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3262 (looking-at "\\([^\n ]+\\)[ \t]*::[ \t]*{"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3263 (match-string 1)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3264 nil))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3265
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3266 (defun prolog-forward-list ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3267 "Move the point to the matching right parenthesis."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3268 (interactive)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3269 (if prolog-use-prolog-tokenizer-flag
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3270 (let ((state (prolog-tokenize (point) (point-max) 'zerodepth)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3271 (goto-char (nth 5 state)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3272 (forward-list)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3273
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3274 ;; NB: This could be done more efficiently!
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3275 (defun prolog-backward-list ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3276 "Move the point to the matching left parenthesis."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3277 (interactive)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3278 (if prolog-use-prolog-tokenizer-flag
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3279 (let ((bal 0)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3280 (paren-regexp (concat prolog-left-paren "\\|" prolog-right-paren))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3281 (notdone t))
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3282 ;; FIXME: Doesn't this incorrectly count 0'( and 0') ?
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3283 (while (and notdone (re-search-backward paren-regexp nil t))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3284 (cond
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3285 ((looking-at prolog-left-paren)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3286 (if (not (prolog-in-string-or-comment))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3287 (setq bal (1+ bal)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3288 (if (= bal 0)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3289 (setq notdone nil)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3290 ((looking-at prolog-right-paren)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3291 (if (not (prolog-in-string-or-comment))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3292 (setq bal (1- bal))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3293 )))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3294 (backward-list)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3295
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3296 (defun prolog-beginning-of-clause ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3297 "Move to the beginning of current clause.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3298 If already at the beginning of clause, move to previous clause."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3299 (interactive)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3300 (let ((point (point))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3301 (new-point (prolog-clause-start)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3302 (if (and (>= new-point point)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3303 (> point 1))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3304 (progn
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3305 (goto-char (1- point))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3306 (goto-char (prolog-clause-start)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3307 (goto-char new-point)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3308 (skip-chars-forward " \t"))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3309
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3310 ;; (defun prolog-previous-clause ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3311 ;; "Move to the beginning of the previous clause."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3312 ;; (interactive)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3313 ;; (forward-char -1)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3314 ;; (prolog-beginning-of-clause))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3315
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3316 (defun prolog-end-of-clause ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3317 "Move to the end of clause.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3318 If already at the end of clause, move to next clause."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3319 (interactive)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3320 (let ((point (point))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3321 (new-point (prolog-clause-end)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3322 (if (and (<= new-point point)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3323 (not (eq new-point (point-max))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3324 (progn
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3325 (goto-char (1+ point))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3326 (goto-char (prolog-clause-end)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3327 (goto-char new-point))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3328
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3329 ;; (defun prolog-next-clause ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3330 ;; "Move to the beginning of the next clause."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3331 ;; (interactive)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3332 ;; (prolog-end-of-clause)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3333 ;; (forward-char)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3334 ;; (prolog-end-of-clause)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3335 ;; (prolog-beginning-of-clause))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3336
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3337 (defun prolog-beginning-of-predicate ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3338 "Go to the nearest beginning of predicate before current point.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3339 Return the final point or nil if no such a beginning was found."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3340 (interactive)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3341 (let ((op (point))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3342 (pos (prolog-pred-start)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3343 (if pos
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3344 (if (= op pos)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3345 (if (not (bobp))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3346 (progn
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3347 (goto-char pos)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3348 (backward-char 1)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3349 (setq pos (prolog-pred-start))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3350 (if pos
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3351 (progn
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3352 (goto-char pos)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3353 (point)))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3354 (goto-char pos)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3355 (point)))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3356
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3357 (defun prolog-end-of-predicate ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3358 "Go to the end of the current predicate."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3359 (interactive)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3360 (let ((op (point)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3361 (goto-char (prolog-pred-end))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3362 (if (= op (point))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3363 (progn
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3364 (forward-line 1)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3365 (prolog-end-of-predicate)))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3366
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3367 (defun prolog-insert-predspec ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3368 "Insert the predspec for the current predicate."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3369 (interactive)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3370 (let* ((pinfo (prolog-clause-info))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3371 (predname (nth 0 pinfo))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3372 (arity (nth 1 pinfo)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3373 (insert (format "%s/%d" predname arity))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3374
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3375 (defun prolog-view-predspec ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3376 "Insert the predspec for the current predicate."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3377 (interactive)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3378 (let* ((pinfo (prolog-clause-info))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3379 (predname (nth 0 pinfo))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3380 (arity (nth 1 pinfo)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3381 (message (format "%s/%d" predname arity))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3382
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3383 (defun prolog-insert-predicate-template ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3384 "Insert the template for the current clause."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3385 (interactive)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3386 (let* ((n 1)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3387 oldp
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3388 (pinfo (prolog-clause-info))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3389 (predname (nth 0 pinfo))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3390 (arity (nth 1 pinfo)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3391 (insert predname)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3392 (if (> arity 0)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3393 (progn
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3394 (insert "(")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3395 (when prolog-electric-dot-full-predicate-template
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3396 (setq oldp (point))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3397 (while (< n arity)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3398 (insert ",")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3399 (setq n (1+ n)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3400 (insert ")")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3401 (goto-char oldp))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3402 ))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3403 ))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3404
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3405 (defun prolog-insert-next-clause ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3406 "Insert newline and the name of the current clause."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3407 (interactive)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3408 (insert "\n")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3409 (prolog-insert-predicate-template))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3410
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3411 (defun prolog-insert-module-modeline ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3412 "Insert a modeline for module specification.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3413 This line should be first in the buffer.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3414 The module name should be written manually just before the semi-colon."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3415 (interactive)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3416 (insert "%%% -*- Module: ; -*-\n")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3417 (backward-char 6))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3418
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
3419 (defalias 'prolog-uncomment-region
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
3420 (if (fboundp 'uncomment-region) #'uncomment-region
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
3421 (lambda (beg end)
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
3422 "Uncomment the region between BEG and END."
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
3423 (interactive "r")
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
3424 (comment-region beg end -1))))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3425
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3426 (defun prolog-goto-comment-column (&optional nocreate)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3427 "Move comments on the current line to the correct position.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3428 If NOCREATE is nil (or omitted) and there is no comment on the line, then
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3429 a new comment is created."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3430 (interactive)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3431 (beginning-of-line)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3432 (if (or (not nocreate)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3433 (and
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3434 (re-search-forward
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3435 (format "^\\(\\(%s\\|%s\\|[^\n\'\"%%]\\)*\\)%% *"
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3436 prolog-quoted-atom-regexp prolog-string-regexp)
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3437 (line-end-position) 'limit)
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3438 (progn
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3439 (goto-char (match-beginning 0))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3440 (not (eq (prolog-in-string-or-comment) 'txt)))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3441 (indent-for-comment)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3442
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3443 (defun prolog-indent-predicate ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3444 "*Indent the current predicate."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3445 (interactive)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3446 (indent-region (prolog-pred-start) (prolog-pred-end) nil))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3447
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3448 (defun prolog-indent-buffer ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3449 "*Indent the entire buffer."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3450 (interactive)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3451 (indent-region (point-min) (point-max) nil))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3452
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3453 (defun prolog-mark-clause ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3454 "Put mark at the end of this clause and move point to the beginning."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3455 (interactive)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3456 (let ((pos (point)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3457 (goto-char (prolog-clause-end))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3458 (forward-line 1)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3459 (beginning-of-line)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3460 (set-mark (point))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3461 (goto-char pos)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3462 (goto-char (prolog-clause-start))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3463
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3464 (defun prolog-mark-predicate ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3465 "Put mark at the end of this predicate and move point to the beginning."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3466 (interactive)
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3467 (goto-char (prolog-pred-end))
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3468 (let ((pos (point)))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3469 (forward-line 1)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3470 (beginning-of-line)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3471 (set-mark (point))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3472 (goto-char pos)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3473 (goto-char (prolog-pred-start))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3474
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3475 ;; Stolen from `cc-mode.el':
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3476 (defun prolog-electric-delete (arg)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3477 "Delete preceding character or whitespace.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3478 If `prolog-hungry-delete-key-flag' is non-nil, then all preceding whitespace is
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3479 consumed. If however an ARG is supplied, or `prolog-hungry-delete-key-flag' is
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3480 nil, or point is inside a literal then the function in the variable
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3481 `backward-delete-char' is called."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3482 (interactive "P")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3483 (if (or (not prolog-hungry-delete-key-flag)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3484 arg
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3485 (prolog-in-string-or-comment))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3486 (funcall 'backward-delete-char (prefix-numeric-value arg))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3487 (let ((here (point)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3488 (skip-chars-backward " \t\n")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3489 (if (/= (point) here)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3490 (delete-region (point) here)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3491 (funcall 'backward-delete-char 1)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3492 ))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3493
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3494 ;; For XEmacs compatibility (suggested by Per Mildner)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3495 (put 'prolog-electric-delete 'pending-delete 'supersede)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3496
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3497 (defun prolog-electric-if-then-else (arg)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3498 "If `prolog-electric-if-then-else-flag' is non-nil, indent if-then-else constructs.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3499 Bound to the >, ; and ( keys."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3500 (interactive "P")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3501 (self-insert-command (prefix-numeric-value arg))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3502 (if prolog-electric-if-then-else-flag (prolog-insert-spaces-after-paren)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3503
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3504 (defun prolog-electric-colon (arg)
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
3505 "If `prolog-electric-colon-flag' is non-nil, insert the electric `:' construct.
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
3506 That is, insert space (if appropriate), `:-' and newline if colon is pressed
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3507 at the end of a line that starts in the first column (i.e., clause
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3508 heads)."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3509 (interactive "P")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3510 (if (and prolog-electric-colon-flag
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3511 (null arg)
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
3512 (eolp)
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3513 ;(not (string-match "^\\s " (thing-at-point 'line))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3514 (not (string-match "^\\(\\s \\|%\\)" (thing-at-point 'line))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3515 (progn
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
3516 (unless (save-excursion (backward-char 1) (looking-at "\\s "))
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
3517 (insert " "))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3518 (insert ":-\n")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3519 (prolog-indent-line))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3520 (self-insert-command (prefix-numeric-value arg))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3521
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3522 (defun prolog-electric-dash (arg)
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
3523 "If `prolog-electric-dash-flag' is non-nil, insert the electric `-' construct.
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
3524 that is, insert space (if appropriate), `-->' and newline if dash is pressed
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3525 at the end of a line that starts in the first column (i.e., DCG
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3526 heads)."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3527 (interactive "P")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3528 (if (and prolog-electric-dash-flag
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3529 (null arg)
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
3530 (eolp)
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3531 ;(not (string-match "^\\s " (thing-at-point 'line))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3532 (not (string-match "^\\(\\s \\|%\\)" (thing-at-point 'line))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3533 (progn
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
3534 (unless (save-excursion (backward-char 1) (looking-at "\\s "))
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
3535 (insert " "))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3536 (insert "-->\n")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3537 (prolog-indent-line))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3538 (self-insert-command (prefix-numeric-value arg))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3539
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3540 (defun prolog-electric-dot (arg)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3541 "Insert dot and newline or a head of a new clause.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3542
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3543 If `prolog-electric-dot-flag' is nil, then simply insert dot.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3544 Otherwise::
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3545 When invoked at the end of nonempty line, insert dot and newline.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3546 When invoked at the end of an empty line, insert a recursive call to
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3547 the current predicate.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3548 When invoked at the beginning of line, insert a head of a new clause
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3549 of the current predicate.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3550
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3551 When called with prefix argument ARG, insert just dot."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3552 (interactive "P")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3553 ;; Check for situations when the electricity should not be active
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3554 (if (or (not prolog-electric-dot-flag)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3555 arg
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3556 (prolog-in-string-or-comment)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3557 ;; Do not be electric in a floating point number or an operator
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3558 (not
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3559 (or
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3560 ;; (re-search-backward
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3561 ;; ######
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3562 ;; "\\(^\\|[])}a-zA-Z_!'0-9]+\\)[ \t]*\\=" nil t)))
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3563 (save-excursion
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3564 (re-search-backward
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3565 ;; "\\(^\\|[])}_!'0-9]+\\)[ \t]*\\=" nil t)))
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3566 "\\(^\\|[])}_!'0-9]+\\)[ \t]*\\="
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3567 nil t))
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3568 (save-excursion
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3569 (re-search-backward
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3570 ;; "\\(^\\|[])}a-zA-Z]+\\)[ \t]*\\=" nil t)))
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3571 (format "\\(^\\|[])}%s]+\\)[ \t]*\\="
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
3572 prolog-lower-case-string) ;FIXME: [:lower:]
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3573 nil t))
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3574 (save-excursion
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3575 (re-search-backward
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3576 ;; "\\(^\\|[])}a-zA-Z]+\\)[ \t]*\\=" nil t)))
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3577 (format "\\(^\\|[])}%s]+\\)[ \t]*\\="
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
3578 prolog-upper-case-string) ;FIXME: [:upper:]
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3579 nil t))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3580 )
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3581 )
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3582 ;; Do not be electric if inside a parenthesis pair.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3583 (not (= (prolog-region-paren-balance (prolog-clause-start) (point))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3584 0))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3585 )
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3586 (funcall 'self-insert-command (prefix-numeric-value arg))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3587 (cond
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3588 ;; Beginning of line
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3589 ((bolp)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3590 (prolog-insert-predicate-template))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3591 ;; At an empty line with at least one whitespace
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3592 ((save-excursion
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3593 (beginning-of-line)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3594 (looking-at "[ \t]+$"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3595 (prolog-insert-predicate-template)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3596 (when prolog-electric-dot-full-predicate-template
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3597 (save-excursion
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3598 (end-of-line)
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3599 (insert ".\n"))))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3600 ;; Default
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3601 (t
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3602 (insert ".\n"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3603 )))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3604
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3605 (defun prolog-electric-underscore ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3606 "Replace variable with an underscore.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3607 If `prolog-electric-underscore-flag' is non-nil and the point is
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3608 on a variable then replace the variable with underscore and skip
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3609 the following comma and whitespace, if any.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3610 If the point is not on a variable then insert underscore."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3611 (interactive)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3612 (if prolog-electric-underscore-flag
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3613 (let (;start
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3614 (case-fold-search nil)
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3615 (oldp (point)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3616 ;; ######
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3617 ;;(skip-chars-backward "a-zA-Z_")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3618 (skip-chars-backward
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
3619 (format "%s%s_"
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
3620 ;; FIXME: Why not "a-zA-Z"?
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3621 prolog-lower-case-string
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3622 prolog-upper-case-string))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3623
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3624 ;(setq start (point))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3625 (if (and (not (prolog-in-string-or-comment))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3626 ;; ######
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3627 ;; (looking-at "\\<[_A-Z][a-zA-Z_0-9]*\\>"))
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3628 (looking-at (format "\\<[_%s][%s%s_0-9]*\\>"
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
3629 ;; FIXME: Use [:upper:] and friends.
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3630 prolog-upper-case-string
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3631 prolog-lower-case-string
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3632 prolog-upper-case-string)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3633 (progn
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3634 (replace-match "_")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3635 (skip-chars-forward ", \t\n"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3636 (goto-char oldp)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3637 (self-insert-command 1))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3638 )
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3639 (self-insert-command 1))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3640 )
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3641
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3642
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3643 (defun prolog-find-term (functor arity &optional prefix)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3644 "Go to the position at the start of the next occurance of a term.
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
3645 The term is specified with FUNCTOR and ARITY. The optional argument
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3646 PREFIX is the prefix of the search regexp."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3647 (let* (;; If prefix is not set then use the default "\\<"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3648 (prefix (if (not prefix)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3649 "\\<"
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3650 prefix))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3651 (regexp (concat prefix functor))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3652 (i 1))
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3653
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3654 ;; Build regexp for the search if the arity is > 0
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3655 (if (= arity 0)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3656 ;; Add that the functor must be at the end of a word. This
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3657 ;; does not work if the arity is > 0 since the closing )
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3658 ;; is not a word constituent.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3659 (setq regexp (concat regexp "\\>"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3660 ;; Arity is > 0, add parens and commas
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3661 (setq regexp (concat regexp "("))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3662 (while (< i arity)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3663 (setq regexp (concat regexp ".+,"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3664 (setq i (1+ i)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3665 (setq regexp (concat regexp ".+)")))
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3666
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3667 ;; Search, and return position
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3668 (if (re-search-forward regexp nil t)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3669 (goto-char (match-beginning 0))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3670 (error "Term not found"))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3671 ))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3672
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3673 (defun prolog-variables-to-anonymous (beg end)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3674 "Replace all variables within a region BEG to END by anonymous variables."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3675 (interactive "r")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3676 (save-excursion
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3677 (let ((case-fold-search nil))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3678 (goto-char end)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3679 (while (re-search-backward "\\<[A-Z_][a-zA-Z_0-9]*\\>" beg t)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3680 (progn
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3681 (replace-match "_")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3682 (backward-char)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3683 )))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3684
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3685
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3686 (defun prolog-set-atom-regexps ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3687 "Set the `prolog-atom-char-regexp' and `prolog-atom-regexp' variables.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3688 Must be called after `prolog-build-case-strings'."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3689 (setq prolog-atom-char-regexp
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3690 (format "[%s%s0-9_$]"
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
3691 ;; FIXME: why not a-zA-Z?
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3692 prolog-lower-case-string
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3693 prolog-upper-case-string))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3694 (setq prolog-atom-regexp
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3695 (format "[%s$]%s*"
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3696 prolog-lower-case-string
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3697 prolog-atom-char-regexp))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3698 )
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3699
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3700 (defun prolog-build-case-strings ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3701 "Set `prolog-upper-case-string' and `prolog-lower-case-string'.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3702 Uses the current case-table for extracting the relevant information."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3703 (let ((up_string "")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3704 (low_string ""))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3705 ;; Use `map-char-table' if it is defined. Otherwise enumerate all
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3706 ;; numbers between 0 and 255. `map-char-table' is probably safer.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3707 ;;
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3708 ;; `map-char-table' causes problems under Emacs 23.0.0.1, the
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3709 ;; while loop seems to do its job well (Ryszard Szopa)
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3710 ;;
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
3711 ;;(if (and (not (featurep 'xemacs))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3712 ;; (fboundp 'map-char-table))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3713 ;; (map-char-table
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3714 ;; (lambda (key value)
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3715 ;; (cond
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3716 ;; ((and
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
3717 ;; (eq (prolog-int-to-char key) (downcase key))
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
3718 ;; (eq (prolog-int-to-char key) (upcase key)))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3719 ;; ;; Do nothing if upper and lower case are the same
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3720 ;; )
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
3721 ;; ((eq (prolog-int-to-char key) (downcase key))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3722 ;; ;; The char is lower case
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3723 ;; (setq low_string (format "%s%c" low_string key)))
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
3724 ;; ((eq (prolog-int-to-char key) (upcase key))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3725 ;; ;; The char is upper case
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3726 ;; (setq up_string (format "%s%c" up_string key)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3727 ;; ))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3728 ;; (current-case-table))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3729 ;; `map-char-table' was undefined.
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3730 (let ((key 0))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3731 (while (< key 256)
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3732 (cond
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3733 ((and
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
3734 (eq (prolog-int-to-char key) (downcase key))
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
3735 (eq (prolog-int-to-char key) (upcase key)))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3736 ;; Do nothing if upper and lower case are the same
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3737 )
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
3738 ((eq (prolog-int-to-char key) (downcase key))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3739 ;; The char is lower case
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3740 (setq low_string (format "%s%c" low_string key)))
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
3741 ((eq (prolog-int-to-char key) (upcase key))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3742 ;; The char is upper case
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3743 (setq up_string (format "%s%c" up_string key)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3744 )
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3745 (setq key (1+ key))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3746 ;; )
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3747 ;; The strings are single-byte strings
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3748 (setq prolog-upper-case-string (prolog-dash-letters up_string))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3749 (setq prolog-lower-case-string (prolog-dash-letters low_string))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3750 ))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3751
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3752 ;(defun prolog-regexp-dash-continuous-chars (chars)
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
3753 ; (let ((ints (mapcar #'prolog-char-to-int (string-to-list chars)))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3754 ; (beg 0)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3755 ; (end 0))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3756 ; (if (null ints)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3757 ; chars
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3758 ; (while (and (< (+ beg 1) (length chars))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3759 ; (not (or (= (+ (nth beg ints) 1) (nth (+ beg 1) ints))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3760 ; (= (nth beg ints) (nth (+ beg 1) ints)))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3761 ; (setq beg (+ beg 1)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3762 ; (setq beg (+ beg 1)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3763 ; end beg)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3764 ; (while (and (< (+ end 1) (length chars))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3765 ; (or (= (+ (nth end ints) 1) (nth (+ end 1) ints))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3766 ; (= (nth end ints) (nth (+ end 1) ints))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3767 ; (setq end (+ end 1)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3768 ; (if (equal (substring chars end) "")
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3769 ; (substring chars 0 beg)
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3770 ; (concat (substring chars 0 beg) "-"
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3771 ; (prolog-regexp-dash-continuous-chars (substring chars end))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3772 ; )))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3773
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3774 (defun prolog-ints-intervals (ints)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3775 "Return a list of intervals (from . to) covering INTS."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3776 (when ints
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3777 (setq ints (sort ints '<))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3778 (let ((prev (car ints))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3779 (interval-start (car ints))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3780 intervals)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3781 (while ints
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3782 (let ((next (car ints)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3783 (when (> next (1+ prev)) ; start of new interval
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3784 (setq intervals (cons (cons interval-start prev) intervals))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3785 (setq interval-start next))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3786 (setq prev next)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3787 (setq ints (cdr ints))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3788 (setq intervals (cons (cons interval-start prev) intervals))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3789 (reverse intervals))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3790
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3791 (defun prolog-dash-letters (string)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3792 "Return a condensed regexp covering all letters in STRING."
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
3793 (let ((intervals (prolog-ints-intervals (mapcar #'prolog-char-to-int
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3794 (string-to-list string))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3795 codes)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3796 (while intervals
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3797 (let* ((i (car intervals))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3798 (from (car i))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3799 (to (cdr i))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3800 (c (cond ((= from to) `(,from))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3801 ((= (1+ from) to) `(,from ,to))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3802 (t `(,from ?- ,to)))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3803 (setq codes (cons c codes)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3804 (setq intervals (cdr intervals)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3805 (apply 'concat (reverse codes))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3806
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3807 ;(defun prolog-condense-character-sets (regexp)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3808 ; "Condense adjacent characters in character sets of REGEXP."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3809 ; (let ((next -1))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3810 ; (while (setq next (string-match "\\[\\(.*?\\)\\]" regexp (1+ next)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3811 ; (setq regexp (replace-match (prolog-dash-letters (match-string 1 regexp))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3812 ; t t regexp 1))))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3813 ; regexp)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3814
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3815 ;; GNU Emacs compatibility: GNU Emacs does not differentiate between
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3816 ;; ints and chars, or at least these two are interchangeable.
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
3817 (defalias 'prolog-int-to-char
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
3818 (if (fboundp 'int-to-char) #'int-to-char #'identity))
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
3819
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
3820 (defalias 'prolog-char-to-int
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
3821 (if (fboundp 'char-to-int) #'char-to-int #'identity))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3822
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3823 ;;-------------------------------------------------------------------
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3824 ;; Menu stuff (both for the editing buffer and for the inferior
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3825 ;; prolog buffer)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3826 ;;-------------------------------------------------------------------
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3827
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3828 (unless (fboundp 'region-exists-p)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3829 (defun region-exists-p ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3830 "Non-nil iff the mark is set. Lobotomized version for Emacsen that do not provide their own."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3831 (mark)))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3832
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3833
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3834 ;; GNU Emacs ignores `easy-menu-add' so the order in which the menus
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3835 ;; are defined _is_ important!
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3836
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3837 (easy-menu-define
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3838 prolog-menu-help (list prolog-mode-map prolog-inferior-mode-map)
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3839 "Help menu for the Prolog mode."
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3840 ;; FIXME: Does it really deserve a whole menu to itself?
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3841 `(,(if (featurep 'xemacs) "Help"
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3842 ;; Not sure it's worth the trouble. --Stef
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3843 ;; (add-to-list 'menu-bar-final-items
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3844 ;; (easy-menu-intern "Prolog-Help"))
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3845 "Prolog-help")
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3846 ["On predicate" prolog-help-on-predicate prolog-help-function-i]
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3847 ["Apropos" prolog-help-apropos (eq prolog-system 'swi)]
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3848 "---"
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3849 ["Describe mode" describe-mode t]))
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3850
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3851 (easy-menu-define
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3852 prolog-edit-menu-runtime prolog-mode-map
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3853 "Runtime Prolog commands available from the editing buffer"
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3854 ;; FIXME: Don't use a whole menu for just "Run Mercury". --Stef
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3855 `("System"
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3856 ;; Runtime menu name.
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3857 ,@(unless (featurep 'xemacs)
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3858 '(:label (cond ((eq prolog-system 'eclipse) "ECLiPSe")
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3859 ((eq prolog-system 'mercury) "Mercury")
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3860 (t "System"))))
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3861
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3862 ;; Consult items, NIL for mercury.
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3863 ["Consult file" prolog-consult-file
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3864 :included (not (eq prolog-system 'mercury))]
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3865 ["Consult buffer" prolog-consult-buffer
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3866 :included (not (eq prolog-system 'mercury))]
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3867 ["Consult region" prolog-consult-region :active (region-exists-p)
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3868 :included (not (eq prolog-system 'mercury))]
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3869 ["Consult predicate" prolog-consult-predicate
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3870 :included (not (eq prolog-system 'mercury))]
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3871
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3872 ;; Compile items, NIL for everything but SICSTUS.
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3873 ,(if (featurep 'xemacs) "---"
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3874 ["---" nil :included (eq prolog-system 'sicstus)])
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3875 ["Compile file" prolog-compile-file
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3876 :included (eq prolog-system 'sicstus)]
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3877 ["Compile buffer" prolog-compile-buffer
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3878 :included (eq prolog-system 'sicstus)]
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3879 ["Compile region" prolog-compile-region :active (region-exists-p)
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3880 :included (eq prolog-system 'sicstus)]
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3881 ["Compile predicate" prolog-compile-predicate
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3882 :included (eq prolog-system 'sicstus)]
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3883
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3884 ;; Debug items, NIL for Mercury.
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3885 ,(if (featurep 'xemacs) "---"
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3886 ["---" nil :included (not (eq prolog-system 'mercury))])
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3887 ;; FIXME: Could we use toggle or radio buttons? --Stef
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3888 ["Debug" prolog-debug-on :included (not (eq prolog-system 'mercury))]
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3889 ["Debug off" prolog-debug-off
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3890 ;; In SICStus, these are pairwise disjunctive,
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3891 ;; so it's enough with a single "off"-command
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3892 :included (not (memq prolog-system '(mercury sicstus)))]
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3893 ["Trace" prolog-trace-on :included (not (eq prolog-system 'mercury))]
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3894 ["Trace off" prolog-trace-off
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3895 :included (not (memq prolog-system '(mercury sicstus)))]
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3896 ["Zip" prolog-zip-on :included (and (eq prolog-system 'sicstus)
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3897 (prolog-atleast-version '(3 . 7)))]
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3898 ["All debug off" prolog-debug-off
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3899 :included (eq prolog-system 'sicstus)]
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3900 ["Source level debugging"
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3901 prolog-toggle-sicstus-sd
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3902 :included (and (eq prolog-system 'sicstus)
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3903 (prolog-atleast-version '(3 . 7)))
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3904 :style toggle
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3905 :selected prolog-use-sicstus-sd]
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3906
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3907 "---"
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3908 ["Run" run-prolog
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3909 :suffix (cond ((eq prolog-system 'eclipse) "ECLiPSe")
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3910 ((eq prolog-system 'mercury) "Mercury")
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3911 (t "Prolog"))]))
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3912
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3913 (easy-menu-define
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3914 prolog-edit-menu-insert-move prolog-mode-map
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3915 "Commands for Prolog code manipulation."
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3916 '("Prolog"
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3917 ["Comment region" comment-region (region-exists-p)]
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3918 ["Uncomment region" prolog-uncomment-region (region-exists-p)]
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3919 ["Add comment/move to comment" indent-for-comment t]
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3920 ["Convert variables in region to '_'" prolog-variables-to-anonymous
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3921 :active (region-exists-p) :included (not (eq prolog-system 'mercury))]
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3922 "---"
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3923 ["Insert predicate template" prolog-insert-predicate-template t]
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3924 ["Insert next clause head" prolog-insert-next-clause t]
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3925 ["Insert predicate spec" prolog-insert-predspec t]
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3926 ["Insert module modeline" prolog-insert-module-modeline t]
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3927 "---"
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3928 ["Beginning of clause" prolog-beginning-of-clause t]
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3929 ["End of clause" prolog-end-of-clause t]
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3930 ["Beginning of predicate" prolog-beginning-of-predicate t]
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3931 ["End of predicate" prolog-end-of-predicate t]
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3932 "---"
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3933 ["Indent line" prolog-indent-line t]
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3934 ["Indent region" indent-region (region-exists-p)]
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3935 ["Indent predicate" prolog-indent-predicate t]
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3936 ["Indent buffer" prolog-indent-buffer t]
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3937 ["Align region" align (region-exists-p)]
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3938 "---"
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3939 ["Mark clause" prolog-mark-clause t]
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3940 ["Mark predicate" prolog-mark-predicate t]
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3941 ["Mark paragraph" mark-paragraph t]
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3942 ;;"---"
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3943 ;;["Fontify buffer" font-lock-fontify-buffer t]
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3944 ))
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3945
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3946 (defun prolog-menu ()
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3947 "Add the menus for the Prolog editing buffers."
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3948
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3949 (easy-menu-add prolog-edit-menu-insert-move)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3950 (easy-menu-add prolog-edit-menu-runtime)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3951
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3952 ;; Add predicate index menu
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3953 (set (make-local-variable 'imenu-create-index-function)
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3954 'imenu-default-create-index-function)
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3955 ;;Milan (this has problems with object methods...) ###### Does it? (Stefan)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3956 (setq imenu-prev-index-position-function 'prolog-beginning-of-predicate)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3957 (setq imenu-extract-index-name-function 'prolog-get-predspec)
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3958
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3959 (if (and prolog-imenu-flag
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3960 (< (count-lines (point-min) (point-max)) prolog-imenu-max-lines))
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
3961 (imenu-add-to-menubar "Predicates"))
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3962
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3963 (easy-menu-add prolog-menu-help))
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3964
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3965 (easy-menu-define
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3966 prolog-inferior-menu-all prolog-inferior-mode-map
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3967 "Menu for the inferior Prolog buffer."
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3968 `("Prolog"
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3969 ;; Runtime menu name.
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3970 ,@(unless (featurep 'xemacs)
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3971 '(:label (cond ((eq prolog-system 'eclipse) "ECLiPSe")
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3972 ((eq prolog-system 'mercury) "Mercury")
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3973 (t "Prolog"))))
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3974
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3975 ;; Debug items, NIL for Mercury.
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3976 ,(if (featurep 'xemacs) "---"
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3977 ["---" nil :included (not (eq prolog-system 'mercury))])
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3978 ;; FIXME: Could we use toggle or radio buttons? --Stef
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3979 ["Debug" prolog-debug-on :included (not (eq prolog-system 'mercury))]
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3980 ["Debug off" prolog-debug-off
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3981 ;; In SICStus, these are pairwise disjunctive,
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3982 ;; so it's enough with a single "off"-command
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3983 :included (not (memq prolog-system '(mercury sicstus)))]
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3984 ["Trace" prolog-trace-on :included (not (eq prolog-system 'mercury))]
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3985 ["Trace off" prolog-trace-off
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3986 :included (not (memq prolog-system '(mercury sicstus)))]
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3987 ["Zip" prolog-zip-on :included (and (eq prolog-system 'sicstus)
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3988 (prolog-atleast-version '(3 . 7)))]
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3989 ["All debug off" prolog-debug-off
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3990 :included (eq prolog-system 'sicstus)]
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3991 ["Source level debugging"
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3992 prolog-toggle-sicstus-sd
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3993 :included (and (eq prolog-system 'sicstus)
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3994 (prolog-atleast-version '(3 . 7)))
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3995 :style toggle
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3996 :selected prolog-use-sicstus-sd]
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3997
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3998 ;; Runtime.
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
3999 "---"
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
4000 ["Interrupt Prolog" comint-interrupt-subjob t]
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
4001 ["Quit Prolog" comint-quit-subjob t]
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
4002 ["Kill Prolog" comint-kill-subjob t]))
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
4003
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
4004
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
4005 (defun prolog-inferior-menu ()
112190
0bfc36865094 * lisp/progmodes/prolog.el: Fix up coding conventions and such.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112189
diff changeset
4006 "Create the menus for the Prolog inferior buffer.
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
4007 This menu is dynamically created because one may change systems during
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
4008 the life of an Emacs session."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
4009 (easy-menu-add prolog-inferior-menu-all)
112210
43d75ad47207 * lisp/progmodes/prolog.el: Use syntax-propertize. Further code cleanup.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 112190
diff changeset
4010 (easy-menu-add prolog-menu-help))
112189
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
4011
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
4012 (defun prolog-mode-version ()
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
4013 "Echo the current version of Prolog mode in the minibuffer."
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
4014 (interactive)
b8f8e953d12f * lisp/progmodes/prolog.el: Replace by a whole new file.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 111870
diff changeset
4015 (message "Using Prolog mode version %s" prolog-mode-version))
72684
f65ec4fd2be1 Remove * in docstrings.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 68773
diff changeset
4016
18383
11218164bc54 Add provide call.
Richard M. Stallman <rms@gnu.org>
parents: 17977
diff changeset
4017 (provide 'prolog)
11218164bc54 Add provide call.
Richard M. Stallman <rms@gnu.org>
parents: 17977
diff changeset
4018
659
505130d1ddf8 *** empty log message ***
Eric S. Raymond <esr@snark.thyrsus.com>
parents: 258
diff changeset
4019 ;;; prolog.el ends here