1
0
mirror of https://git.savannah.gnu.org/git/emacs.git synced 2025-01-22 18:35:09 +00:00

Merged from miles@gnu.org--gnu-2005 (patch 34-36, 142-158)

Patches applied:

 * miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-142
   Update from CVS

 * miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-143
   Update from CVS

 * miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-144
   Update from CVS

 * miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-145
   (make-text-button): Default button type if not specified

 * miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-146
   quick-install-emacs: Use mkdir --verbose only when requested

 * miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-147
   Update from CVS

 * miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-148
   Update from CVS

 * miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-149
   Update from CVS

 * miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-150
   Update from CVS

 * miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-151
   Merge from gnus--rel--5.10

 * miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-152
   Add info/dir to arch branch

 * miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-153
   Update from CVS

 * miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-154
   Update from CVS

 * miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-155
   Merge from gnus--rel--5.10

 * miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-156
   Update from CVS

 * miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-157
   Update from CVS

 * miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-158
   Update from CVS

 * miles@gnu.org--gnu-2005/gnus--rel--5.10--patch-34
   Merge from emacs--cvs-trunk--0

 * miles@gnu.org--gnu-2005/gnus--rel--5.10--patch-35
   Update from CVS

 * miles@gnu.org--gnu-2005/gnus--rel--5.10--patch-36
   Update from CVS

git-archimport-id: lorentey@elte.hu--2004/emacs--multi-tty--0--patch-303
This commit is contained in:
Karoly Lorentey 2005-03-06 13:31:20 +00:00
commit a0d878a9cc
67 changed files with 1308 additions and 485 deletions

View File

@ -1,9 +1,6 @@
# Generated files
precious ^(config\.status|config\.cache)$
# Build-in-place makes these directories, so just ignore them
precious ^(info)$
# Install-in-place makes these directories, so just ignore them
backup ^(bin|data|lock|site-lisp)$

View File

@ -1,3 +1,8 @@
2005-03-04 Jan Dj,Ad(Brv <jan.h.d@swipnet.se>
* configure.in: Added --enable-asserts.
* configure: Regenerate.
2005-02-09 Kim F. Storm <storm@cua.dk>
Change release version from 21.4 to 22.1 throughout.

View File

@ -1,3 +1,9 @@
2005-03-02 Miles Bader <miles@gnu.org>
* quick-install-emacs: Only use the mkdir --verbose option if the
script's --verbose option was specified (this avoids problems with
default usage on systems where mkdir doesn't support that option).
2005-02-15 Jason Rumney <jasonr@gnu.org>
* nt/makedist.bat: Do not rely on non-standard behaviour of

View File

@ -37,9 +37,6 @@ invalid pointer from string_free_list.
** Fix up url-ldap.el.
** url/*.el has lots of `(declare (special ...))' which
are meaningless. What's that trying to do?
* BUGS
** Ange-ftp should ignore irrelevant IPv6 errors:
@ -242,7 +239,7 @@ lispref/commands.texi "Luc Teirlinck" Chong Yidong
lispref/compile.texi "Luc Teirlinck" Chong Yidong
lispref/control.texi "Luc Teirlinck" Chong Yidong
lispref/customize.texi
lispref/debugging.texi Joakim Verona <joakim@verona.se>
lispref/debugging.texi Joakim Verona <joakim@verona.se> Lute Kamstra
lispref/display.texi
lispref/edebug.texi
lispref/elisp.texi "Luc Teirlinck"

View File

@ -19,15 +19,16 @@ VERBOSE=''
me="`basename $0`"
# Install commands (these commands are also expected to understand the
# GNU -v (--verbose) option)
# Install commands (if the user specifies the `--verbose' option, it is
# passed to these commands, so that feature only works if these commands
# implement it too)
LINK='cp -lf'
COPY='cp -f'
REMOVE='rm -r'
MKDIR='mkdir -p'
# Used to execute commands once once we create them
EXEC='sh'
MKDIR='mkdir --verbose -p'
NAWK=/usr/bin/nawk
@ -157,7 +158,7 @@ DST_INFO="$prefix/info"
maybe_mkdir ()
{
if ! test -d "$1"; then
$MKDIR "$1" 2>&1 | sed "s/^mkdir:/$me:/" 1>&2
$MKDIR $VERBOSE "$1" 2>&1 | sed "s/^mkdir:/$me:/" 1>&2
fi
}

37
configure vendored
View File

@ -856,6 +856,7 @@ Optional Features:
--enable-FEATURE[=ARG] include FEATURE [ARG=yes]
--enable-carbon-app[=DIR] [DIR=/Application]
specify install directory for Emacs.app on Mac OS X
--enable-asserts compile code with asserts enabled
--enable-maintainer-mode enable make rules and dependencies not useful
(and sometimes confusing) to the casual installer
--disable-largefile omit support for large files
@ -1520,6 +1521,14 @@ if test "${enable_carbon_app+set}" = set; then
carbon_appdir_x=${enableval}
fi;
# Check whether --enable-asserts or --disable-asserts was given.
if test "${enable_asserts+set}" = set; then
enableval="$enable_asserts"
USE_XASSERTS=$enableval
else
USE_XASSERTS=no
fi;
# Check whether --enable-maintainer-mode or --disable-maintainer-mode was given.
if test "${enable_maintainer_mode+set}" = set; then
enableval="$enable_maintainer_mode"
@ -21976,29 +21985,15 @@ echo " Does Emacs use -lpng? ${HAVE_PNG}"
echo " Does Emacs use X toolkit scroll bars? ${USE_TOOLKIT_SCROLL_BARS}"
echo
if test "$emacs_cv_randomheap" = warn; then
{ echo "$as_me:$LINENO: WARNING:
**********************************************************************
Heap start address is randomized and no workaround is known.
Emacs will probably dump core when temacs is run in the build phase.
Maybe exec-shield is turned on. Read about exec-shield in \`etc/PROBLEMS'
for further information.
**********************************************************************
" >&5
echo "$as_me: WARNING:
**********************************************************************
Heap start address is randomized and no workaround is known.
Emacs will probably dump core when temacs is run in the build phase.
Maybe exec-shield is turned on. Read about exec-shield in \`etc/PROBLEMS'
for further information.
**********************************************************************
" >&2;}
if test $USE_XASSERTS = yes; then
echo " Compiling with asserts turned on."
CFLAGS="$CFLAGS -DXASSERTS=1"
CPPFLAGS="$CPPFLAGS -DXASSERTS=1"
echo
fi
# Remove any trailing slashes in these variables.
test "${prefix}" != NONE &&
prefix=`echo "${prefix}" | sed 's,\([^/]\)/*$,\1,'`

View File

@ -125,6 +125,11 @@ AC_ARG_ENABLE(carbon-app,
specify install directory for Emacs.app on Mac OS X]],
[ carbon_appdir_x=${enableval}])
AC_ARG_ENABLE(asserts,
[ --enable-asserts compile code with asserts enabled],
USE_XASSERTS=$enableval,
USE_XASSERTS=no)
AC_ARG_ENABLE(maintainer-mode,
[ --enable-maintainer-mode enable make rules and dependencies not useful
(and sometimes confusing) to the casual installer],
@ -3096,19 +3101,15 @@ echo " Does Emacs use -lpng? ${HAVE_PNG}"
echo " Does Emacs use X toolkit scroll bars? ${USE_TOOLKIT_SCROLL_BARS}"
echo
if test "$emacs_cv_randomheap" = warn; then
AC_MSG_WARN([
**********************************************************************
Heap start address is randomized and no workaround is known.
Emacs will probably dump core when temacs is run in the build phase.
Maybe exec-shield is turned on. Read about exec-shield in `etc/PROBLEMS'
for further information.
**********************************************************************
])
if test $USE_XASSERTS = yes; then
echo " Compiling with asserts turned on."
CFLAGS="$CFLAGS -DXASSERTS=1"
CPPFLAGS="$CPPFLAGS -DXASSERTS=1"
echo
fi
# Remove any trailing slashes in these variables.
[test "${prefix}" != NONE &&
prefix=`echo "${prefix}" | sed 's,\([^/]\)/*$,\1,'`

View File

@ -1,3 +1,11 @@
2005-03-05 YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
* NEWS: Mention Carbon build on Mac OS 9.
2005-03-01 David Kastrup <dak@gnu.org>
* DEBUG: Add information about `-fno-crossjumping' for GCC.
2005-02-14 Lute Kamstra <lute@gnu.org>
* TODO: Remove battery.el entry (DONE).

View File

@ -1,5 +1,5 @@
Debugging GNU Emacs
Copyright (c) 1985, 2000, 2001 Free Software Foundation, Inc.
Copyright (c) 1985, 2000, 2001, 2005 Free Software Foundation, Inc.
Permission is granted to anyone to make or distribute verbatim copies
of this document as received, in any medium, provided that the
@ -20,6 +20,13 @@ document.]
where the executable was made. That directory has a .gdbinit file
that defines various "user-defined" commands for debugging Emacs.
** When you are trying to analyze failed assertions, it will be
essential to compile Emacs either completely without optimizations or
at least (when using GCC) with the -fno-crossjumping option. Failure
to do so may make the compiler recycle the same abort call for all
assertions in a given function, rendering the stack backtrace useless
for identifying the specific failed assertion.
** It is a good idea to run Emacs under GDB (or some other suitable
debugger) *all the time*. Then, when Emacs crashes, you will be able
to debug the live process, not just a core dump. (This is especially

View File

@ -89,6 +89,10 @@ See the files mac/README and mac/INSTALL for build instructions.
---
** Support for GNU/Linux systems on X86-64 machines was added.
** Mac OS 9 port now uses the Carbon API by default. You can also
create non-Carbon build by specifying `NonCarbon' as a target. See
the files mac/README and mac/INSTALL for build instructions.
---
** A French translation of the `Emacs Survival Guide' is available.
@ -99,6 +103,12 @@ types any more. Add -DUSE_LISP_UNION_TYPE if you want union types.
* Changes in Emacs 22.1
** C-u M-x goto-line now switches to the most recent previous buffer,
and goes to the specified line in that buffer.
When goto-line starts to execute, if there's a number in the buffer at
point then it acts as the default argument for the minibuffer.
** Emacs now responds to mouse-clicks on the mode-line, header-line and
display margin, when run in an xterm.
@ -280,6 +290,10 @@ This is like using -q --no-site-file, but in addition it also disables
the menu-bar, the tool-bar, the scroll-bars, tool tips, the blinking
cursor, and the fancy startup screen.
+++
** New command line option -nbc or --no-blinking-cursor disables
the blinking cursor on graphical terminals.
** C-h v and C-h f commands now include a hyperlink to the C source for
variables and functions defined in C (if the C source is available).

19
info/.arch-inventory Normal file
View File

@ -0,0 +1,19 @@
# Only two real source files: "dir", and this file, ".arch-inventory"
source ^(dir|\.arch-inventory)$
# Everything else is generated at compile time. Unfortunately, the "backup"
# category overrides the "source" category, so we have to have horrible
# regexp that matches everything _except_ "dir"...
# 1 or 2 characters long
backup ^[-_.a-zA-Z0-9][-_.a-zA-Z0-9]?$
# 4 or more characters long
backup ^[-_.a-zA-Z0-9][-_.a-zA-Z0-9][-_.a-zA-Z0-9][-_.a-zA-Z0-9]+$
# 3 chars long, but 1st char not "d"
backup ^[-_.abce-zA-Z0-9][-_.a-zA-Z0-9][-_.a-zA-Z0-9]$
# 3 chars long, but 2nd char not "i"
backup ^[-_.a-zA-Z0-9][-_.a-hj-zA-Z0-9][-_.a-zA-Z0-9]$
# 3 chars long, but 3rd char not "r"
backup ^[-_.a-zA-Z0-9][-_.a-zA-Z0-9][-_.a-qs-zA-Z0-9]$
# arch-tag: 60144ab9-cdc1-45b6-8193-b9683c80ec86

77
info/dir Normal file
View File

@ -0,0 +1,77 @@
-*- Text -*-
This is the file .../info/dir, which contains the topmost node of the
Info hierarchy. The first time you invoke Info you start off
looking at that node, which is (dir)Top.

File: dir Node: Top This is the top of the INFO tree
The Info Directory
******************
The Info Directory is the top-level menu of major Info topics.
Type "d" in Info to return to the Info Directory. Type "q" to exit Info.
Type "?" for a list of Info commands, or "h" to visit an Info tutorial.
Type "m" to choose a menu item--for instance,
"mEmacs<Return>" visits the Emacs manual.
In Emacs Info, you can click mouse button 2 on a menu item
or cross reference to follow it to its target.
Each menu line that starts with a * is a topic you can select with "m".
Every third topic has a red * to help pick the right number to type.
* Menu:
* Info: (info). How to use the documentation browsing system.
Emacs
* Emacs: (emacs). The extensible self-documenting text editor.
* Emacs FAQ: (efaq). Frequently Asked Questions about Emacs.
* Emacs Lisp Introduction: (eintr).
A simple introduction to Emacs Lisp programming.
* Elisp: (elisp). The Emacs Lisp Reference Manual.
* CL: (cl). Partial Common Lisp support for Emacs Lisp.
* Dired-X: (dired-x). Dired Extra Features.
* Ediff: (ediff). A visual interface for comparing and merging programs.
* Emacs-Xtra: (emacs-xtra). Specialized Emacs features.
* Org Mode: (org). Outline-based notes management and organizer.
* PCL-CVS: (pcl-cvs). Emacs front-end to CVS.
* Speedbar: (speedbar). File/Tag summarizing utility.
* Ada mode: (ada-mode). Emacs mode for editing Ada code.
* CC mode: (ccmode). Emacs mode for editing C, C++, Objective-C,
Java, Pike, and IDL code.
* Ebrowse: (ebrowse). A C++ class browser for Emacs.
* Flymake: (flymake). An on-the-fly syntax checker for Emacs.
* IDLWAVE: (idlwave). Major mode and shell for IDL and WAVE/CL files.
* Gnus: (gnus). The news reader Gnus.
* Message: (message). Mail and news composition mode that goes with Gnus.
* MH-E: (mh-e). Emacs interface to the MH mail system.
* MIME: (emacs-mime). Emacs MIME de/composition library.
* PGG: (pgg). Emacs interface to various PGP implementations.
* SC: (sc). Supercite lets you cite parts of messages you're
replying to, in flexible ways.
* SMTP: (smtpmail). Emacs library for sending mail via SMTP.
* Sieve: (sieve). Managing Sieve scripts in Emacs.
* Autotype: (autotype). Convenient features for text that you enter frequently
in Emacs.
* Calc: (calc). Advanced desk calculator and mathematical tool.
* Eshell: (eshell). A command shell implemented in Emacs Lisp.
* EUDC: (eudc). An Emacs client for directory servers (LDAP, PH).
* Forms: (forms). Emacs package for editing data bases
by filling in forms.
* RefTeX: (reftex). Emacs support for LaTeX cross-references and citations.
* SES: (ses). Simple Emacs Spreadsheet
* Tramp: (tramp). Transparent Remote (file) Access, Multiple Protocol.
Edit remote files via a remote shell (rsh,
ssh, telnet).
* URL: (url). URL loading package.
* Widget: (widget). The "widget" package used by the Emacs Customization
facility.
* WoMan: (woman). Browse UN*X Manual Pages "Wo (without) Man".
* VIPER: (viper). The newest Emacs VI-emulation mode.
(also, A VI Plan for Emacs Rescue
or the VI PERil.)
* VIP: (vip). An older VI-emulation for Emacs.

View File

@ -1,3 +1,7 @@
2005-03-04 YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
* make-docfile.c: Undo previous change.
2005-02-04 Andreas Schwab <schwab@suse.de>
* movemail.c (fatal): Accept third parameter and pass down to

View File

@ -43,11 +43,11 @@ Boston, MA 02111-1307, USA. */
#undef chdir
#include <stdio.h>
#include <stdlib.h>
#ifdef MSDOS
#include <fcntl.h>
#endif /* MSDOS */
#ifdef WINDOWSNT
#include <stdlib.h>
#include <fcntl.h>
#include <direct.h>
#endif /* WINDOWSNT */

View File

@ -1,7 +1,147 @@
2005-03-05 Luc Teirlinck <teirllm@auburn.edu>
* simple.el (goto-line): Remove unbalanced final parenthesis.
2005-03-05 Richard M. Stallman <rms@gnu.org>
* simple.el (goto-line): Use a number at point as the default.
With C-u as arg, switch buffers.
2005-03-05 Juri Linkov <juri@jurta.org>
* frame.el (blink-cursor-mode): Replace `emacs-quick-startup'
with `no-blinking-cursor'.
* startup.el (no-blinking-cursor): New defvar.
(command-line): Add `--no-blinking-cursor' to longopts.
Set `no-blinking-cursor' to t for command line arguments
-Q, -nbc, --no-blinking-cursor. Replace `emacs-quick-startup'
with `no-blinking-cursor' in the condition for calling
`blink-cursor-mode'.
2005-03-04 Luc Teirlinck <teirllm@auburn.edu>
* menu-bar.el (menu-bar-make-mm-toggle): Doc fix.
(menu-bar-options-save): Add blink-cursor-mode.
(menu-bar-options-menu): Add blink-cursor-mode.
2005-03-04 Ulf Jasper <ulf.jasper@web.de>
* calendar/icalendar.el (icalendar-version): Increase to 0.11.
(icalendar-export-file, icalendar-export-region)
(icalendar-import-file, icalendar-import-buffer): Add autoload
cookies.
(icalendar--convert-ical-to-diary): Fix problem with DURATION.
2005-03-04 Lute Kamstra <lute@gnu.org>
* emacs-lisp/debug.el (debugger-step-after-exit): Make it a
defvar.
(debug-function-list): Ditto.
2005-03-04 Robert J. Chassell <bob@rattlesnake.com>
* textmodes/texinfmt.el (texinfo-append-refill):
Redefine the types of line to which @refill
is not appended by replacing a search for `@refill\\|@bye' with
`@refill\\|^[ \t]*@'. The intent is to solve both the `@end
itemize@refill' bug and the unfilled long lines bug.
(texinfmt-version): update number and date.
2005-03-04 Reiner Steib <Reiner.Steib@gmx.de>
* international/code-pages.el (windows-1250, windows-125[2-8])
(iso-8859-10, -13, -16, georgian-ps): Add autoload cookies.
2005-03-03 Stefan Monnier <monnier@iro.umontreal.ca>
* frame.el (blink-cursor-mode): `emacs-quick-startup' may not be
bound yet.
2005-03-02 Romain Francoise <romain@orebokech.com>
* ibuf-ext.el (ibuffer-filter-disable): Move back to the current
buffer after removing limits.
(ibuffer-pop-filter): Ditto.
Update copyright.
2005-03-02 Miles Bader <miles@gnu.org>
* button.el (make-text-button): If the user doesn't specify a
type, use the default. Rewrite to use `add-text-properties' and
plist functions.
2005-03-01 Lute Kamstra <lute@gnu.org>
* emacs-lisp/debug.el (inhibit-debug-on-entry): Add docstring.
(debugger-jumping-flag): New var.
(debug-entry-code): Use it.
(debugger-jump): Use debugger-jumping-flag and add
debugger-reenable to post-command-hook.
(debugger-reenable): Use debugger-jumping-flag and remove itself
from post-command-hook.
(debug, debug-on-entry, cancel-debug-on-entry): Remove call to
debugger-reenable.
2005-03-01 Robert J. Chassell <bob@rattlesnake.com>
* textmodes/texinfmt.el (texinfo-no-refill-regexp): Comment out
inclusion of "itemize\\|", which may be unnecessary, is certainly
inelegant, and stops refilling in itemize lists when formatting
Japanese Texinfo files to Info.
Update copyright to 2005.
2005-03-01 Nick Roberts <nickrob@snap.net.nz>
* progmodes/gdb-ui.el (gdb-get-location): Use a warning instead
of an error if GDB can't find the source file.
2005-03-01 Glenn Morris <gmorris@ast.cam.ac.uk>
* calendar/calendar.el (redraw-calendar): Work from any buffer,
not just the calendar.
* calendar/diary-lib.el (mark-diary-entries): Remove any old marks
first.
(diary-redraw-calendar): New function.
(make-diary-entry): Add diary-redraw-calendar to local
write-contents-functions. Turn off selective display before
inserting in diary.
2005-03-01 Kim F. Storm <storm@cua.dk>
* emacs-lisp/copyright.el (copyright-fix-years): New command.
2005-03-01 Lute Kamstra <lute@gnu.org>
* emacs-lisp/debug.el (debug-on-entry-1): Reimplement to make sure
that debug-entry-code can be safely removed from a function while
this code is being evaluated. Revert the 2005-02-27 change as the
new implementation no longer requires it. Make sure that a
function body containing just a string is not mistaken for a
docstring.
(debug): Skip one more frame in case of debug on entry.
(debugger-setup-buffer): Delete one more frame line in case of
debug on entry.
(debugger-frame-number): Update to use the new text introduced by
the 1999-11-03 change. Skip one more frame in case of debug on entry.
2005-02-28 Kim F. Storm <storm@cua.dk>
* double.el (double-translate-key): Call force-window-update after
read-event to avoid crash in redisplay.
2005-02-28 Stefan Monnier <monnier@iro.umontreal.ca>
* emacs-lisp/debug.el (inhibit-debug-on-entry): New var.
(debug): Use it. Move the inhibit-trace earlier.
(debug-entry-code): New const.
(debug-on-entry-1): Use it.
2005-02-28 Chong Yidong" <cyd@stupidchicken.com> (tiny change)
* international/utf-16.el (ccl-encode-mule-utf-16le): Fix
BUFFER_MAGNIFICATION to 2.
* international/utf-16.el (ccl-encode-mule-utf-16le):
Fix BUFFER_MAGNIFICATION to 2.
(ccl-encode-mule-utf-16be): Likewise.
2005-02-28 Kenichi Handa <handa@m17n.org>

View File

@ -1,6 +1,6 @@
;;; button.el --- clickable buttons
;;
;; Copyright (C) 2001 Free Software Foundation, Inc.
;; Copyright (C) 2001, 2005 Free Software Foundation, Inc.
;;
;; Author: Miles Bader <miles@gnu.org>
;; Keywords: extensions
@ -298,24 +298,23 @@ large numbers of buttons can also be somewhat faster using
`make-text-button'.
Also see `insert-text-button'."
(let (prop val)
(while properties
(setq prop (pop properties))
(setq val (pop properties))
;; Note that all the following code is basically equivalent to
;; `button-put', but we can do it much more efficiently since we
;; already have BEG and END.
(cond ((memq prop '(type :type))
;; We translate a `type' property into a `category'
;; property, since that's what's actually used by
;; text-properties for inheritance.
(setq prop 'category)
(setq val (button-category-symbol val)))
((eq prop 'category)
;; Disallow setting the `category' property directly.
(error "Button `category' property may not be set directly")))
;; Add the property.
(put-text-property beg end prop val)))
(let ((type-entry
(or (plist-member properties 'type)
(plist-member properties :type))))
;; Disallow setting the `category' property directly.
(when (plist-get properties 'category)
(error "Button `category' property may not be set directly"))
(if (null type-entry)
;; The user didn't specify a `type' property, use the default.
(setq properties (cons 'category (cons 'default-button properties)))
;; The user did specify a `type' property. Translate it into a
;; `category' property, which is what's actually used by
;; text-properties for inheritance.
(setcar type-entry 'category)
(setcar (cdr type-entry)
(button-category-symbol (car (cdr type-entry))))))
;; Now add all the text properties at once
(add-text-properties beg end properties)
;; Return something that can be used to get at the button.
beg)

View File

@ -2169,11 +2169,13 @@ the inserted text. Value is always t."
t)
(defun redraw-calendar ()
"Redraw the calendar display."
"Redraw the calendar display, if `calendar-buffer' is live."
(interactive)
(let ((cursor-date (calendar-cursor-to-nearest-date)))
(generate-calendar-window displayed-month displayed-year)
(calendar-cursor-to-visible-date cursor-date)))
(if (get-buffer calendar-buffer)
(with-current-buffer calendar-buffer
(let ((cursor-date (calendar-cursor-to-nearest-date)))
(generate-calendar-window displayed-month displayed-year)
(calendar-cursor-to-visible-date cursor-date)))))
(defcustom calendar-debug-sexp nil
"*Turn debugging on when evaluating a sexp in the diary or holiday list."

View File

@ -1,6 +1,6 @@
;;; diary-lib.el --- diary functions
;; Copyright (C) 1989, 1990, 1992, 1993, 1994, 1995, 2003, 2004
;; Copyright (C) 1989, 1990, 1992, 1993, 1994, 1995, 2003, 2004, 2005
;; Free Software Foundation, Inc.
;; Author: Edward M. Reingold <reingold@cs.uiuc.edu>
@ -841,6 +841,10 @@ Each entry in the diary file visible in the calendar window is marked.
After the entries are marked, the hooks `nongregorian-diary-marking-hook' and
`mark-diary-entries-hook' are run."
(interactive)
;; To remove any deleted diary entries.
(when mark-diary-entries-in-calendar
(setq mark-diary-entries-in-calendar nil)
(redraw-calendar))
(let ((marking-diary-entries t)
file-glob-attrs marks)
(save-excursion
@ -1647,11 +1651,26 @@ Do nothing if DATE or STRING is nil."
(append diary-entries-list
(list (list date string specifier marker globcolor))))))
(defun diary-redraw-calendar ()
"If `calendar-buffer' is live and diary entries are marked, redraw it."
(and mark-diary-entries-in-calendar
(redraw-calendar))
;; Return value suitable for `write-contents-functions'.
nil)
(defun make-diary-entry (string &optional nonmarking file)
"Insert a diary entry STRING which may be NONMARKING in FILE.
If omitted, NONMARKING defaults to nil and FILE defaults to `diary-file'."
If omitted, NONMARKING defaults to nil and FILE defaults to
`diary-file'. Adds `diary-redraw-calendar' to
`write-contents-functions' for FILE, so that the calendar will be
redrawn with the new entry marked, if necessary."
(let ((pop-up-frames (window-dedicated-p (selected-window))))
(find-file-other-window (substitute-in-file-name (or file diary-file))))
(add-hook 'write-contents-functions 'diary-redraw-calendar nil t)
(when selective-display
(subst-char-in-region (point-min) (point-max) ?\^M ?\n t)
(setq selective-display nil)
(kill-local-variable 'mode-line-format))
(widen)
(goto-char (point-max))
(when (let ((case-fold-search t))

View File

@ -90,7 +90,7 @@
;;; Code:
(defconst icalendar-version 0.10
(defconst icalendar-version 0.11
"Version number of icalendar.el.")
;; ======================================================================
@ -415,8 +415,10 @@ FIXME: multiple comma-separated values should be allowed!"
"Return ISODURATIONSTRING in format like `decode-time'.
Converts from ISO-8601 to Emacs representation. If ISODURATIONSTRING
specifies UTC time (trailing letter Z) the decoded time is given in
the local time zone! FIXME: TZID-attributes are ignored....! FIXME:
multiple comma-separated values should be allowed!"
the local time zone!
FIXME: TZID-attributes are ignored....!
FIXME: multiple comma-separated values should be allowed!"
(if isodurationstring
(save-match-data
(string-match
@ -672,7 +674,7 @@ would be \"pm\"."
;; Export -- convert emacs-diary to icalendar
;; ======================================================================
;; User function
;;;###autoload
(defun icalendar-export-file (diary-filename ical-filename)
"Export diary file to iCalendar format.
All diary entries in the file DIARY-FILENAME are converted to iCalendar
@ -686,7 +688,7 @@ Finto iCalendar file: ")
(defalias 'icalendar-convert-diary-to-ical 'icalendar-export-file)
(make-obsolete 'icalendar-convert-diary-to-ical 'icalendar-export-file)
;; User function
;;;###autoload
(defun icalendar-export-region (min max ical-filename)
"Export region in diary file to iCalendar format.
All diary entries in the region from MIN to MAX in the current buffer are
@ -1112,7 +1114,7 @@ FExport diary data into iCalendar file: ")
;; Import -- convert icalendar to emacs-diary
;; ======================================================================
;; User function
;;;###autoload
(defun icalendar-import-file (ical-filename diary-filename
&optional non-marking)
"Import a iCalendar file and append to a diary file.
@ -1129,7 +1131,7 @@ p")
(set-buffer (find-file ical-filename))
(icalendar-import-buffer diary-filename t non-marking)))
;; User function
;;;###autoload
(defun icalendar-import-buffer (&optional diary-file do-not-ask
non-marking)
"Extract iCalendar events from current buffer.
@ -1423,10 +1425,7 @@ written into the buffer ` *icalendar-errors*'."
((not (string= start-d end-d))
(icalendar--dmsg "non-recurring event")
(let ((ds (icalendar--datetime-to-diary-date dtstart))
(de (icalendar--datetime-to-diary-date
(icalendar--decode-isodatetime
(icalendar--get-event-property e 'DTEND)
-1))))
(de (icalendar--datetime-to-diary-date dtend)))
(setq diary-string
(format "%%%%(and (diary-block %s %s))"
ds de)))

View File

@ -116,6 +116,7 @@ but not `C-u X' or `ESC X' since the X is not the prefix key."
;; End of generated event. See if he will repeat it...
(let ((new (double-read-event prompt))
(entry (assoc double-last-event double-map)))
(force-window-update (selected-window))
(if (eq new double-last-event)
(progn
(setq unread-command-events

View File

@ -1,6 +1,6 @@
;;; copyright.el --- update the copyright notice in current buffer
;; Copyright (C) 1991, 92, 93, 94, 95, 1998, 2001, 2003, 2004
;; Copyright (C) 1991, 1992, 1993, 1994, 1995, 1998, 2001, 2003, 2004, 2005
;; Free Software Foundation, Inc.
;; Author: Daniel Pfeiffer <occitan@esperanto.org>
@ -177,6 +177,41 @@ version \\([0-9]+\\), or (at"
nil))
;;;###autoload
(defun copyright-fix-years ()
"Convert 2 digit years to 4 digit years.
Uses heuristic: year >= 50 means 19xx, < 50 means 20xx."
(interactive)
(widen)
(goto-char (point-min))
(if (re-search-forward copyright-regexp (+ (point) copyright-limit) t)
(let ((s (match-beginning 2)) (e (make-marker))
last)
(set-marker e (1+ (match-end 2)))
(goto-char s)
(while (and (< (point) (marker-position e))
(re-search-forward "\\([^0-9]\\)\\([0-9]+\\)[^0-9]"
(marker-position e) t))
(let ((p (point))
(sep (match-string 1))
(year (string-to-number (match-string 2))))
(goto-char (1+ (match-beginning 0)))
(unless (= (char-syntax (string-to-char sep)) ?\s)
(insert " "))
(if (< year 100)
(insert (if (>= year 50) "19" "20")))
(goto-char p)
(setq last p)))
(when last
(goto-char last)
(let ((fill-prefix " "))
(fill-region s last))
)
(set-marker e nil)
(copyright-update nil t))
(message "No copyright message")
(goto-char (point-min))))
;;;###autoload
(define-skeleton copyright
"Insert a copyright by $ORGANIZATION notice at cursor."

View File

@ -25,7 +25,7 @@
;;; Commentary:
;; This is a major mode documented in the Emacs manual.
;; This is a major mode documented in the Emacs Lisp manual.
;;; Code:
@ -51,15 +51,11 @@ the middle is discarded, and just the beginning and end are displayed."
:group 'debugger
:version "21.1")
(defcustom debug-function-list nil
"List of functions currently set for debug on entry."
:type '(repeat function)
:group 'debugger)
(defvar debug-function-list nil
"List of functions currently set for debug on entry.")
(defcustom debugger-step-after-exit nil
"Non-nil means \"single-step\" after the debugger exits."
:type 'boolean
:group 'debugger)
(defvar debugger-step-after-exit nil
"Non-nil means \"single-step\" after the debugger exits.")
(defvar debugger-value nil
"This is the value for the debugger to return, when it returns.")
@ -93,6 +89,21 @@ This is to optimize `debugger-make-xrefs'.")
(defvar debugger-outer-inhibit-redisplay)
(defvar debugger-outer-cursor-in-echo-area)
(defvar inhibit-debug-on-entry nil
"Non-nil means that debug-on-entry is disabled.")
(defvar debugger-jumping-flag nil
"Non-nil means that debug-on-entry is disabled.
This variable is used by `debugger-jump' and `debugger-reenable'.")
;; When you change this, you may also need to change the number of
;; frames that the debugger skips.
(defconst debug-entry-code
'(if (or inhibit-debug-on-entry debugger-jumping-flag)
nil
(debug 'debug))
"Code added to a function to cause it to call the debugger upon entry.")
;;;###autoload
(setq debugger 'debug)
;;;###autoload
@ -147,6 +158,8 @@ first will be printed into the backtrace buffer."
(setq overriding-terminal-local-map nil)
;; Don't let these magic variables affect the debugger itself.
(let ((last-command nil) this-command track-mouse
(inhibit-trace t)
(inhibit-debug-on-entry t)
unread-command-events
unread-post-input-method-events
last-input-event last-command-event last-nonmenu-event
@ -185,12 +198,11 @@ first will be printed into the backtrace buffer."
(message "%s" (buffer-string))
(kill-emacs))
(if (eq (car debugger-args) 'debug)
;; Skip the frames for backtrace-debug, byte-code, and debug.
(backtrace-debug 3 t))
(debugger-reenable)
;; Skip the frames for backtrace-debug, byte-code,
;; and debug-entry-code.
(backtrace-debug 4 t))
(message "")
(let ((inhibit-trace t)
(standard-output nil)
(let ((standard-output nil)
(buffer-read-only t))
(message "")
;; Make sure we unbind buffer-read-only in the right buffer.
@ -250,7 +262,9 @@ That buffer should be current already."
(delete-region (point)
(progn
(search-forward "\n debug(")
(forward-line 1)
(forward-line (if (eq (car debugger-args) 'debug)
2 ; Remove debug-entry-code frame.
1))
(point)))
(insert "Debugger entered")
;; lambda is for debug-on-call when a function call is next.
@ -395,25 +409,17 @@ will be used, such as in a debug on exit from a frame."
"Continue to exit from this frame, with all debug-on-entry suspended."
(interactive)
(debugger-frame)
;; Turn off all debug-on-entry functions
;; but leave them in the list.
(let ((list debug-function-list))
(while list
(fset (car list)
(debug-on-entry-1 (car list) (symbol-function (car list)) nil))
(setq list (cdr list))))
(setq debugger-jumping-flag t)
(add-hook 'post-command-hook 'debugger-reenable)
(message "Continuing through this frame")
(exit-recursive-edit))
(defun debugger-reenable ()
"Turn all debug-on-entry functions back on."
(let ((list debug-function-list))
(while list
(or (consp (symbol-function (car list)))
(debug-convert-byte-code (car list)))
(fset (car list)
(debug-on-entry-1 (car list) (symbol-function (car list)) t))
(setq list (cdr list)))))
"Turn all debug-on-entry functions back on.
This function is put on `post-command-hook' by `debugger-jump' and
removes itself from that hook."
(setq debugger-jumping-flag nil)
(remove-hook 'post-command-hook 'debugger-reenable))
(defun debugger-frame-number ()
"Return number of frames in backtrace before the one point points at."
@ -423,14 +429,13 @@ will be used, such as in a debug on exit from a frame."
(count 0))
(while (not (eq (cadr (backtrace-frame count)) 'debug))
(setq count (1+ count)))
;; Skip debug-entry-code frame.
(when (member '(debug (quote debug)) (cdr (backtrace-frame (1+ count))))
(setq count (1+ count)))
(goto-char (point-min))
(if (or (equal (buffer-substring (point) (+ (point) 6))
"Signal")
(equal (buffer-substring (point) (+ (point) 6))
"Return"))
(progn
(search-forward ":")
(forward-sexp 1)))
(when (looking-at "Debugger entered--\\(Lisp error\\|returning value\\):")
(goto-char (match-end 0))
(forward-sexp 1))
(forward-line 1)
(while (progn
(forward-char 2)
@ -476,8 +481,6 @@ Applies to the frame whose line point is on in the backtrace."
(insert ? )))
(beginning-of-line))
(put 'debugger-env-macro 'lisp-indent-function 0)
(defmacro debugger-env-macro (&rest body)
"Run BODY in original environment."
@ -626,7 +629,6 @@ which must be written in Lisp, not predefined.
Use \\[cancel-debug-on-entry] to cancel the effect of this command.
Redefining FUNCTION also cancels it."
(interactive "aDebug on entry (to function): ")
(debugger-reenable)
;; Handle a function that has been aliased to some other function.
(if (and (subrp (symbol-function function))
(eq (cdr (subr-arity (symbol-function function))) 'unevalled))
@ -657,7 +659,6 @@ If argument is nil or an empty string, cancel for all functions."
(mapcar 'symbol-name debug-function-list)
nil t nil)))
(if name (intern name)))))
(debugger-reenable)
(if (and function (not (string= function "")))
(progn
(let ((f (debug-on-entry-1 function (symbol-function function) nil)))
@ -698,22 +699,18 @@ If argument is nil or an empty string, cancel for all functions."
(debug-on-entry-1 function (cdr defn) flag)
(or (eq (car defn) 'lambda)
(error "%s not user-defined Lisp function" function))
(let ((tail (cddr defn)))
(let ((tail (cdr defn)))
;; Skip the docstring.
(if (stringp (car tail)) (setq tail (cdr tail)))
(when (and (stringp (cadr tail)) (cddr tail))
(setq tail (cdr tail)))
;; Skip the interactive form.
(if (eq 'interactive (car-safe (car tail))) (setq tail (cdr tail)))
(unless (eq flag (equal (car tail) '(debug 'debug)))
;; If the function has no body, add nil as a body element.
(when (null tail)
(setq tail (list nil))
(nconc defn tail))
(when (eq 'interactive (car-safe (cadr tail)))
(setq tail (cdr tail)))
(unless (eq flag (equal (cadr tail) debug-entry-code))
;; Add/remove debug statement as needed.
(if (not flag)
(progn (setcar tail (cadr tail))
(setcdr tail (cddr tail)))
(setcdr tail (cons (car tail) (cdr tail)))
(setcar tail '(debug 'debug))))
(if flag
(setcdr tail (cons debug-entry-code (cdr tail)))
(setcdr tail (cddr tail))))
defn))))
(defun debugger-list-functions ()

View File

@ -1341,7 +1341,7 @@ Note that this command is effective only when Emacs
displays through a window system, because then Emacs does its own
cursor display. On a text-only terminal, this is not implemented."
:init-value (not (or noninteractive
emacs-quick-startup
(if (boundp 'no-blinking-cursor) no-blinking-cursor)
(eq system-type 'ms-dos)
(not (memq initial-window-system '(x w32)))))
:group 'cursor

View File

@ -1,11 +1,37 @@
2005-03-04 Reiner Steib <Reiner.Steib@gmx.de>
* message.el: Don't autoload former message-utils variables.
(message-strip-subject-trailing-was): Changed doc string.
* nnweb.el: Fixes for `gnus-group-make-web-group'.
(nnweb-type-definition): Don't add "hl=en" in `address'. Added
`base'.
(nnweb-google-search): Add "hl=en" here.
(nnweb-google-parse-1, nnweb-google-create-mapping): Don't
hardcode URL.
2005-03-03 Reiner Steib <Reiner.Steib@gmx.de>
* message.el (message-get-reply-headers, message-followup):
Mention related variables `message-use-followup-to' and
`message-use-mail-followup-to', in the information buffer.
* nnweb.el (nnweb-type-definition): Use groups.google.de instead
of broken groups(-beta).google.com.
2005-03-01 Stefan Monnier <monnier@iro.umontreal.ca>
* gnus-sum.el (gnus-summary-exit): Undo last change and fix it in
a more conservative way.
2005-02-27 Arne J,Ax(Brgensen <arne@arnested.dk>
* mm-decode.el (mm-dissect-buffer): Pass the from field on to
`mm-dissect-multipart' and receive the from field as an (optional)
argument from `mm-dissect-multipart'.
(mm-dissect-multipart): Receive the from field as an argument and
pass it on when we call `mm-dissect-buffer' on MIME parts. Fixes
verification/decryption of signed/encrypted MIME parts.
pass it on when we call `mm-dissect-buffer' on MIME parts.
Fixes verification/decryption of signed/encrypted MIME parts.
2005-02-26 Stefan Monnier <monnier@iro.umontreal.ca>

View File

@ -6680,11 +6680,13 @@ If FORCE (the prefix), also save the .newsrc file(s)."
(set-buffer gnus-group-buffer)
(if quit-config
(gnus-handle-ephemeral-exit quit-config)
(goto-char group-point)
;; If gnus-group-buffer is already displayed, make sure we also move
;; the cursor in the window that displays it.
(let ((win (get-buffer-window (current-buffer) 0)))
(if win (set-window-point win (point))))
(unless leave-hidden
(gnus-configure-windows 'group 'force))
;; Move point after calling gnus-configure-windows to make sure it
;; moves the window's point as well.
(goto-char group-point))
(gnus-configure-windows 'group 'force)))
;; Clear the current group name.
(unless quit-config
(setq gnus-newsgroup-name nil)))))

View File

@ -335,11 +335,8 @@ few false positives here."
:link '(custom-manual "(message)Message Headers")
:type 'regexp)
;; Fixme: Why are all these things autoloaded?
;;; marking inserted text
;;;###autoload
(defcustom message-mark-insert-begin
"--8<---------------cut here---------------start------------->8---\n"
"How to mark the beginning of some inserted text."
@ -348,7 +345,6 @@ few false positives here."
:link '(custom-manual "(message)Insertion Variables")
:group 'message-various)
;;;###autoload
(defcustom message-mark-insert-end
"--8<---------------cut here---------------end--------------->8---\n"
"How to mark the end of some inserted text."
@ -357,9 +353,7 @@ few false positives here."
:link '(custom-manual "(message)Insertion Variables")
:group 'message-various)
;;;###autoload
(defcustom message-archive-header
"X-No-Archive: Yes\n"
(defcustom message-archive-header "X-No-Archive: Yes\n"
"Header to insert when you don't want your article to be archived.
Archives \(such as groups.google.com\) respect this header."
:version "22.1"
@ -367,7 +361,6 @@ Archives \(such as groups.google.com\) respect this header."
:link '(custom-manual "(message)Header Commands")
:group 'message-various)
;;;###autoload
(defcustom message-archive-note
"X-No-Archive: Yes - save http://groups.google.com/"
"Note to insert why you wouldn't want this posting archived.
@ -385,7 +378,6 @@ If nil, don't insert any text in the body."
"Old target for cross-posts or follow-ups.")
(make-variable-buffer-local 'message-cross-post-old-target)
;;;###autoload
(defcustom message-cross-post-default t
"When non-nil `message-cross-post-followup-to' will perform a crosspost.
If nil, `message-cross-post-followup-to' will only do a followup. Note that
@ -395,25 +387,19 @@ you can explicitly override this setting by calling
:type 'boolean
:group 'message-various)
;;;###autoload
(defcustom message-cross-post-note
"Crosspost & Followup-To: "
(defcustom message-cross-post-note "Crosspost & Followup-To: "
"Note to insert before signature to notify of cross-post and follow-up."
:version "22.1"
:type 'string
:group 'message-various)
;;;###autoload
(defcustom message-followup-to-note
"Followup-To: "
(defcustom message-followup-to-note "Followup-To: "
"Note to insert before signature to notify of follow-up only."
:version "22.1"
:type 'string
:group 'message-various)
;;;###autoload
(defcustom message-cross-post-note-function
'message-cross-post-insert-note
(defcustom message-cross-post-note-function 'message-cross-post-insert-note
"Function to use to insert note about Crosspost or Followup-To.
The function will be called with four arguments. The function should not only
insert a note, but also ensure old notes are deleted. See the documentation
@ -1766,7 +1752,7 @@ see `message-narrow-to-headers-or-head'."
;;; Start of functions adopted from `message-utils.el'.
(defun message-strip-subject-trailing-was (subject)
"Remove trailing \"(Was: <old subject>)\" from SUBJECT lines.
"Remove trailing \"(was: <old subject>)\" from SUBJECT lines.
Leading \"Re: \" is not stripped by this function. Use the function
`message-strip-subject-re' for this."
(let* ((query message-subject-trailing-was-query)
@ -5675,7 +5661,10 @@ because discussions that are spread over several lists tend to be
fragmented and very difficult to follow.
Also, some source/announcement lists are not intended for discussion;
responses here are directed to other addresses.")))
responses here are directed to other addresses.
You may customize the variable `message-use-mail-followup-to', if you
want to get rid of this query permanently.")))
(setq recipients (concat ", " mft)))
(to-address
(setq recipients (concat ", " to-address))
@ -5871,7 +5860,10 @@ You should normally obey the Followup-To: header.
`Followup-To: poster' sends your response via e-mail instead of news.
A typical situation where `Followup-To: poster' is used is when the poster
does not read the newsgroup, so he wouldn't see any replies sent to it."))
does not read the newsgroup, so he wouldn't see any replies sent to it.
You may customize the variable `message-use-followup-to', if you
want to get rid of this query permanently."))
(progn
(setq message-this-is-news nil)
(cons 'To (or mrt reply-to from "")))
@ -5894,7 +5886,10 @@ because discussions that are spread over several newsgroup tend to
be fragmented and very difficult to follow.
Also, some source/announcement newsgroups are not intended for discussion;
responses here are directed to other newsgroups."))
responses here are directed to other newsgroups.
You may customize the variable `message-use-followup-to', if you
want to get rid of this query permanently."))
(cons 'Newsgroups followup-to)
(cons 'Newsgroups newsgroups))))))
(posted-to

View File

@ -54,11 +54,12 @@ Valid types include `google', `dejanews', and `gmane'.")
(defvar nnweb-type-definition
'((google
(article . ignore)
(id . "http://groups.google.com/groups?selm=%s&output=gplain")
(id . "http://groups.google.de/groups?selm=%s&output=gplain")
(reference . identity)
(map . nnweb-google-create-mapping)
(search . nnweb-google-search)
(address . "http://groups.google.com/groups")
(address . "http://groups.google.de/groups")
(base . "http://groups.google.de")
(identifier . nnweb-google-identity))
(dejanews ;; alias of google
(article . ignore)
@ -67,6 +68,7 @@ Valid types include `google', `dejanews', and `gmane'.")
(map . nnweb-google-create-mapping)
(search . nnweb-google-search)
(address . "http://groups.google.com/groups")
(base . "http://groups.google.com")
(identifier . nnweb-google-identity))
(gmane
(article . nnweb-gmane-wash-article)
@ -349,7 +351,7 @@ Valid types include `google', `dejanews', and `gmane'.")
"a href=/groups\\(\\?[^ \">]*selm=\\([^ &\">]+\\)\\)" nil t)
(setq mid (match-string 2)
url (format
"http://groups.google.com/groups?selm=%s&output=gplain" mid))
(nnweb-definition 'id) mid))
(narrow-to-region (search-forward ">" nil t)
(search-forward "</a>" nil t))
(mm-url-remove-markup)
@ -420,7 +422,7 @@ Valid types include `google', `dejanews', and `gmane'.")
(>= i nnweb-max-hits))
(setq more nil)
;; Yup, there are more articles
(setq more (concat "http://groups.google.com" (match-string 1)))
(setq more (concat (nnweb-definition 'base) (match-string 1)))
(when more
(erase-buffer)
(mm-url-insert more))))
@ -435,9 +437,9 @@ Valid types include `google', `dejanews', and `gmane'.")
"?"
(mm-url-encode-www-form-urlencoded
`(("q" . ,search)
("num". "100")
("num" . "100")
("hq" . "")
("hl" . "")
("hl" . "en")
("lr" . "")
("safe" . "off")
("sites" . "groups")))))

View File

@ -1,6 +1,6 @@
;;; ibuf-ext.el --- extensions for ibuffer
;; Copyright (C) 2000, 2001, 2002, 2003, 2004 Free Software Foundation, Inc.
;; Copyright (C) 2000, 2001, 2002, 2003, 2004, 2005 Free Software Foundation, Inc.
;; Author: Colin Walters <walters@verbum.org>
;; Maintainer: John Paul Wallington <jpw@gnu.org>
@ -753,7 +753,10 @@ of replacing the current filters."
"Disable all filters currently in effect in this buffer."
(interactive)
(setq ibuffer-filtering-qualifiers nil)
(ibuffer-update nil t))
(let ((buf (ibuffer-current-buffer)))
(ibuffer-update nil t)
(when buf
(ibuffer-jump-to-buffer (buffer-name buf)))))
;;;###autoload
(defun ibuffer-pop-filter ()
@ -762,7 +765,10 @@ of replacing the current filters."
(when (null ibuffer-filtering-qualifiers)
(error "No filters in effect"))
(pop ibuffer-filtering-qualifiers)
(ibuffer-update nil t))
(let ((buf (ibuffer-current-buffer)))
(ibuffer-update nil t)
(when buf
(ibuffer-jump-to-buffer (buffer-name buf)))))
(defun ibuffer-push-filter (qualifier)
"Add QUALIFIER to `ibuffer-filtering-qualifiers'."

View File

@ -1,6 +1,6 @@
;;; code-pages.el --- coding systems for assorted codepages -*-coding: utf-8;-*-
;; Copyright (C) 2001, 2002 Free Software Foundation, Inc.
;; Copyright (C) 2001, 2002, 2003, 2004, 2005 Free Software Foundation, Inc.
;; Author: Dave Love <fx@gnu.org>
;; Keywords: i18n
@ -2440,6 +2440,7 @@ Return an updated `non-iso-charset-alist'."
nil
nil])
;;;###autoload(autoload-coding-system 'windows-1250 '(require 'code-pages))
(cp-make-coding-system
windows-1250
[?\€
@ -2571,6 +2572,7 @@ Return an updated `non-iso-charset-alist'."
?\ţ
?\˙])
;;;###autoload(autoload-coding-system 'windows-1253 '(require 'code-pages))
(cp-make-coding-system
windows-1253
[?\€
@ -2703,6 +2705,7 @@ Return an updated `non-iso-charset-alist'."
nil]
nil ?g) ;; Greek
;;;###autoload(autoload-coding-system 'windows-1254 '(require 'code-pages))
(cp-make-coding-system
windows-1254
[?\€
@ -2835,6 +2838,7 @@ Return an updated `non-iso-charset-alist'."
?\ÿ])
;; yi_US
;;;###autoload(autoload-coding-system 'windows-1255 '(require 'code-pages))
(cp-make-coding-system
windows-1255
[?\€
@ -2967,6 +2971,7 @@ Return an updated `non-iso-charset-alist'."
nil]
nil ?h) ;; Hebrew
;;;###autoload(autoload-coding-system 'windows-1256 '(require 'code-pages))
(cp-make-coding-system
windows-1256
[?\€
@ -3099,6 +3104,7 @@ Return an updated `non-iso-charset-alist'."
?\ے]
nil ?a) ;; Arabic
;;;###autoload(autoload-coding-system 'windows-1257 '(require 'code-pages))
(cp-make-coding-system
windows-1257
[?\€
@ -3230,6 +3236,7 @@ Return an updated `non-iso-charset-alist'."
?\ž
nil])
;;;###autoload(autoload-coding-system 'windows-1258 '(require 'code-pages))
(cp-make-coding-system
windows-1258
[?\€
@ -3652,6 +3659,7 @@ Return an updated `non-iso-charset-alist'."
;; ISO 8859-16 was primarily designed for single-byte encoding the Romanian
;; language. The UTF-8 charset is the preferred and in today's MIME software
;; more widely implemented encoding suitable for Romanian.
;;;###autoload(autoload-coding-system 'iso-8859-16 '(require 'code-pages))
(cp-make-coding-system
iso-latin-10 ; consistent with, e.g. Latin-1
[nil nil nil nil nil nil nil nil nil nil nil nil nil nil nil nil nil
@ -3823,6 +3831,7 @@ Return an updated `non-iso-charset-alist'."
?6)
(define-coding-system-alias 'arabic-iso-8bit 'iso-8859-6)
;;;###autoload(autoload-coding-system 'iso-8859-10 '(require 'code-pages))
(cp-make-coding-system
iso-latin-6
[nil nil nil nil nil nil nil nil nil nil nil nil nil nil nil nil nil
@ -3929,6 +3938,7 @@ Return an updated `non-iso-charset-alist'."
(define-coding-system-alias 'latin-6 'iso-latin-6)
;; used by lt_LT, lv_LV, mi_NZ
;;;###autoload(autoload-coding-system 'iso-8859-13 '(require 'code-pages))
(cp-make-coding-system
iso-latin-7
[nil nil nil nil nil nil nil nil nil nil nil nil nil nil nil nil nil
@ -4039,6 +4049,7 @@ Return an updated `non-iso-charset-alist'."
;; Fixme: check on the C1 characters which libiconv includes. They
;; are reproduced below, but are probably wrong. I can't find an
;; official definition of georgian-ps.
;;;###autoload(autoload-coding-system 'georgian-ps '(require 'code-pages))
(cp-make-coding-system
georgian-ps ; used by glibc for ka_GE
[?\€

View File

@ -590,7 +590,7 @@ Do the same for the keys of the same name."
(defmacro menu-bar-make-mm-toggle (fname doc help &optional props)
"Make a menu-item for a global minor mode toggle.
FNAME is the minor mode's name (variable and function).
DOC is the text to use the menu entry.
DOC is the text to use for the menu entry.
HELP is the text to use for the tooltip.
PROPS are additional properties."
`'(menu-item ,doc ,fname
@ -637,7 +637,8 @@ by \"Save Options\" in Custom buffers.")
;; These are set with menu-bar-make-mm-toggle, which does not
;; put on a customized-value property.
(dolist (elt '(line-number-mode column-number-mode cua-mode show-paren-mode
transient-mark-mode global-font-lock-mode))
transient-mark-mode global-font-lock-mode
blink-cursor-mode))
(and (customize-mark-to-save elt)
(setq need-save t)))
;; These are set with `customize-set-variable'.
@ -959,6 +960,14 @@ by \"Save Options\" in Custom buffers.")
"Enter Lisp debugger when an error is signaled"))
(define-key menu-bar-options-menu [debugger-separator]
'("--"))
(define-key menu-bar-options-menu [blink-cursor-mode]
(menu-bar-make-mm-toggle blink-cursor-mode
"Blinking Cursor"
"Whether the cursor blinks (Blink Cursor mode)"))
(define-key menu-bar-options-menu [cursor-separator]
'("--"))
(define-key menu-bar-options-menu [toggle-auto-compression]
'(menu-item "Automatic File De/compression"
auto-compression-mode

View File

@ -514,6 +514,10 @@ Faces `compilation-error-face', `compilation-warning-face',
(and (cdr type) (match-end (cdr type)) compilation-info-face)
compilation-error-face))
;; Internal function for calculating the text properties of a directory
;; change message. The directory property is important, because it is
;; the stack of nested enter-messages. Relative filenames on the following
;; lines are relative to the top of the stack.
(defun compilation-directory-properties (idx leave)
(if leave (setq leave (match-end leave)))
;; find previous stack, and push onto it, or if `leave' pop it

View File

@ -880,8 +880,7 @@ sink to `user' in `gdb-stopping', that is fine."
"An annotation handler for `post-prompt'.
This begins the collection of output from the current command if that
happens to be appropriate."
(if (not gdb-pending-triggers)
(progn
(unless gdb-pending-triggers
(gdb-get-current-frame)
(gdb-invalidate-frames)
(gdb-invalidate-breakpoints)
@ -897,7 +896,7 @@ happens to be appropriate."
(setq gdb-var-changed t) ; force update
(dolist (var gdb-var-list)
(setcar (nthcdr 5 var) nil))
(gdb-var-update)))))
(gdb-var-update))))
(let ((sink gdb-output-sink))
(cond
((eq sink 'user) t)
@ -1211,14 +1210,13 @@ static char *magick[] = {
(goto-line (string-to-number line))
(gdb-put-breakpoint-icon (eq flag ?y) bptno)))
(gdb-enqueue-input
(list (concat gdb-server-prefix "list "
(list (concat "list "
(match-string-no-properties 1) ":1\n")
'ignore))
(gdb-enqueue-input
(list (concat gdb-server-prefix "info source\n")
`(lambda ()
(gdb-get-location
,bptno ,line ,flag)))))))))))
(list "info source\n"
`(lambda () (gdb-get-location
,bptno ,line ,flag)))))))))))
(end-of-line)))))
(if (gdb-get-buffer 'gdb-assembler-buffer) (gdb-assembler-custom)))
@ -2108,22 +2106,29 @@ buffers."
"Find the directory containing the relevant source file.
Put in buffer and place breakpoint icon."
(goto-char (point-min))
(if (search-forward "Located in " nil t)
(if (looking-at "\\S-*")
(push (cons bptno (match-string 0)) gdb-location-list))
(gdb-resync)
(push (cons bptno "File not found") gdb-location-list)
(error "Cannot find source file for breakpoint location.
(catch 'file-not-found
(if (search-forward "Located in " nil t)
(if (looking-at "\\S-*")
(push (cons bptno (match-string 0)) gdb-location-list))
(gdb-resync)
(push (cons bptno "File not found") gdb-location-list)
(if (eq window-system 'x)
(x-popup-dialog
t '("Cannot find source file for breakpoint location.\n\
Add directory to search path for source files using the GDB command, dir."
("Ok" . nil)))
(message "Cannot find source file for breakpoint location.\n\
Add directory to search path for source files using the GDB command, dir."))
(with-current-buffer
(find-file-noselect (match-string 0))
(save-current-buffer
(set (make-local-variable 'gud-minor-mode) 'gdba)
(set (make-local-variable 'tool-bar-map) gud-tool-bar-map))
;; only want one breakpoint icon at each location
(save-excursion
(goto-line (string-to-number line))
(gdb-put-breakpoint-icon (eq flag ?y) bptno))))
(throw 'file-not-found nil))
(with-current-buffer
(find-file-noselect (match-string 0))
(save-current-buffer
(set (make-local-variable 'gud-minor-mode) 'gdba)
(set (make-local-variable 'tool-bar-map) gud-tool-bar-map))
;; only want one breakpoint icon at each location
(save-excursion
(goto-line (string-to-number line))
(gdb-put-breakpoint-icon (eq flag ?y) bptno)))))
(add-hook 'find-file-hook 'gdb-find-file-hook)

View File

@ -733,10 +733,48 @@ that uses or sets the mark."
;; Counting lines, one way or another.
(defun goto-line (arg)
"Goto line ARG, counting from line 1 at beginning of buffer."
(interactive "NGoto line: ")
(setq arg (prefix-numeric-value arg))
(defun goto-line (arg &optional buffer)
"Goto line ARG, counting from line 1 at beginning of buffer.
Normally, move point in the curren buffer.
With just C-u as argument, move point in the most recently displayed
other buffer, and switch to it.
If there's a number in the buffer at point, it is the default for ARG."
(interactive
(if (and current-prefix-arg (not (consp current-prefix-arg)))
(list (prefix-numeric-value current-prefix-arg))
;; Look for a default, a number in the buffer at point.
(let* ((default
(save-excursion
(skip-chars-backward "0-9")
(if (looking-at "[0-9]")
(buffer-substring-no-properties
(point)
(progn (skip-chars-forward "0-9")
(point))))))
;; Decide if we're switching buffers.
(buffer
(if (consp current-prefix-arg)
(other-buffer (current-buffer) t)))
(buffer-prompt
(if buffer
(concat " in " (buffer-name buffer))
"")))
;; Read the argument, offering that number (if any) as default.
(list (read-from-minibuffer (format (if default "Goto line%s (%s): "
"Goto line%s: ")
buffer-prompt
default)
nil nil t
'minibuffer-history
default)
buffer))))
;; Switch to the desired buffer, one way or another.
(if buffer
(let ((window (get-buffer-window buffer)))
(if window (select-window window)
(switch-to-buffer-other-window buffer))))
;; Move to the specified line number in that buffer.
(save-restriction
(widen)
(goto-char 1)

View File

@ -290,6 +290,8 @@ from being initialized."
(defvar normal-top-level-add-subdirs-inode-list nil)
(defvar no-blinking-cursor nil)
(defvar pure-space-overflow nil
"Non-nil if building Emacs overflowed pure space.")
@ -674,7 +676,8 @@ opening the first frame (e.g. open a connection to the server).")
;; does things.
(while (and (not done) args)
(let* ((longopts '(("--no-init-file") ("--no-site-file") ("--user")
("--debug-init") ("--iconic") ("--icon-type")))
("--debug-init") ("--iconic") ("--icon-type")
("--no-blinking-cursor")))
(argi (pop args))
(orig-argi argi)
argval)
@ -697,6 +700,7 @@ opening the first frame (e.g. open a connection to the server).")
((equal argi "-Q")
(setq init-file-user nil
site-run-file nil
no-blinking-cursor t
emacs-quick-startup t)
(push '(vertical-scroll-bars . nil) initial-frame-alist))
((member argi '("-q" "-no-init-file"))
@ -712,6 +716,8 @@ opening the first frame (e.g. open a connection to the server).")
(push '(visibility . icon) initial-frame-alist))
((member argi '("-icon-type" "-i" "-itype"))
(push '(icon-type . t) default-frame-alist))
((member argi '("-nbc" "-no-blinking-cursor"))
(setq no-blinking-cursor t))
;; Push the popped arg back on the list of arguments.
(t
(push argi args)
@ -747,7 +753,7 @@ opening the first frame (e.g. open a connection to the server).")
;; you should also change the corresponding expression in the
;; defcustom in frame.el, or Custom will be badly confused.
(unless (or noninteractive
emacs-quick-startup
no-blinking-cursor
(eq system-type 'ms-dos)
(not (memq initial-window-system '(x w32))))
(blink-cursor-mode 1))

View File

@ -1,7 +1,7 @@
;;; texinfmt.el --- format Texinfo files into Info files
;; Copyright (C) 1985, 1986, 1988, 1990, 1991, 1992, 1993,
;; 1994, 1995, 1996, 1997, 1998, 2000, 2001
;; 1994, 1995, 1996, 1997, 1998, 2000, 2001, 2005
;; Free Software Foundation, Inc.
;; Maintainer: Robert J. Chassell <bug-texinfo@gnu.org>
@ -37,7 +37,7 @@
(defmacro defcustom (var value doc &rest ignore)
`(defvar ,var ,value ,doc)))
(defvar texinfmt-version "2.40 of 6 Dec 2002")
(defvar texinfmt-version "2.41 of 1 Mar 2005")
(defun texinfmt-version (&optional here)
"Show the version of texinfmt.el in the minibuffer.
@ -486,7 +486,8 @@ if large. You can use Info-split to do this manually."
;; I don't know if this causes other problems.
;; I suspect itemized lists don't get filled properly and a
;; more precise fix is required. Bob
"itemize\\|"
;; commented out on 2005 Feb 28 by Bob
;; "itemize\\|"
"direntry\\|"
"lisp\\|"
"smalllisp\\|"
@ -636,7 +637,7 @@ Do not append @refill to paragraphs containing @w{TEXT} or @*."
(forward-char 1)
(unless (re-search-backward "@c[ \t\n]\\|@comment[ \t\n]" line-beg t)
(forward-char -1))
(unless (re-search-backward "@refill\\|@bye" line-beg t)
(unless (re-search-backward "@refill\\|^[ \t]*@" line-beg t)
(insert "@refill")))
(forward-line 1))))))

View File

@ -1,3 +1,32 @@
2005-03-05 Richard M. Stallman <rms@gnu.org>
* debugging.texi (Error Debugging): Remove stack-trace-on-error.
2005-03-04 Lute Kamstra <lute@gnu.org>
* debugging.texi (Error Debugging): Document stack-trace-on-error.
2005-03-03 Lute Kamstra <lute@gnu.org>
* edebug.texi (Instrumenting Macro Calls): Fix typo.
2005-03-01 Lute Kamstra <lute@gnu.org>
* debugging.texi (Debugger Commands): Update `j'.
2005-02-28 Lute Kamstra <lute@gnu.org>
* debugging.texi (Debugging): Fix typo.
(Error Debugging): Document eval-expression-debug-on-error.
(Function Debugging): Update example.
(Using Debugger): Mention starred stack frames.
(Debugger Commands): Document `j' and `l'.
(Invoking the Debugger): `d' and `j' exit recursive edit too.
Update the messages that the debugger displays.
(Internals of Debugger): Add cross reference. Update example.
(Excess Open): Minor improvement.
(Excess Close): Minor improvement.
2005-02-26 Richard M. Stallman <rms@gnu.org>
* tips.texi (Coding Conventions): Clarify.

View File

@ -1,6 +1,6 @@
@c -*-texinfo-*-
@c This is part of the GNU Emacs Lisp Reference Manual.
@c Copyright (C) 1990, 1991, 1992, 1993, 1994, 1998, 1999
@c Copyright (C) 1990, 1991, 1992, 1993, 1994, 1998, 1999, 2005
@c Free Software Foundation, Inc.
@c See the file elisp.texi for copying conditions.
@setfilename ../info/debugging
@ -14,7 +14,7 @@ depending on what you are doing with the program when the problem appears.
@item
If the problem occurs when you run the program, you can use a Lisp
debugger to investigate what is happening during execution. In addition
to the ordinary debugger, Emacs comes with a source level debugger,
to the ordinary debugger, Emacs comes with a source-level debugger,
Edebug. This chapter describes both of them.
@item
@ -117,6 +117,15 @@ the error. The easiest way is usually to set
@code{debug-ignored-errors} to @code{nil}.
@end defopt
@defopt eval-expression-debug-on-error
If you set this variable to a non-@code{nil} value, then
@code{debug-on-error} will be set to @code{t} when evaluating with the
command @code{eval-expression}. If
@code{eval-expression-debug-on-error} is @code{nil}, then the value of
@code{debug-on-error} is not changed. @xref{Lisp Eval,, Evaluating
Emacs-Lisp Expressions, emacs, The GNU Emacs Manual}.
@end defopt
@defopt debug-on-signal
Normally, errors that are caught by @code{condition-case} never run the
debugger, even if @code{debug-on-error} is non-@code{nil}. In other
@ -240,14 +249,12 @@ Here's an example to illustrate use of this function:
@group
------ Buffer: *Backtrace* ------
Entering:
Debugger entered--entering a function:
* fact(3)
eval-region(4870 4878 t)
byte-code("...")
eval((fact 3))
eval-last-sexp-1(nil)
eval-last-sexp(nil)
(let ...)
eval-insert-last-sexp(nil)
* call-interactively(eval-insert-last-sexp)
call-interactively(eval-last-sexp)
------ Buffer: *Backtrace* ------
@end group
@ -317,7 +324,9 @@ moving point to the line describing that frame. (A stack frame is the
place where the Lisp interpreter records information about a particular
invocation of a function.) The frame whose line point is on is
considered the @dfn{current frame}. Some of the debugger commands
operate on the current frame.
operate on the current frame. If a line starts with a star, that means
that exiting that frame will call the debugger again. This is useful
for examining the return value of a function.
If a function name is underlined, that means the debugger knows
where its source code is located. You can click @kbd{Mouse-2} on that
@ -328,8 +337,6 @@ assumptions about how many stack frames are used for the debugger
itself. These assumptions are false if the debugger is running
interpreted.
@need 3000
@node Debugger Commands
@subsection Debugger Commands
@cindex debugger command list
@ -378,6 +385,11 @@ Don't enter the debugger when the current frame is exited. This
cancels a @kbd{b} command on that frame. The visible effect is to
remove the star from the line in the backtrace buffer.
@item j
Flag the current frame like @kbd{b}. Then continue execution like
@kbd{c}, but temporarily disable break-on-entry for all functions that
are set up to do so by @code{debug-on-entry}.
@item e
Read a Lisp expression in the minibuffer, evaluate it, and print the
value in the echo area. The debugger alters certain important
@ -410,6 +422,13 @@ used as the value of that frame. It is also useful if you call
effect as @kbd{c}, and the specified return value does not matter.
You can't use @kbd{r} when the debugger was entered due to an error.
@item l
Display a list of functions that will invoke the debugger when called.
This is a list of functions that are set to break on entry by means of
@code{debug-on-entry}. @strong{Warning:} if you redefine such a
function and thus cancel the effect of @code{debug-on-entry}, it may
erroneously show up in this list.
@end table
@node Invoking the Debugger
@ -425,10 +444,10 @@ recursive entry to the debugger, etc.), and fills it with information
about the stack of Lisp function calls. It then enters a recursive
edit, showing the backtrace buffer in Debugger mode.
The Debugger mode @kbd{c} and @kbd{r} commands exit the recursive edit;
then @code{debug} switches back to the previous buffer and returns to
whatever called @code{debug}. This is the only way the function
@code{debug} can return to its caller.
The Debugger mode @kbd{c}, @kbd{d}, @kbd{j}, and @kbd{r} commands exit
the recursive edit; then @code{debug} switches back to the previous
buffer and returns to whatever called @code{debug}. This is the only
way the function @code{debug} can return to its caller.
The use of the @var{debugger-args} is that @code{debug} displays the
rest of its arguments at the top of the @samp{*Backtrace*} buffer, so
@ -443,41 +462,41 @@ is a table of these special values:
@table @code
@item lambda
@cindex @code{lambda} in debug
A first argument of @code{lambda} means @code{debug} was called because
of entry to a function when @code{debug-on-next-call} was
non-@code{nil}. The debugger displays @samp{Entering:} as a line of
text at the top of the buffer.
A first argument of @code{lambda} means @code{debug} was called
because of entry to a function when @code{debug-on-next-call} was
non-@code{nil}. The debugger displays @samp{Debugger
entered--entering a function:} as a line of text at the top of the
buffer.
@item debug
@code{debug} as first argument indicates a call to @code{debug} because
of entry to a function that was set to debug on entry. The debugger
displays @samp{Entering:}, just as in the @code{lambda} case. It also
marks the stack frame for that function so that it will invoke the
debugger when exited.
@code{debug} as first argument indicates a call to @code{debug}
because of entry to a function that was set to debug on entry. The
debugger displays @samp{Debugger entered--entering a function:}, just
as in the @code{lambda} case. It also marks the stack frame for that
function so that it will invoke the debugger when exited.
@item t
When the first argument is @code{t}, this indicates a call to
@code{debug} due to evaluation of a list form when
@code{debug-on-next-call} is non-@code{nil}. The debugger displays the
following as the top line in the buffer:
@smallexample
Beginning evaluation of function call form:
@end smallexample
@code{debug-on-next-call} is non-@code{nil}. The debugger displays
@samp{Debugger entered--beginning evaluation of function call form:}
as the top line in the buffer.
@item exit
When the first argument is @code{exit}, it indicates the exit of a stack
frame previously marked to invoke the debugger on exit. The second
argument given to @code{debug} in this case is the value being returned
from the frame. The debugger displays @samp{Return value:} in the top
line of the buffer, followed by the value being returned.
When the first argument is @code{exit}, it indicates the exit of a
stack frame previously marked to invoke the debugger on exit. The
second argument given to @code{debug} in this case is the value being
returned from the frame. The debugger displays @samp{Debugger
entered--returning value:} in the top line of the buffer, followed by
the value being returned.
@item error
@cindex @code{error} in debug
When the first argument is @code{error}, the debugger indicates that
it is being entered because an error or @code{quit} was signaled and not
handled, by displaying @samp{Signaling:} followed by the error signaled
and any arguments to @code{signal}. For example,
it is being entered because an error or @code{quit} was signaled and
not handled, by displaying @samp{Debugger entered--Lisp error:}
followed by the error signaled and any arguments to @code{signal}.
For example,
@example
@group
@ -487,7 +506,7 @@ and any arguments to @code{signal}. For example,
@group
------ Buffer: *Backtrace* ------
Signaling: (arith-error)
Debugger entered--Lisp error: (arith-error)
/(1 0)
...
------ Buffer: *Backtrace* ------
@ -522,7 +541,7 @@ some kind of debugger. The default value of the variable is
The first argument that Lisp hands to the function indicates why it
was called. The convention for arguments is detailed in the description
of @code{debug}.
of @code{debug} (@pxref{Invoking the Debugger}).
@end defvar
@deffn Command backtrace
@ -567,17 +586,14 @@ forms are elided.
(save-excursion ...)
(let ...)
(with-output-to-temp-buffer ...)
eval-region(1973 2142 #<buffer *scratch*>)
byte-code("... for eval-print-last-sexp ...")
eval((with-output-to-temp-buffer ...))
eval-last-sexp-1(nil)
@group
eval-print-last-sexp(nil)
* call-interactively(eval-print-last-sexp)
eval-last-sexp(nil)
call-interactively(eval-last-sexp)
----------- Buffer: backtrace-output ------------
@end group
@end smallexample
The character @samp{*} indicates a frame whose debug-on-exit flag is
set.
@end deffn
@ignore @c Not worth mentioning
@ -687,8 +703,8 @@ find the mismatch.)
The first step is to find the defun that is unbalanced. If there is
an excess open parenthesis, the way to do this is to go to the end of
the file and type @kbd{C-u C-M-u}. This will move you to the beginning
of the defun that is unbalanced.
the file and type @kbd{C-u C-M-u}. This will move you to the
beginning of the first defun that is unbalanced.
The next step is to determine precisely what is wrong. There is no
way to be sure of this except by studying the program, but often the
@ -719,9 +735,9 @@ anything.
@node Excess Close
@subsection Excess Close Parentheses
To deal with an excess close parenthesis, first go to the beginning of
the file, then type @kbd{C-u -1 C-M-u} to find the end of the unbalanced
defun.
To deal with an excess close parenthesis, first go to the beginning
of the file, then type @kbd{C-u -1 C-M-u} to find the end of the first
unbalanced defun.
Then find the actual matching close parenthesis by typing @kbd{C-M-f}
at the beginning of that defun. This will leave you somewhere short of

View File

@ -1,6 +1,6 @@
@comment -*-texinfo-*-
@c This is part of the GNU Emacs Lisp Reference Manual.
@c Copyright (C) 1992, 1993, 1994, 1998, 1999 Free Software Foundation, Inc.
@c Copyright (C) 1992, 1993, 1994, 1998, 1999, 2005 Free Software Foundation, Inc.
@c See the file elisp.texi for copying conditions.
@c This file can also be used by an independent Edebug User
@ -1082,7 +1082,7 @@ the @code{for} example macro (@pxref{Argument Evaluation}).
(defmacro for (var from init to final do &rest body)
"Execute a simple \"for\" loop.
For example, (for i from 1 to 10 do (print i))."
(declare (edebug symbolp "from" form "to" form "do" &rest form))
(declare (debug symbolp "from" form "to" form "do" &rest form))
...)
@end example

View File

@ -1,3 +1,17 @@
2005-03-05 YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
* INSTALL: Mention new target `NonCarbon'.
2005-03-04 YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
* makefile.MPW (NonCarbon): New target. The target `Emacs' is now
used for the Carbon build that defines HAVE_CARBON.
* inc/config.h (HAVE_STDLIB_H): Define to 1.
* src/EmacsMPW.r (SIZE): Increase preferred memory size to 32MB.
[HAVE_CARBON] (crfg): New resource for extra stack space.
2004-12-24 YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
* makefile.MPW: Add dependencies for fringe.c.x, image.c.x, and

View File

@ -182,6 +182,12 @@ makefile.mpw. I.e., execute the commands
make Emacs -f makefile.MPW > Emacs.MakeScript
Emacs.MakeScript
The above commands create an executable that uses the Carbon API. The
non-Carbon version can also be created by replacing all the
occurrences of `Emacs' above with `NonCarbon'. Not that the
non-Carbon version does not support some features such as file
dialogs, drag-and-drop, and unicode menus.
To build Emacs using CodeWarrior, start up the CodeWarrior IDE, choose
File->Import Project... and select the file cw6-mcp.xml. When
prompted to save the project, navigate to same directory as the file

View File

@ -184,7 +184,7 @@ Boston, MA 02111-1307, USA. */
/* #undef HAVE_TERMIOS_H */
#define HAVE_LIMITS_H 1
#define HAVE_STRING_H 1
/* #undef HAVE_STDLIB_H */
#define HAVE_STDLIB_H 1
/* #undef HAVE_TERMCAP_H */
/* #undef HAVE_TERM_H */
/* #undef HAVE_STDIO_EXT_H */

View File

@ -21,7 +21,8 @@
# Boston, MA 02111-1307, USA. */
#
# Defines the following targets:
# Emacs (default) - normal Emacs build.
# Emacs (default) - normal Carbon Emacs build.
# NonCarbon - non-Carbon Emacs build.
# Clean - remove all object and executable files to prepare for a fresh build.
# Doc - generate the "DOC" file in ~emacs/etc/.
# Make-DocFile - build the make-docfile tool, utility for generating "DOC".
@ -38,7 +39,9 @@ Lisp = ::lisp: # emacs's lisp directory
Make-DocFileDir = {Lib-Src} # directory containing make-docfile tool
Makefile = makefile.MPW # self reference
NonCarbonMakeOut = NonCarbon.MakeOut # temporary file for non-Carbon build script
CarbonOption = -d HAVE_CARBON
SymOption = # -sym on # remove hash mark before "-sym on" to enable source debugging
OptOption = # -opt speed # alternatively set to -opt off or -opt size
@ -47,7 +50,7 @@ OptOption = # -opt speed # alternatively set to -opt off or -opt size
PPCCOptions = {SymOption} {OptOption} -noMapCR -enum int -alloca ¶
-typecheck relaxed -w off ¶
-includes unix -i {Includes},{Src} ¶
-d emacs=1 -d HAVE_CONFIG_H -d MAC_OS -d MAC_OS8
-d emacs=1 -d HAVE_CONFIG_H -d MAC_OS -d MAC_OS8 {CarbonOption}
LinkOptions = {SymOption} -d
@ -132,29 +135,42 @@ MacObjects =
"{Src}macmenu.c.x" ¶
"{Src}macterm.c.x"
StdLibraries = ¶
"{SharedLibraries}CarbonLib" ¶
"{SharedLibraries}StdCLib" ¶
"{PPCLibraries}StdCRuntime.o" ¶
"{PPCLibraries}PPCCRuntime.o"
NonCarbonLibs = ¶
"{SharedLibraries}InterfaceLib" ¶
"{SharedLibraries}StdCLib" ¶
"{SharedLibraries}MathLib" ¶
"{SharedLibraries}AppleScriptLib" ¶
"{SharedLibraries}TextEncodingConverter" ¶
"{SharedLibraries}AppearanceLib" ¶
"{SharedLibraries}QuickTimeLib" ¶
"{PPCLibraries}StdCRuntime.o" ¶
"{PPCLibraries}PPCCRuntime.o" ¶
"{PPCLibraries}PPCToolLibs.o"
# The next two are the dependency rules for building Emacs.
Emacs ÄÄ {Makefile} {DocTarget}DOC {EmacsObjects} {MacObjects}
PPCLink ¶
{LinkOptions} ¶
{EmacsObjects} {MacObjects} ¶
"{SharedLibraries}InterfaceLib" ¶
"{SharedLibraries}StdCLib" ¶
"{SharedLibraries}MathLib" ¶
"{SharedLibraries}AppleScriptLib" ¶
"{SharedLibraries}TextEncodingConverter" ¶
"{SharedLibraries}AppearanceLib" ¶
"{SharedLibraries}QuickTimeLib" ¶
"{PPCLibraries}StdCRuntime.o" ¶
"{PPCLibraries}PPCCRuntime.o" ¶
"{PPCLibraries}PPCToolLibs.o" ¶
{StdLibraries} ¶
-o "{EmacsTarget}"
Emacs ÄÄ {Makefile} "{Source}"Emacs.maclf.r "{Source}"EmacsMPW.maclf.r
Rez -a "{Source}"Emacs.maclf.r -o "{EmacsTarget}"
Rez -a "{Source}"EmacsMPW.maclf.r -o "{EmacsTarget}"
Rez {CarbonOption} -a "{Source}"Emacs.maclf.r -o "{EmacsTarget}"
Rez {CarbonOption} -a "{Source}"EmacsMPW.maclf.r -o "{EmacsTarget}"
SetFile "{EmacsTarget}" -t APPL -c 'EMAx' -a B
NonCarbon Ä
Make -f "{Makefile}" -d CarbonOption="" -d StdLibraries='{NonCarbonLibs}' > "{NonCarbonMakeOut}"
"{NonCarbonMakeOut}"
# Rez cannot handle files with Unix style end lines at all. So generate
# them. It does not hurt if Emacs.r and EmacsMPW.r already have Mac end
# lines.
@ -951,6 +967,7 @@ Clean
Delete -i stdout stderr
Delete -i {Make-DocFile-Objects} {Make-DocFileDir}make-docfile
Delete -i "{Source}"Emacs.maclf.r "{Source}"EmacsMPW.maclf.r
Delete -i "{NonCarbonMakeOut}"
DistClean Ä Clean
Delete -i "Emacs CW"Å

View File

@ -42,6 +42,18 @@ resource 'SIZE' (-1) {
reserved,
reserved,
reserved,
16777216,
33554432,
16777216
};
#ifdef HAVE_CARBON
resource 'cfrg' (0) {
{
kPowerPCCFragArch, kIsCompleteCFrag, kNoVersionNum, kNoVersionNum,
311296, /* 48K (default) + 256K (EXTRA_STACK_ALLOC in macterm.c) */
kNoAppSubFolder,
kApplicationCFrag, kDataForkCFragLocator, kZeroOffset, kCFragGoesToEOF,
"",
}
};
#endif

View File

@ -1,3 +1,37 @@
2005-03-05 Thien-Thi Nguyen <ttn@gnu.org>
* flymake.texi: Refill and tweak style in @lisp blocks.
2005-03-05 Juri Linkov <juri@jurta.org>
* cmdargs.texi (Emacs Invocation): Add cindex
"invocation (command line arguments)"
(Misc X): Add -nbc, --no-blinking-cursor.
2005-03-04 Ulf Jasper <ulf.jasper@web.de>
* calendar.texi (iCalendar): No need to require it now.
2005-03-03 Reiner Steib <Reiner.Steib@gmx.de>
* gnus.texi (Slow/Expensive Connection): Don't abbreviate "very".
2005-03-03 Nick Roberts <nickrob@snap.net.nz>
* trouble.texi (Contributing): Mention Savannah. Direct users to
emacs-devel.
2005-03-01 Glenn Morris <gmorris@ast.cam.ac.uk>
* calendar.texi (Adding to Diary): Mention redrawing of calendar
window.
2005-03-01 Jay Belanger <belanger@truman.edu>
* calc.texi (Trigonometric and Hyperbolic Functions):
Mention additional functions.
(Algebraic Simplifications): Mention additional simplifications.
2005-02-27 Matt Hodges <MPHodges@member.fsf.org>
* calendar.texi (General Calendar): Document binding of

View File

@ -18473,6 +18473,25 @@ With the Inverse flag [@code{arcsincos}], this command takes a two-element
vector as an argument and computes @code{arctan2} of the elements.
(This command does not accept the Hyperbolic flag.)
@pindex calc-sec
@tindex sec
@pindex calc-csc
@tindex csc
@pindex calc-cot
@tindex cot
@pindex calc-sech
@tindex sech
@pindex calc-csch
@tindex csch
@pindex calc-coth
@tindex coth
The remaining trigonometric functions, @code{calc-sec} [@code{sec}],
@code{calc-csc} [@code{csc}] and @code{calc-sec} [@code{sec}], are also
available. With the Hyperbolic flag, these compute their hyperbolic
counterparts, which are also available separately as @code{calc-sech}
[@code{sech}], @code{calc-csch} [@code{csch}] and @code{calc-sech}
[@code{sech}]. (These commmands do not accept the Inverse flag.)
@node Advanced Math Functions, Branch Cuts, Trigonometric and Hyperbolic Functions, Scientific Functions
@section Advanced Mathematical Functions
@ -22730,18 +22749,27 @@ declared to be an integer.
\bigskip
@end tex
Trigonometric functions are simplified in several ways. First,
@expr{@tfn{sin}(@tfn{arcsin}(x))} is simplified to @expr{x}, and
similarly for @code{cos} and @code{tan}. If the argument to
@code{sin} is negative-looking, it is simplified to
@expr{-@tfn{sin}(x),}, and similarly for @code{cos} and @code{tan}.
Finally, certain special values of the argument are recognized;
@pxref{Trigonometric and Hyperbolic Functions}.
Trigonometric functions are simplified in several ways. Whenever a
products of two trigonometric functions can be replaced by a single
function, the replacement is made; for example,
@expr{@tfn{tan}(x) @tfn{cos}(x)} is simplified to @expr{@tfn{sin}(x)}.
Reciprocals of trigonometric functions are replaced by their reciprocal
function; for example, @expr{1/@tfn{sec}(x)} is simplified to
@expr{@tfn{cos}(x)}. The corresponding simplifications for the
hyperbolic functions are also handled.
Trigonometric functions of their inverse functions are
simplified. The expression @expr{@tfn{sin}(@tfn{arcsin}(x))} is
simplified to @expr{x}, and similarly for @code{cos} and @code{tan}.
Trigonometric functions of inverses of different trigonometric
functions can also be simplified, as in @expr{@tfn{sin}(@tfn{arccos}(x))}
to @expr{@tfn{sqrt}(1 - x^2)}.
If the argument to @code{sin} is negative-looking, it is simplified to
@expr{-@tfn{sin}(x)}, and similarly for @code{cos} and @code{tan}.
Finally, certain special values of the argument are recognized;
@pxref{Trigonometric and Hyperbolic Functions}.
Hyperbolic functions of their inverses and of negative-looking
arguments are also handled, as are exponentials of inverse
hyperbolic functions.

View File

@ -1206,7 +1206,10 @@ make a nonmarking diary entry, give a numeric argument to the command.
For example, @kbd{C-u i w} makes a nonmarking weekly diary entry.
When you modify the diary file, be sure to save the file before
exiting Emacs.
exiting Emacs. Saving the diary file after using any of the above
insertion commands will automatically update the diary marks in the
calendar window, if appropriate. You can use the command
@code{redraw-calendar} to force an update at any time.
@node Special Diary Entries
@subsection Special Diary Entries
@ -1403,8 +1406,6 @@ Exporting of diary files into iCalendar files should work correctly for
most diary entries. Please note that @file{icalendar.el} is work in
progress, so usage may evolve in future.
To activate the package, use @code{(require 'icalendar)}.
@findex icalendar-import-buffer
The command @code{icalendar-import-buffer} extracts
iCalendar data from the current buffer and adds it to your (default)

View File

@ -9,6 +9,7 @@
@cindex options (command line)
@cindex switches (command line)
@cindex startup (command line arguments)
@cindex invocation (command line arguments)
GNU Emacs supports command line arguments to request various actions
when invoking Emacs. These are for compatibility with other editors and
@ -1211,6 +1212,13 @@ Enable vertical scroll bars.
@opindex --line-spacing
@cindex line spacing, command-line argument
Specify @var{pixels} as additional space to put between lines, in pixels.
@item -nbc
@opindex -nbc
@itemx --no-blinking-cursor
@opindex --no-blinking-cursor
@cindex blinking cursor disable, command-line argument
Disable the blinking cursor on graphical terminals.
@end table
The @samp{--xrm} option (@pxref{Resources}) specifies additional

View File

@ -419,19 +419,16 @@ checking.
First, we write the @code{init-function}:
@lisp
(defun flymake-perl-init(buffer)
(let* ((temp-file (flymake-init-create-temp-buffer-copy
buffer
'flymake-create-temp-inplace))
(local-file (concat (flymake-build-relative-path
(file-name-directory
(buffer-file-name
(current-buffer)))
(file-name-directory temp-file))
(file-name-nondirectory temp-file))))
(list "perl" (list "-wc " local-file))
)
)
(defun flymake-perl-init (buffer)
(let* ((temp-file (flymake-init-create-temp-buffer-copy
buffer 'flymake-create-temp-inplace))
(local-file (concat (flymake-build-relative-path
(file-name-directory
(buffer-file-name
(current-buffer)))
(file-name-directory temp-file))
(file-name-nondirectory temp-file))))
(list "perl" (list "-wc " local-file))))
@end lisp
@code{flymake-perl-init} creates a temporary copy of the buffer
@ -444,11 +441,11 @@ Next, we add a new entry to the
@lisp
(setq flymake-allowed-file-name-masks
(cons '(".+\\.pl$"
flymake-perl-init
flymake-simple-cleanup
flymake-get-real-file-name)
flymake-allowed-file-name-masks))
(cons '(".+\\.pl$"
flymake-perl-init
flymake-simple-cleanup
flymake-get-real-file-name)
flymake-allowed-file-name-masks))
@end lisp
Note that we use standard @code{cleanup-function} and
@ -458,8 +455,9 @@ Finally, we add an entry to @code{flymake-err-line-patterns}:
@lisp
(setq flymake-err-line-patterns
(cons '("\\(.*\\) at \\([^ \n]+\\) line \\([0-9]+\\)[,.\n]" 2 3 nil 1)
flymake-err-line-patterns))
(cons '("\\(.*\\) at \\([^ \n]+\\) line \\([0-9]+\\)[,.\n]"
2 3 nil 1)
flymake-err-line-patterns))
@end lisp
@node Example -- Configuring a tool called via make
@ -475,11 +473,11 @@ functions for @code{make}. We just add a new entry to the
@lisp
(setq flymake-allowed-file-name-masks
(cons '(".+\\.c$"
flymake-simple-make-init
flymake-simple-cleanup
flymake-get-real-file-name)
flymake-allowed-file-name-masks))
(cons '(".+\\.c$"
flymake-simple-make-init
flymake-simple-cleanup
flymake-get-real-file-name)
flymake-allowed-file-name-masks))
@end lisp
@code{flymake-simple-make-init} builds the following @code{make}
@ -487,12 +485,11 @@ command line:
@lisp
(list "make"
(list "-s"
"-C"
base-dir
(concat "CHK_SOURCES=" source)
"SYNTAX_CHECK_MODE=1"
"check-syntax"))
(list "-s" "-C"
base-dir
(concat "CHK_SOURCES=" source)
"SYNTAX_CHECK_MODE=1"
"check-syntax"))
@end lisp
@code{base-dir} is a directory containing @code{Makefile}, see @ref{Locating the buildfile}.
@ -748,12 +745,11 @@ Flymake also provides an alternative command for starting compilation,
@code{flymake-compile}:
@lisp
(defun flymake-compile()
"kill all flymake syntax checks, start compilation"
(interactive)
(flymake-stop-all-syntax-checks)
(call-interactively 'compile)
)
(defun flymake-compile ()
"Kill all flymake syntax checks then start compilation."
(interactive)
(flymake-stop-all-syntax-checks)
(call-interactively 'compile))
@end lisp
It just kills all the active syntax check processes before calling

View File

@ -26688,7 +26688,7 @@ Gnus has to get from the @acronym{NNTP} server.
@item gnus-read-active-file
Set this to @code{nil}, which will inhibit Gnus from requesting the
entire active file from the server. This file is often v. large. You
entire active file from the server. This file is often very large. You
also have to set @code{gnus-check-new-newsgroups} and
@code{gnus-check-bogus-newsgroups} to @code{nil} to make sure that Gnus
doesn't suddenly decide to fetch the active file anyway.

View File

@ -1037,17 +1037,22 @@ form that is clearly safe to install.
If you would like to help pretest Emacs releases to assure they work
well, or if you would like to work on improving Emacs, please contact
the maintainers at @email{bug-gnu-emacs@@gnu.org}. A pretester
the maintainers at @email{emacs-devel@@gnu.org}. A pretester
should be prepared to investigate bugs as well as report them. If you'd
like to work on improving Emacs, please ask for suggested projects or
suggest your own ideas.
If you have already written an improvement, please tell us about it. If
you have not yet started work, it is useful to contact
@email{bug-gnu-emacs@@gnu.org} before you start; it might be
@email{emacs-devel@@gnu.org} before you start; it might be
possible to suggest ways to make your extension fit in better with the
rest of Emacs.
The development version of Emacs can be downloaded from the CVS
repository where it is actively maintained by a group of developers.
See the Emacs project page http://savannah.gnu.org/projects/emacs/ for
details.
@node Service, Copying, Contributing, Top
@section How To Get Help with GNU Emacs

View File

@ -1,6 +1,115 @@
2005-03-05 Juri Linkov <juri@jurta.org>
* emacs.c (USAGE1): Replace Info node name "command arguments"
with "emacs invocation".
(USAGE3): Fix usage of `--color=MODE' which actually doesn't
allow arguments `--color' and `MODE' to be separated by space.
Add --no-blinking-cursor, -nbc.
(standard_args): Add -nbc, --no-blinking-cursor.
2005-03-04 Thien-Thi Nguyen <ttn@gnu.org>
* s/vms.h: Define NO_HYPHENS_IN_FILENAMES.
* s/vms4-4.h, s/vms5-5.h: Undefine NO_HYPHENS_IN_FILENAMES.
* fileio.c (Fexpand_file_name) [VMS]:
Use NO_HYPHENS_IN_FILENAMES, not VMS4_4.
* doc.c (munge_doc_file_name) [VMS]: Likewise.
(Fsnarf_documentation): Call munge_doc_file_name.
2005-03-04 Thien-Thi Nguyen <ttn@gnu.org>
* s/vms.h (FILE_SYSTEM_CASE): New macro.
* fileio.c (Fexpand_file_name) [VMS]: Don't upcase the name
"manually"; this is now handled generally via FILE_SYSTEM_CASE.
2005-03-04 YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
* emacs.c (main): Change `#ifdef HAVE_CARBON' to `#if
defined (MAC_OSX) && defined (HAVE_CARBON)'.
* image.c [!MAC_OSX && TARGET_API_MAC_CARBON]: Include
QuickTime.h.
* mac.c [!MAC_OSX && HAVE_CARBON]: Include Carbon.h.
[!MAC_OSX] (select) [TARGET_API_MAC_CARBON]: Use ReceiveNextEvent.
(posix_pathname_to_fsspec, fsspec_to_posix_pathname): New
functions.
(mac_clear_font_name_table): Move extern to macterm.h.
* macfns.c (install_window_handler): Move extern to macterm.h.
(Fx_file_dialog): Check STRINGP (default_filename) to see it is
valid. Don't check !NILP (dir) because it is already checked with
CHECK_STRING.
(Fx_file_dialog) [!MAC_OSX]: Use FSSpec instead of FSRef for
specifying the default location and obtaining the selected
filename.
* macgui.h [!MAC_OSX && HAVE_CARBON]: Include Carbon.h.
* macmenu.c [TARGET_API_MAC_CARBON]: Don't include headers that
are included via Carbon.h.
* macterm.c [TARGET_API_MAC_CARBON && !MAC_OSX]: Define
USE_CARBON_EVENTS to 1.
(qd) [__MRC__ && TARGET_API_MAC_CARBON]: Don't declare.
(x_free_frame_resources): Call remove_window_handler for
non-tooltip windows.
[TARGET_API_MAC_CARBON]: Don't include headers that are included
via Carbon.h.
[TARGET_API_MAC_CARBON] (mac_do_track_dragUPP)
(mac_do_receive_dragUPP): New variables.
(mac_handle_service_event, init_service_handler): Put declarations
and definitions in #ifdef MAC_OSX.
(install_window_handler) [TARGET_API_MAC_CARBON]: Create UPPs for
drag-and-drop handler functions and register them.
(remove_window_handler): New function.
(do_ae_open_documents, mac_do_receive_drag) [!MAC_OSX]: Use
fsspec_to_posix_pathname.
(main): Change #if !TARGET_API_MAC_CARBON to #ifdef MAC_OS8.
(XTread_socket) [!MAC_OSX]: Don't pass keyboard events to TSM.
[MAC_OS8] (make_mac_terminal_frame) [TARGET_API_MAC_CARBON]: Set
default cursors.
(mac_initialize) [USE_CARBON_EVENTS && !MAC_OSX] : Don't call
init_service_handler or init_quit_char_handler.
(mac_initialize) [!MAC_OSX]: Don't call MakeMeTheFrontProcess.
* macterm.h (install_window_handler, remove_window_handler)
(posix_pathname_to_fsspec, fsspec_to_posix_pathname)
(mac_clear_font_name_table): New externs.
2005-03-03 Thien-Thi Nguyen <ttn@gnu.org>
* fileio.c (FILE_SYSTEM_CASE): Define macro if not already defined.
(Ffile_name_directory): Use FILE_SYSTEM_CASE unconditionally.
(Fexpand_file_name): Likewise.
2005-03-03 Thien-Thi Nguyen <ttn@gnu.org>
* emacs.c (Fkill_emacs): Use EXIT_SUCCESS;
no longer special-case VMS. Add bogus return value.
2005-03-02 Kim F. Storm <storm@cua.dk>
* dispextern.h (XASSERTS): Define to 0 if not already defined.
(xassert) [!XASSERTS]: Define dummy version.
2005-03-02 Kim F. Storm <storm@cua.dk>
* xdisp.c (redisplay_window): YABX (yet another bogus xassert).
Reported by David Kastrup.
2005-03-01 Ehud Karni <ehud@unix.mvs.co.il>
* xdisp.c (get_next_display_element): Fix control and escape
glyph from display vector.
2005-03-01 Stefan Monnier <monnier@iro.umontreal.ca>
* keyboard.c (Fposn_at_x_y): Check integerness of X and Y.
2005-02-27 Jan Dj,Ad(Brv <jan.h.d@swipnet.se>
* gtkutil.c (xg_resize_outer_widget): Removed unneeded call to
* gtkutil.c (xg_resize_outer_widget): Remove unneeded call to
gtk_window_resize and x_wm_set_size_hint.
2005-02-25 Kim F. Storm <storm@cua.dk>
@ -30,7 +139,7 @@
* window.c (window_scroll_pixel_based): When scrolling backwards,
handle partial visible line at end of window even when we hit PT.
2005-02-21 Stefan <monnier@iro.umontreal.ca>
2005-02-21 Stefan Monnier <monnier@iro.umontreal.ca>
* keymap.h: Declare Fcurrent_active_maps, used in doc.c.
@ -88,8 +197,7 @@
(Fx_window_property): Likewise.
* xselect.c (Fx_disown_selection_internal): Use union of struct
input_event and struct selection_input_event to avoid aliasing
issues.
input_event and struct selection_input_event to avoid aliasing issues.
* xterm.c (handle_one_xevent): Use union of struct input_event and
struct selection_input_event to avoid aliasing issues.
@ -118,21 +226,20 @@
clipboard operations and delayed rendering.
Drop last_clipboard_text and related code, keep track of
ownership via clipboard_owner instead. Drop old #if0
sections.
ownership via clipboard_owner instead. Drop old #if0 sections.
(DEFAULT_LCID, ANSICP, OEMCP, QUNICODE, QANSICP, QOEMCP)
(clipboard_owner, modifying_clipboard, cfg_coding_system)
(cfg_codepage, cfg_lcid, cfg_clipboard_type, current_text)
(current_coding_system, current_requires_encoding)
(current_num_nls, current_clipboard_type, current_lcid): New
static variables.
(current_num_nls, current_clipboard_type, current_lcid):
New static variables.
(convert_to_handle_as_ascii, convert_to_handle_as_coded)
(render, render_all, run_protected, lisp_error_handler)
(owner_callback, create_owner, setup_config)
(enum_locale_callback, cp_from_locale, coding_from_cp): New
local functions.
(enum_locale_callback, cp_from_locale, coding_from_cp):
New local functions.
(term_w32select, globals_of_w32select): New global functions.
@ -332,8 +439,7 @@
(casify_region): Fix loop condition, args to replace_range_2, and
update opoint_byte.
* insdel.c (replace_range_2): Fix bugs in adjusting markers and
point.
* insdel.c (replace_range_2): Fix bugs in adjusting markers and point.
2005-02-01 Kim F. Storm <storm@cua.dk>
@ -761,7 +867,7 @@
[TARGET_API_MAC_CARBON] (mac_do_track_drag): Likewise.
Reject only when there are no filename items. Set background color
before (un)highlighting the window below the dragged items.
(XTread_socket) [!USE_CARBON_EVENTS]: Don't call do_window_update.
(XTread_socket) [USE_CARBON_EVENTS]: Don't call do_window_update.
2005-01-05 Romain Francoise <romain@orebokech.com>
@ -11015,9 +11121,9 @@
These changes were in part based upon suggestions made by Peter
'Luna' Runestig [peter@runestig.com].
* w32.c (g_b_init_is_windows_9x, g_b_init_open_process_token,
g_b_init_get_token_information, g_b_init_lookup_account_sid,
g_b_init_get_sid_identifier_authority ): Add several static
* w32.c (g_b_init_is_windows_9x, g_b_init_open_process_token)
(g_b_init_get_token_information, g_b_init_lookup_account_sid)
(g_b_init_get_sid_identifier_authority ): Add several static
global variables.
* w32.c (globals_of_w32): New function. Used to initialize those

View File

@ -119,6 +119,13 @@ enum window_part
#define GLYPH_DEBUG 0
#endif
/* If XASSERTS is non-zero, additional consistency checks are activated.
Turn it off by defining the macro XASSERTS to zero. */
#ifndef XASSERTS
#define XASSERTS 0
#endif
/* Macros to include code only if GLYPH_DEBUG != 0. */
#if GLYPH_DEBUG
@ -127,8 +134,11 @@ enum window_part
#define IF_DEBUG(X) (void) 0
#endif
/* Maybe move this inside the above `#ifdef GLYPH_DEBUG' for release. */
#if XASSERTS
#define xassert(X) do {if (!(X)) abort ();} while (0)
#else
#define xassert(X) (void) 0
#endif
/* Macro for displaying traces of redisplay. If Emacs was compiled
with GLYPH_DEBUG != 0, the variable trace_redisplay_p can be set to

View File

@ -58,26 +58,24 @@ static Lisp_Object Vbuild_files;
extern Lisp_Object Voverriding_local_map;
/* For VMS versions with limited file name syntax,
convert the name to something VMS will allow. */
convert the name to something VMS will allow. */
static void
munge_doc_file_name (name)
char *name;
{
#ifdef VMS
#ifndef VMS4_4
/* For VMS versions with limited file name syntax,
convert the name to something VMS will allow. */
p = name;
#ifndef NO_HYPHENS_IN_FILENAMES
extern char * sys_translate_unix (char *ufile);
strcpy (name, sys_translate_unix (name));
#else /* NO_HYPHENS_IN_FILENAMES */
char *p = name;
while (*p)
{
if (*p == '-')
*p = '_';
p++;
}
#endif /* not VMS4_4 */
#ifdef VMS4_4
strcpy (name, sys_translate_unix (name));
#endif /* VMS4_4 */
#endif /* NO_HYPHENS_IN_FILENAMES */
#endif /* VMS */
}
@ -607,21 +605,7 @@ the same file name is found in the `doc-directory'. */)
strcpy (name, SDATA (Vdoc_directory));
}
strcat (name, SDATA (filename)); /*** Add this line ***/
#ifdef VMS
#ifndef VMS4_4
/* For VMS versions with limited file name syntax,
convert the name to something VMS will allow. */
p = name;
while (*p)
{
if (*p == '-')
*p = '_';
p++;
}
#else /* VMS4_4 */
strcpy (name, sys_translate_unix (name));
#endif /* VMS4_4 */
#endif /* VMS */
munge_doc_file_name (name);
/* Vbuild_files is nil when temacs is run, and non-nil after that. */
if (NILP (Vbuild_files))

View File

@ -251,7 +251,7 @@ Run Emacs, the extensible, customizable, self-documenting real-time\n\
display editor. The recommended way to start Emacs for normal editing\n\
is with no options at all.\n\
\n\
Run M-x info RET m emacs RET m command arguments RET inside Emacs to\n\
Run M-x info RET m emacs RET m emacs invocation RET inside Emacs to\n\
read the main documentation for these command-line arguments.\n\
\n\
Initialization options:\n\
@ -297,7 +297,7 @@ Display options:\n\
--background-color, -bg COLOR window background color\n\
--border-color, -bd COLOR main border color\n\
--border-width, -bw WIDTH width of main border\n\
--color MODE color mode for character terminals;\n\
--color, --color=MODE color mode for character terminals;\n\
MODE defaults to `auto', and can also\n\
be `never', `auto', `always',\n\
or a mode name like `ansi8'\n\
@ -314,6 +314,7 @@ Display options:\n\
--line-spacing, -lsp PIXELS additional space to put between lines\n\
--mouse-color, -ms COLOR mouse cursor color in Emacs window\n\
--name NAME title for initial Emacs frame\n\
--no-blinking-cursor, -nbc disable blinking cursor\n\
--reverse-video, -r, -rv switch foreground and background\n\
--title, -T TITLE title for initial Emacs frame\n\
--vertical-scroll-bars, -vb enable vertical scroll bars\n\
@ -1483,7 +1484,7 @@ main (argc, argv
init_ntproc (); /* must precede init_editfns. */
#endif
#ifdef HAVE_CARBON
#if defined (MAC_OSX) && defined (HAVE_CARBON)
if (initialized)
init_mac_osx_environment ();
#endif
@ -1627,12 +1628,12 @@ main (argc, argv
syms_of_fontset ();
#endif /* HAVE_NTGUI */
#ifdef HAVE_CARBON
#if defined (MAC_OSX) && defined (HAVE_CARBON)
syms_of_macterm ();
syms_of_macfns ();
syms_of_macmenu ();
syms_of_fontset ();
#endif /* HAVE_CARBON */
#endif /* MAC_OSX && HAVE_CARBON */
#ifdef SYMS_SYSTEM
SYMS_SYSTEM;
@ -1824,6 +1825,7 @@ struct standard_args standard_args[] =
{ "-ib", "--internal-border", 10, 1 },
{ "-ms", "--mouse-color", 10, 1 },
{ "-cr", "--cursor-color", 10, 1 },
{ "-nbc", "--no-blinking-cursor", 10, 0 },
{ "-fn", "--font", 10, 1 },
{ "-font", 0, 10, 1 },
{ "-fs", "--fullscreen", 10, 0 },
@ -2052,14 +2054,9 @@ all of which are called before Emacs is actually killed. */)
if (STRINGP (Vauto_save_list_file_name))
unlink (SDATA (Vauto_save_list_file_name));
exit (INTEGERP (arg) ? XINT (arg)
#ifdef VMS
: 1
#else
: 0
#endif
);
exit (INTEGERP (arg) ? XINT (arg) : EXIT_SUCCESS);
/* NOTREACHED */
return 0;
}

View File

@ -150,6 +150,10 @@ extern int use_file_dialog;
# define lstat stat
#endif
#ifndef FILE_SYSTEM_CASE
#define FILE_SYSTEM_CASE(filename) (filename)
#endif
/* Nonzero during writing of auto-save files */
int auto_saving;
@ -415,9 +419,7 @@ on VMS, perhaps instead a string ending in `:', `]' or `>'. */)
if (!NILP (handler))
return call2 (handler, Qfile_name_directory, filename);
#ifdef FILE_SYSTEM_CASE
filename = FILE_SYSTEM_CASE (filename);
#endif
beg = SDATA (filename);
#ifdef DOS_NT
beg = strcpy (alloca (strlen (beg) + 1), beg);
@ -1122,14 +1124,7 @@ See also the function `substitute-in-file-name'. */)
UNGCPRO;
}
#ifdef VMS
/* Filenames on VMS are always upper case. */
name = Fupcase (name);
#endif
#ifdef FILE_SYSTEM_CASE
name = FILE_SYSTEM_CASE (name);
#endif
nm = SDATA (name);
#ifdef DOS_NT
@ -1229,23 +1224,23 @@ See also the function `substitute-in-file-name'. */)
slash = p;
}
if (p[0] == '-')
#ifndef VMS4_4
/* VMS pre V4.4,convert '-'s in filenames. */
#ifdef NO_HYPHENS_IN_FILENAMES
if (lbrack == rbrack)
{
if (dots < 2) /* this is to allow negative version numbers */
/* Avoid clobbering negative version numbers. */
if (dots < 2)
p[0] = '_';
}
else
#endif /* VMS4_4 */
#endif /* NO_HYPHENS_IN_FILENAMES */
if (lbrack > rbrack &&
((p[-1] == '.' || p[-1] == '[' || p[-1] == '<') &&
(p[1] == '.' || p[1] == ']' || p[1] == '>')))
lose = 1;
#ifndef VMS4_4
#ifdef NO_HYPHENS_IN_FILENAMES
else
p[0] = '_';
#endif /* VMS4_4 */
#endif /* NO_HYPHENS_IN_FILENAMES */
/* count open brackets, reset close bracket pointer */
if (p[0] == '[' || p[0] == '<')
lbrack++, brack = 0;
@ -1625,12 +1620,12 @@ See also the function `substitute-in-file-name'. */)
}
else
{
#ifndef VMS4_4
#ifdef NO_HYPHENS_IN_FILENAMES
if (*p == '-' &&
o[-1] != '[' && o[-1] != '<' && o[-1] != '.' &&
p[1] != ']' && p[1] != '>' && p[1] != '.')
*p = '_';
#endif /* VMS4_4 */
#endif /* NO_HYPHENS_IN_FILENAMES */
*o++ = *p++;
}
#else /* not VMS */
@ -6387,7 +6382,7 @@ and `read-file-name-function'. */)
{
Lisp_Object val1 = double_dollars (val);
tem = Fsymbol_value (Qfile_name_history);
if (history_delete_duplicates)
if (history_delete_duplicates)
XSETCDR (tem, Fdelete (val1, XCDR(tem)));
XSETCAR (tem, val1);
}

View File

@ -88,15 +88,19 @@ typedef struct w32_bitmap_record Bitmap_Record;
#include <alloca.h>
#include <sys/param.h>
#endif
#if TARGET_API_MAC_CARBON
#ifdef MAC_OSX
#include <QuickTime/QuickTime.h>
#else /* not MAC_OSX */
#else /* not MAC_OSX */
#include <QuickTime.h>
#endif /* not MAC_OSX */
#else /* not TARGET_API_MAC_CARBON */
#include <Windows.h>
#include <Gestalt.h>
#include <TextUtils.h>
#include <ImageCompression.h>
#include <QuickTimeComponents.h>
#endif /* not MAC_OSX */
#endif /* not TARGET_API_MAC_CARBON */
/* MAC_TODO : Color tables on Mac. */
#undef COLOR_TABLE_SUPPORT

View File

@ -1,6 +1,6 @@
/* Keyboard and mouse input; editor command loop.
Copyright (C) 1985,86,87,88,89,93,94,95,96,97,99,2000,01,02,03,04
Free Software Foundation, Inc.
Copyright (C) 1985, 1986, 1987, 1988, 1989, 1993, 1994, 1995, 1996, 1997,
1999, 2000, 2001, 2002, 2003, 2004, 2005 Free Software Foundation, Inc.
This file is part of GNU Emacs.
@ -10660,6 +10660,9 @@ The `posn-' functions access elements of such lists. */)
(x, y, frame_or_window, whole)
Lisp_Object x, y, frame_or_window, whole;
{
CHECK_NATNUM (x);
CHECK_NATNUM (y);
if (NILP (frame_or_window))
frame_or_window = selected_window;

View File

@ -25,20 +25,8 @@ Boston, MA 02111-1307, USA. */
#include <stdio.h>
#include <errno.h>
#include <time.h>
#include <utime.h>
#include <dirent.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <string.h>
#include <pwd.h>
#include <grp.h>
#include <sys/param.h>
#include <stdlib.h>
#include <fcntl.h>
#if __MWERKS__
#include <unistd.h>
#endif
#ifdef HAVE_CARBON
#ifdef MAC_OSX
#undef mktime
#undef DEBUG
@ -57,7 +45,12 @@ Boston, MA 02111-1307, USA. */
#define realloc unexec_realloc
#undef init_process
#define init_process emacs_init_process
#else /* not MAC_OSX */
#else /* not MAC_OSX */
#undef SIGHUP
#define OLDP2C 1
#include <Carbon.h>
#endif /* not MAC_OSX */
#else /* not HAVE_CARBON */
#include <Files.h>
#include <MacTypes.h>
#include <TextUtils.h>
@ -69,7 +62,24 @@ Boston, MA 02111-1307, USA. */
#include <OSA.h>
#include <AppleScript.h>
#include <Scrap.h>
#endif /* not MAC_OSX */
#include <Events.h>
#include <Processes.h>
#include <EPPC.h>
#endif /* not HAVE_CARBON */
#include <utime.h>
#include <dirent.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <string.h>
#include <pwd.h>
#include <grp.h>
#include <sys/param.h>
#include <stdlib.h>
#include <fcntl.h>
#if __MWERKS__
#include <unistd.h>
#endif
#include "lisp.h"
#include "process.h"
@ -812,8 +822,6 @@ sys_fopen (const char *name, const char *mode)
}
#include <Events.h>
long target_ticks = 0;
#ifdef __MRC__
@ -856,7 +864,24 @@ select (n, rfds, wfds, efds, timeout)
struct timeval *timeout;
{
#if TARGET_API_MAC_CARBON
return 1;
OSErr err;
EventTimeout timeout_sec =
(timeout
? (EMACS_SECS (*timeout) * kEventDurationSecond
+ EMACS_USECS (*timeout) * kEventDurationMicrosecond)
: kEventDurationForever);
if (FD_ISSET (0, rfds))
{
BLOCK_INPUT;
err = ReceiveNextEvent (0, NULL, timeout_sec, kEventLeaveInQueue, NULL);
UNBLOCK_INPUT;
if (err == noErr)
return 1;
else
FD_ZERO (rfds);
}
return 0;
#else /* not TARGET_API_MAC_CARBON */
EventRecord e;
UInt32 sleep_time = EMACS_SECS (*timeout) * 60 +
@ -1421,6 +1446,39 @@ path_from_vol_dir_name (char *path, int man_path_len, short vol_ref_num,
return 1; /* success */
}
OSErr
posix_pathname_to_fsspec (ufn, fs)
const char *ufn;
FSSpec *fs;
{
Str255 mac_pathname;
if (posix_to_mac_pathname (ufn, mac_pathname, sizeof (mac_pathname)) == 0)
return fnfErr;
else
{
c2pstr (mac_pathname);
return FSMakeFSSpec (0, 0, mac_pathname, fs);
}
}
OSErr
fsspec_to_posix_pathname (fs, ufn, ufnbuflen)
const FSSpec *fs;
char *ufn;
int ufnbuflen;
{
char mac_pathname[MAXPATHLEN];
if (path_from_vol_dir_name (mac_pathname, sizeof (mac_pathname) - 1,
fs->vRefNum, fs->parID, fs->name)
&& mac_to_posix_pathname (mac_pathname, ufn, ufnbuflen))
return noErr;
else
return fnfErr;
}
#ifndef MAC_OSX
int
@ -1899,9 +1957,6 @@ uname (struct utsname *name)
}
#include <Processes.h>
#include <EPPC.h>
/* Event class of HLE sent to subprocess. */
const OSType kEmacsSubprocessSend = 'ESND';
@ -2770,7 +2825,6 @@ and t is the same as `SECONDARY'. */)
return Qnil;
}
extern void mac_clear_font_name_table P_ ((void));
DEFUN ("mac-clear-font-name-table", Fmac_clear_font_name_table, Smac_clear_font_name_table, 0, 0, 0,
doc: /* Clear the font name table. */)

View File

@ -2294,8 +2294,6 @@ XParseGeometry (string, x, y, width, height)
/* Create and set up the Mac window for frame F. */
extern OSErr install_window_handler (WindowPtr);
static void
mac_window (f)
struct frame *f;
@ -4356,7 +4354,7 @@ If ONLY-DIR-P is non-nil, the user can only select directories. */)
options.actionButtonLabel = CFSTR ("Ok");
options.windowTitle = CFSTR ("Enter name");
if (!NILP(default_filename))
if (STRINGP (default_filename))
{
Lisp_Object utf8 = ENCODE_UTF_8 (default_filename);
char *begPtr = SDATA(utf8);
@ -4381,22 +4379,29 @@ If ONLY-DIR-P is non-nil, the user can only select directories. */)
}
/* Set the default location and continue*/
if (status == noErr) {
if (!NILP(dir)) {
FSRef defLoc;
if (status == noErr)
{
AEDesc defLocAed;
#ifdef MAC_OSX
FSRef defLoc;
status = FSPathMakeRef(SDATA(ENCODE_FILE(dir)), &defLoc, NULL);
#else
FSSpec defLoc;
status = posix_pathname_to_fsspec (SDATA (ENCODE_FILE (dir)), &defLoc);
#endif
if (status == noErr)
{
#ifdef MAC_OSX
AECreateDesc(typeFSRef, &defLoc, sizeof(FSRef), &defLocAed);
#else
AECreateDesc(typeFSS, &defLoc, sizeof(FSSpec), &defLocAed);
#endif
NavCustomControl(dialogRef, kNavCtlSetLocation, (void*) &defLocAed);
AEDisposeDesc(&defLocAed);
}
status = NavDialogRun(dialogRef);
}
status = NavDialogRun(dialogRef);
}
if (saveName) CFRelease(saveName);
if (message) CFRelease(message);
@ -4413,11 +4418,22 @@ If ONLY-DIR-P is non-nil, the user can only select directories. */)
{
NavReplyRecord reply;
AEDesc aed;
#ifdef MAC_OSX
FSRef fsRef;
#else
FSSpec fs;
#endif
status = NavDialogGetReply(dialogRef, &reply);
#ifdef MAC_OSX
AECoerceDesc(&reply.selection, typeFSRef, &aed);
AEGetDescData(&aed, (void *) &fsRef, sizeof (FSRef));
FSRefMakePath(&fsRef, (UInt8 *) filename, sizeof (filename));
#else
AECoerceDesc (&reply.selection, typeFSS, &aed);
AEGetDescData (&aed, (void *) &fs, sizeof (FSSpec));
fsspec_to_posix_pathname (&fs, filename, sizeof (filename) - 1);
#endif
AEDisposeDesc(&aed);
if (reply.saveFileName)
{

View File

@ -29,10 +29,11 @@ typedef char * XrmDatabase; /* fix later */
typedef unsigned long Time;
#if MAC_OSX
#ifdef HAVE_CARBON
#undef Z
#ifdef MAC_OSX
#undef mktime
#undef DEBUG
#undef Z
#undef free
#undef malloc
#undef realloc
@ -44,8 +45,6 @@ typedef unsigned long Time;
#include <Carbon/Carbon.h>
#undef mktime
#define mktime emacs_mktime
#undef Z
#define Z (current_buffer->text->z)
#undef free
#define free unexec_free
#undef malloc
@ -59,12 +58,19 @@ typedef unsigned long Time;
#undef init_process
#define init_process emacs_init_process
#undef INFINITY
#else
#else /* not MAC_OSX */
#undef SIGHUP
#define OLDP2C 1
#include <Carbon.h>
#endif /* not MAC_OSX */
#undef Z
#define Z (current_buffer->text->z)
#else /* not HAVE_CARBON */
#include <QuickDraw.h> /* for WindowPtr */
#include <QDOffscreen.h> /* for GWorldPtr */
#include <Windows.h>
#include <Gestalt.h>
#endif
#endif /* not HAVE_CARBON */
typedef WindowPtr Window;
typedef GWorldPtr Pixmap;

View File

@ -35,7 +35,7 @@ Boston, MA 02111-1307, USA. */
#include "charset.h"
#include "coding.h"
#ifndef MAC_OSX
#if !TARGET_API_MAC_CARBON
#include <MacTypes.h>
#include <Menus.h>
#include <QuickDraw.h>
@ -47,7 +47,7 @@ Boston, MA 02111-1307, USA. */
#if defined (__MRC__) || (__MSL__ >= 0x6000)
#include <ControlDefinitions.h>
#endif
#endif /* not MAC_OSX */
#endif /* not TARGET_API_MAC_CARBON */
/* This may include sys/types.h, and that somehow loses
if this is not done before the other system files. */

View File

@ -34,12 +34,12 @@ Boston, MA 02111-1307, USA. */
#include <alloca.h>
#endif
#ifdef MAC_OSX
#if TARGET_API_MAC_CARBON
/* USE_CARBON_EVENTS determines if the Carbon Event Manager is used to
obtain events from the event queue. If set to 0, WaitNextEvent is
used instead. */
#define USE_CARBON_EVENTS 1
#else /* not MAC_OSX */
#else /* not TARGET_API_MAC_CARBON */
#include <Quickdraw.h>
#include <ToolUtils.h>
#include <Sound.h>
@ -58,7 +58,7 @@ Boston, MA 02111-1307, USA. */
#if __profile__
#include <profiler.h>
#endif
#endif /* not MAC_OSX */
#endif /* not TARGET_API_MAC_CARBON */
#include "systty.h"
#include "systime.h"
@ -245,7 +245,7 @@ extern XrmDatabase x_load_resources P_ ((Display *, char *, char *, char *));
extern int inhibit_window_system;
#if __MRC__
#if __MRC__ && !TARGET_API_MAC_CARBON
QDGlobals qd; /* QuickDraw global information structure. */
#endif
@ -5574,6 +5574,9 @@ x_free_frame_resources (f)
BLOCK_INPUT;
if (wp != tip_window)
remove_window_handler (wp);
DisposeWindow (wp);
if (wp == tip_window)
/* Neither WaitNextEvent nor ReceiveNextEvent receives `window
@ -7078,7 +7081,7 @@ x_find_ccl_program (fontp)
/* The Mac Event loop code */
#ifndef MAC_OSX
#if !TARGET_API_MAC_CARBON
#include <Events.h>
#include <Quickdraw.h>
#include <Balloons.h>
@ -7099,7 +7102,7 @@ x_find_ccl_program (fontp)
#if __MWERKS__
#include <unix.h>
#endif
#endif /* ! MAC_OSX */
#endif /* ! TARGET_API_MAC_CARBON */
#define M_APPLE 128
#define I_ABOUT 1
@ -7200,12 +7203,16 @@ static pascal OSErr do_ae_quit_application (AppleEvent *, AppleEvent *, long);
/* Drag and Drop */
static pascal OSErr mac_do_track_drag (DragTrackingMessage, WindowPtr, void*, DragReference);
static pascal OSErr mac_do_receive_drag (WindowPtr, void*, DragReference);
static DragTrackingHandlerUPP mac_do_track_dragUPP = NULL;
static DragReceiveHandlerUPP mac_do_receive_dragUPP = NULL;
#endif
#if USE_CARBON_EVENTS
#ifdef MAC_OSX
/* Preliminary Support for the OSX Services Menu */
static OSStatus mac_handle_service_event (EventHandlerCallRef,EventRef,void*);
static void init_service_handler ();
#endif
/* Window Event Handler */
static pascal OSStatus mac_handle_window_event (EventHandlerCallRef,
EventRef, void *);
@ -7844,7 +7851,7 @@ init_required_apple_events ()
}
#if USE_CARBON_EVENTS
#ifdef MAC_OSX
void
init_service_handler ()
{
@ -7940,7 +7947,7 @@ mac_handle_service_event (EventHandlerCallRef callRef,
}
return err;
}
#endif
static pascal OSStatus
mac_handle_window_event (next_handler, event, data)
@ -8037,14 +8044,30 @@ install_window_handler (window)
NULL, NULL);
#endif
#if TARGET_API_MAC_CARBON
if (mac_do_track_dragUPP == NULL)
mac_do_track_dragUPP = NewDragTrackingHandlerUPP (mac_do_track_drag);
if (mac_do_receive_dragUPP == NULL)
mac_do_receive_dragUPP = NewDragReceiveHandlerUPP (mac_do_receive_drag);
if (err == noErr)
err = InstallTrackingHandler (mac_do_track_drag, window, NULL);
err = InstallTrackingHandler (mac_do_track_dragUPP, window, NULL);
if (err == noErr)
err = InstallReceiveHandler (mac_do_receive_drag, window, NULL);
err = InstallReceiveHandler (mac_do_receive_dragUPP, window, NULL);
#endif
return err;
}
void
remove_window_handler (window)
WindowPtr window;
{
#if TARGET_API_MAC_CARBON
if (mac_do_track_dragUPP)
RemoveTrackingHandler (mac_do_track_dragUPP, window);
if (mac_do_receive_dragUPP)
RemoveReceiveHandler (mac_do_receive_dragUPP, window);
#endif
}
/* Open Application Apple Event */
static pascal OSErr
@ -8123,9 +8146,9 @@ do_ae_open_documents(AppleEvent *message, AppleEvent *reply, long refcon)
/* AE file list is one based so just use that for indexing here. */
for (i = 1; i <= num_files_to_open; i++)
{
char unix_path_name[MAXPATHLEN];
#ifdef MAC_OSX
FSRef fref;
char unix_path_name[MAXPATHLEN];
err = AEGetNthPtr (&the_desc, i, typeFSRef, &keyword,
&actual_type, &fref, sizeof (FSRef),
@ -8137,15 +8160,13 @@ do_ae_open_documents(AppleEvent *message, AppleEvent *reply, long refcon)
== noErr)
#else
FSSpec fs;
Str255 path_name, unix_path_name;
err = AEGetNthPtr(&the_desc, i, typeFSS, &keyword, &actual_type,
(Ptr) &fs, sizeof (fs), &actual_size);
if (err != noErr) continue;
if (path_from_vol_dir_name (path_name, 255, fs.vRefNum, fs.parID,
fs.name) &&
mac_to_posix_pathname (path_name, unix_path_name, 255))
if (fsspec_to_posix_pathname (&fs, unix_path_name,
sizeof (unix_path_name) - 1) == noErr)
#endif
/* x-dnd functions expect undecoded filenames. */
drag_and_drop_file_list =
@ -8264,10 +8285,9 @@ mac_do_receive_drag (WindowPtr window, void *handlerRefCon,
{
#ifdef MAC_OSX
FSRef fref;
char unix_path_name[MAXPATHLEN];
#else
Str255 path_name, unix_path_name;
#endif
char unix_path_name[MAXPATHLEN];
GetFlavorData (theDrag, theItem, flavorTypeHFS, &data, &size, 0L);
#ifdef MAC_OSX
/* Use Carbon routines, otherwise it converts the file name
@ -8275,9 +8295,8 @@ mac_do_receive_drag (WindowPtr window, void *handlerRefCon,
FSpMakeFSRef (&data.fileSpec, &fref);
if (! FSRefMakePath (&fref, unix_path_name, sizeof (unix_path_name)));
#else
if (path_from_vol_dir_name (path_name, 255, data.fileSpec.vRefNum,
data.fileSpec.parID, data.fileSpec.name) &&
mac_to_posix_pathname (path_name, unix_path_name, 255))
if (fsspec_to_posix_pathname (&data.fileSpec, unix_path_name,
sizeof (unix_path_name) - 1) == noErr)
#endif
/* x-dnd functions expect undecoded filenames. */
drag_and_drop_file_list =
@ -8374,7 +8393,7 @@ profiler_exit_proc ()
hints and prompts in the minibuffer after the user stops typing for
a wait, etc. */
#if !TARGET_API_MAC_CARBON
#ifdef MAC_OS8
#undef main
int
main (void)
@ -8956,7 +8975,7 @@ XTread_socket (sd, expected, hold_quit)
int keycode = (er.message & keyCodeMask) >> 8;
int xkeysym;
#if USE_CARBON_EVENTS
#if USE_CARBON_EVENTS && defined (MAC_OSX)
/* When using Carbon Events, we need to pass raw keyboard
events to the TSM ourselves. If TSM handles it, it
will pass back noErr, otherwise it will pass back
@ -9265,12 +9284,21 @@ make_mac_terminal_frame (struct frame *f)
f->output_data.mac->mouse_pixel = 0xff00ff;
f->output_data.mac->cursor_foreground_pixel = 0x0000ff;
#if TARGET_API_MAC_CARBON
f->output_data.mac->text_cursor = kThemeIBeamCursor;
f->output_data.mac->nontext_cursor = kThemeArrowCursor;
f->output_data.mac->modeline_cursor = kThemeArrowCursor;
f->output_data.mac->hand_cursor = kThemePointingHandCursor;
f->output_data.mac->hourglass_cursor = kThemeWatchCursor;
f->output_data.mac->horizontal_drag_cursor = kThemeResizeLeftRightCursor;
#else
f->output_data.mac->text_cursor = GetCursor (iBeamCursor);
f->output_data.mac->nontext_cursor = &arrow_cursor;
f->output_data.mac->modeline_cursor = &arrow_cursor;
f->output_data.mac->hand_cursor = &arrow_cursor;
f->output_data.mac->hourglass_cursor = GetCursor (watchCursor);
f->output_data.mac->horizontal_drag_cursor = &arrow_cursor;
#endif
FRAME_FONTSET (f) = -1;
f->output_data.mac->explicit_parent = 0;
@ -9806,7 +9834,7 @@ mac_initialize ()
#if TARGET_API_MAC_CARBON
init_required_apple_events ();
#if USE_CARBON_EVENTS
#if USE_CARBON_EVENTS && defined (MAC_OSX)
init_service_handler ();
init_quit_char_handler ();
@ -9814,8 +9842,10 @@ mac_initialize ()
DisableMenuCommand (NULL, kHICommandQuit);
#ifdef MAC_OSX
if (!inhibit_window_system)
MakeMeTheFrontProcess ();
#endif
#endif
UNBLOCK_INPUT;
}

View File

@ -604,10 +604,17 @@ extern void XSetWindowBackground P_ ((Display *, WindowPtr, unsigned long));
extern void mac_draw_line_to_pixmap P_ ((Display *, Pixmap, GC, int, int,
int, int));
extern void mac_unload_font P_ ((struct mac_display_info *, XFontStruct *));
extern OSErr install_window_handler P_ ((WindowPtr));
extern void remove_window_handler P_ ((WindowPtr));
#define FONT_TYPE_FOR_UNIBYTE(font, ch) 0
#define FONT_TYPE_FOR_MULTIBYTE(font, ch) 0
/* Defined in mac.c. */
extern OSErr posix_pathname_to_fsspec P_ ((const char *, FSSpec *));
extern OSErr fsspec_to_posix_pathname P_ ((const FSSpec *, char *, int));
extern void mac_clear_font_name_table P_ ((void));
#if TARGET_API_MAC_CARBON
extern CFStringRef cfstring_create_with_utf8_cstring P_ ((const char *));
#endif

View File

@ -109,6 +109,11 @@ Boston, MA 02111-1307, USA. */
your system and must be used only through an encapsulation
(Which you should place, by convention, in sysdep.c). */
/* In olden days, VMS filenames did not support hyphen (i.e., the "-"
character). You can #undef this in vmsX-Y.h for newer versions. */
#define NO_HYPHENS_IN_FILENAMES
/* Do you have the sharable library bug? If you link with a sharable
library that contains psects with the NOSHR attribute and also refer to
those psects in your program, the linker give you a private version of
@ -135,6 +140,10 @@ Boston, MA 02111-1307, USA. */
/* #define READ_SYSUAF */
/* Traditionally, filenames on VMS are always upper case. */
#define FILE_SYSTEM_CASE Fupcase
/* On VMS these have a different name */
#define index strchr

View File

@ -1,5 +1,7 @@
#include "vms.h"
#define VMS4_4
#undef NO_HYPHENS_IN_FILENAMES
/* arch-tag: 2e65c7ad-0d17-45a0-b4cb-3e76c72ea9d5
(do not change this comment) */

View File

@ -2,6 +2,8 @@
#define VMS5_5
#define VMS4_4
#undef NO_HYPHENS_IN_FILENAMES
/* The bug that SHARABLE_LIB_BUG fixes is gone in version 5.5 of VMS.
And defining it causes lossage because sys_errlist has a different
number of elements. */

View File

@ -5083,11 +5083,12 @@ get_next_display_element (it)
display. Then, set IT->dpvec to these glyphs. */
GLYPH g;
int ctl_len;
int face_id, lface_id;
int face_id, lface_id = 0 ;
GLYPH escape_glyph;
if (it->c < 128 && it->ctl_arrow_p)
{
g = '^'; /* default glyph for Control */
/* Set IT->ctl_chars[0] to the glyph for `^'. */
if (it->dp
&& INTEGERP (DISP_CTRL_GLYPH (it->dp))
@ -5095,19 +5096,18 @@ get_next_display_element (it)
{
g = XINT (DISP_CTRL_GLYPH (it->dp));
lface_id = FAST_GLYPH_FACE (g);
if (lface_id)
{
g = FAST_GLYPH_CHAR (g);
face_id = merge_faces (it->f, Qt, lface_id,
it->face_id);
}
}
if (lface_id)
{
g = FAST_GLYPH_CHAR (g);
face_id = merge_faces (it->f, Qt, lface_id,
it->face_id);
}
else
{
/* Merge the escape-glyph face into the current face. */
face_id = merge_faces (it->f, Qescape_glyph, 0,
it->face_id);
g = '^';
}
XSETINT (it->ctl_chars[0], g);
@ -5117,25 +5117,25 @@ get_next_display_element (it)
goto display_control;
}
escape_glyph = '\\'; /* default for Octal display */
if (it->dp
&& INTEGERP (DISP_ESCAPE_GLYPH (it->dp))
&& GLYPH_CHAR_VALID_P (XFASTINT (DISP_ESCAPE_GLYPH (it->dp))))
{
escape_glyph = XFASTINT (DISP_ESCAPE_GLYPH (it->dp));
lface_id = FAST_GLYPH_FACE (escape_glyph);
if (lface_id)
{
escape_glyph = FAST_GLYPH_CHAR (escape_glyph);
face_id = merge_faces (it->f, Qt, lface_id,
it->face_id);
}
}
if (lface_id)
{
escape_glyph = FAST_GLYPH_CHAR (escape_glyph);
face_id = merge_faces (it->f, Qt, lface_id,
it->face_id);
}
else
{
/* Merge the escape-glyph face into the current face. */
face_id = merge_faces (it->f, Qescape_glyph, 0,
it->face_id);
escape_glyph = '\\';
}
if (it->c == 0x8a0 || it->c == 0x8ad)
@ -12284,7 +12284,11 @@ redisplay_window (window, just_this_one_p)
{
init_iterator (&it, w, PT, PT_BYTE, NULL, DEFAULT_FACE_ID);
move_it_vertically_backward (&it, 0);
#if 0
/* I think this assert is bogus if buffer contains
invisible text or images. KFS. */
xassert (IT_CHARPOS (it) <= PT);
#endif
it.current_y = 0;
}