]> git.eshelyaron.com Git - emacs.git/log
emacs.git
13 years agoOverflow, signedness and related fixes for images.
Paul Eggert [Sun, 17 Jul 2011 00:34:43 +0000 (17:34 -0700)]
Overflow, signedness and related fixes for images.

* dispextern.h (struct it.stack[0].u.image.image_id)
(struct_it.image_id, struct image.id, struct image_cache.size)
(struct image_cache.used, struct image_cache.ref_count):
* gtkutil.c (update_frame_tool_bar):
* image.c (x_reference_bitmap, Fimage_size, Fimage_mask_p)
(Fimage_metadata, free_image_cache, clear_image_cache, lookup_image)
(cache_image, mark_image_cache, x_kill_gs_process, Flookup_image):
* nsmenu.m (update_frame_tool_bar):
* xdisp.c (calc_pixel_width_or_height):
* xfns.c (image_cache_refcount):
Image IDs are now ptrdiff_t, not int, to avoid arbitrary limits
on typical 64-bit hosts.

* image.c (RANGED_INTEGERP, TYPE_RANGED_INTEGERP): New macros.
(x_bitmap_pixmap, x_create_x_image_and_pixmap):
Omit unnecessary casts to int.
(parse_image_spec): Check that integers fall into 'int' range
when the callers expect that.
(image_ascent): Redo ascent calculation to avoid int overflow.
(clear_image_cache): Avoid overflow when sqrt (INT_MAX) < nimages.
(lookup_image): Remove unnecessary tests.
(xbm_image_p): Locals are now of int, not EMACS_INT,
since parse_image_check makes sure they fit into int.
(png_load, gif_load, svg_load_image):
Prefer int to unsigned where either will do.
(tiff_handler): New function, combining the cores of the
old tiff_error_handler and tiff_warning_handler.  This
function is rewritten to use vsnprintf and thereby avoid
stack buffer overflows.  It uses only the features of vsnprintf
that are common to both POSIX and native Microsoft.
(tiff_error_handler, tiff_warning_handler): Use it.
(tiff_load, gif_load, imagemagick_load_image):
Don't assume :index value fits in 'int'.
(gif_load): Omit unnecessary cast to double, and avoid double-rounding.
(imagemagick_load_image): Check that crop parameters fit into
the integer types that MagickCropImage accepts.  Don't assume
Vimagemagick_render_type has a nonnegative value.  Don't assume
size_t fits in 'long'.
(gs_load): Use printmax_t to print the widest integers possible.
Check for integer overflow when computing image height and width.

13 years ago* bidi.c: Integer size and overflow fixes.
Paul Eggert [Thu, 14 Jul 2011 21:57:00 +0000 (14:57 -0700)]
* bidi.c: Integer size and overflow fixes.

(bidi_cache_size, bidi_cache_idx, bidi_cache_last_idx)
(bidi_cache_start, bidi_cache_fetch_state, bidi_cache_search)
(bidi_cache_find_level_change, bidi_cache_ensure_space)
(bidi_cache_iterator_state, bidi_cache_find, bidi_cache_start_stack)
(bidi_find_other_level_edge):
Use ptrdiff_t instead of EMACS_INT where either will do.
This works better on 32-bit hosts configured --with-wide-int.
(bidi_cache_ensure_space): Check for size-calculation overflow.
Use % rather than repeated addition, for better worst-case speed.
Don't set bidi_cache_size until after xrealloc returns, because it
might not return.
(bidi_dump_cached_states): Use ptrdiff_t, not int, to avoid overflow.

13 years agoMerge from trunk.
Paul Eggert [Thu, 14 Jul 2011 21:46:32 +0000 (14:46 -0700)]
Merge from trunk.

13 years agoFix minor problems found by static checking.
Paul Eggert [Thu, 14 Jul 2011 21:43:31 +0000 (14:43 -0700)]
Fix minor problems found by static checking.

* bidi.c (bidi_cache_size): Now EMACS_INT, not size_t.
(elsz): Now a signed constant, not a size_t var.  We prefer signed
types to unsigned, to avoid integer comparison confusion.  Without
this change, GCC 4.6.1 with -Wunsafe-loop-optimizations complains
"cannot optimize loop, the loop counter may overflow", a symptom
of the confusion.

13 years ago* indent.c (Fvertical_motion): Mark locals as initialized.
Paul Eggert [Thu, 14 Jul 2011 21:35:23 +0000 (14:35 -0700)]
* indent.c (Fvertical_motion): Mark locals as initialized.

13 years ago* xdisp.c (reseat_to_string): Fix pointer signedness issue.
Paul Eggert [Thu, 14 Jul 2011 21:34:18 +0000 (14:34 -0700)]
* xdisp.c (reseat_to_string): Fix pointer signedness issue.

13 years agoMerge from trunk.
Paul Eggert [Thu, 14 Jul 2011 20:40:35 +0000 (13:40 -0700)]
Merge from trunk.

13 years ago* data.c (Fcdr, Fcar): Revert the last change, since it didn't really clarify much.
Lars Magne Ingebrigtsen [Thu, 14 Jul 2011 20:08:05 +0000 (22:08 +0200)]
* data.c (Fcdr, Fcar): Revert the last change, since it didn't really clarify much.

13 years agoMention `case-fold-search' in all the re_search_* functions
Lars Magne Ingebrigtsen [Thu, 14 Jul 2011 18:45:36 +0000 (20:45 +0200)]
Mention `case-fold-search' in all the re_search_* functions

Fixes: debbugs:8138
13 years agoManual fix for the dribble file
Lars Magne Ingebrigtsen [Thu, 14 Jul 2011 18:37:53 +0000 (20:37 +0200)]
Manual fix for the dribble file

* trouble.texi (Checklist): Use an `M-x' example instead of an
Emacs Lisp form to switch on the dribble file.

Fixes: debbugs:8056
13 years ago* keyboard.c (Fopen_dribble_file): Document when the file is closed.
Lars Magne Ingebrigtsen [Thu, 14 Jul 2011 18:34:54 +0000 (20:34 +0200)]
* keyboard.c (Fopen_dribble_file): Document when the file is closed.

Fixes: debbugs:8056
13 years ago* data.c (car, cdr): add functionality hints to documentation.
Adam Sjøgren [Thu, 14 Jul 2011 18:29:19 +0000 (20:29 +0200)]
* data.c (car, cdr): add functionality hints to documentation.

13 years ago* man.el (Man-fontify-manpage): Fix message when formatting the man page.
Lars Magne Ingebrigtsen [Thu, 14 Jul 2011 17:43:29 +0000 (19:43 +0200)]
* man.el (Man-fontify-manpage): Fix message when formatting the man page.

Fixes: debbugs:7929
13 years agoFix format conversion in bidi.c.
Eli Zaretskii [Thu, 14 Jul 2011 17:43:50 +0000 (20:43 +0300)]
Fix format conversion in bidi.c.

 src/bidi.c (bidi_dump_cached_states): Fix format of displaying
 bidi_cache_idx.

13 years agoOnly output the man page name on failures
Lars Magne Ingebrigtsen [Thu, 14 Jul 2011 17:39:00 +0000 (19:39 +0200)]
Only output the man page name on failures

* man.el (Man-bgproc-sentinel): Skip any arguments and only output
the man page name.

Fixes: debbugs:6935
13 years agoSupport bidi reordering of overlay and display strings.
Eli Zaretskii [Thu, 14 Jul 2011 17:28:42 +0000 (20:28 +0300)]
Support bidi reordering of overlay and display strings.
Fix bugs #7616, #8133, #8867.

 src/xdisp.c (compute_display_string_pos)
 (compute_display_string_end): Accept additional argument STRING.
 (init_iterator, reseat_1): Initialize bidi_it->string.s to NULL.
 (reseat_to_string): Initialize bidi_it->string.s and
 bidi_it->string.schars.
 (Fcurrent_bidi_paragraph_direction): Initialize itb.string.s to
 NULL (avoids a crash in bidi_paragraph_init).  Initialize
 itb.string.lstring.
 (init_iterator): Call bidi_init_it only of a valid
 buffer position was specified.  Initialize paragraph_embedding to
 L2R.
 (reseat_to_string): Initialize the bidi iterator.
 (display_string): If we need to ignore text properties of
 LISP_STRING, set IT->stop_charpos to IT->end_charpos.  (The
 original value of -1 will not work with bidi.)
 (compute_display_string_pos): First arg is now struct
 `text_pos *'; all callers changed.  Support display properties on
 Lisp strings.
 (compute_display_string_end): Support display properties on Lisp
 strings.
 (init_iterator, reseat_1, reseat_to_string): Initialize the
 string.bufpos member to 0 (zero, for compatibility with IT_CHARPOS
 when iterating on a string not from display properties).
 (compute_display_string_pos, compute_display_string_end): Fix
 calculation of the object to scan.  Fixes an error when using
 arrow keys.
 (next_element_from_buffer): Don't abort when IT_CHARPOS is before
 base_level_stop; instead, set base_level_stop to BEGV.  Fixes
 crashes in vertical-motion.
 (next_element_from_buffer): Improve commentary for when
 the iterator is before prev_stop.
 (init_iterator): Initialize bidi_p from the default value of
 bidi-display-reordering, not from buffer-local value.  Use the
 buffer-local value only if initializing for buffer iteration.
 (handle_invisible_prop): Support invisible properties on strings
 that are being bidi-reordered.
 (set_iterator_to_next): Support bidi reordering of C strings and
 Lisp strings.
 (next_element_from_string): Support bidi reordering of Lisp
 strings.
 (handle_stop_backwards): Support Lisp strings as well.
 (display_string): Support display of R2L glyph rows.  Use
 IT_STRING_CHARPOS when displaying from a Lisp string.
 (init_iterator): Don't initialize it->bidi_p for strings
 here.
 (reseat_to_string): Initialize it->bidi_p for strings here.
 (next_element_from_string, next_element_from_c_string)
 (next_element_from_buffer): Add xassert's for correspondence
 between IT's object being iterated and it->bidi_it.string
 structure.
 (face_before_or_after_it_pos): Support bidi iteration.
 (next_element_from_c_string): Handle the case of the first string
 character that is not the first one in the visual order.
 (get_visually_first_element): New function, refactored from common
 parts of next_element_from_buffer, next_element_from_string, and
 next_element_from_c_string.
 (tool_bar_lines_needed, redisplay_tool_bar)
 (display_menu_bar): Force left-to-right direction.  Add a FIXME
 comment for making that be controlled by a user option.
 (push_it, pop_it): Save and restore the state of the
 bidi iterator.  Save and restore the bidi_p flag.
 (pop_it): Iterate out of display property for string iteration as
 well.
 (iterate_out_of_display_property): Support iteration over strings.
 (handle_single_display_spec): Set up it->bidi_it for iteration
 over a display string, and call bidi_init_it.
 (handle_single_display_spec, next_overlay_string)
 (get_overlay_strings_1, push_display_prop): Set up the bidi
 iterator for displaying display or overlay strings.
 (forward_to_next_line_start): Don't use the shortcut if
 bidi-iterating.
 (back_to_previous_visible_line_start): If handle_display_prop
 pushed the iterator stack, restore the internal state of the bidi
 iterator by calling bidi_pop_it same number of times.
 (reseat_at_next_visible_line_start): If ON_NEWLINE_P is non-zero,
 and we are bidi-iterating, don't decrement the iterator position;
 instead, set the first_elt flag in the bidi iterator, to produce
 the same effect.
 (reseat_1): Remove redundant setting of string_from_display_prop_p.
 (push_display_prop): xassert that we are iterating a buffer.
 (push_it, pop_it): Save and restore paragraph_embedding member.
 (handle_single_display_spec, next_overlay_string)
 (get_overlay_strings_1, reseat_1, reseat_to_string)
 (push_display_prop): Set up the `unibyte' member of bidi_it.string
 correctly.  Don't assume unibyte strings are not bidi-reordered.
 (compute_display_string_pos)
 (compute_display_string_end): Fix handling the case of C string.
 (push_it, pop_it): Save and restore from_disp_prop_p.
 (handle_single_display_spec, push_display_prop): Set the
 from_disp_prop_p flag.
 (get_overlay_strings_1): Reset the from_disp_prop_p flag.
 (pop_it): Call iterate_out_of_display_property only if we are
 popping after iteration over a string that came from a display
 property.  Fix a typo in popping stretch info.  Add an assertion
 for verifying that the iterator position is in sync with the bidi
 iterator.
 (handle_single_display_spec, get_overlay_strings_1)
 (push_display_prop): Fix initialization of paragraph direction for
 string when that of the parent object is not yet determined.
 (reseat_1): Call bidi_init_it to resync the bidi
 iterator with IT's position.  (Bug#7616)
 (find_row_edges): If ROW->start.pos gives position
 smaller than min_pos, use it as ROW->minpos.  (Bug#7616)
 (handle_stop, back_to_previous_visible_line_start, reseat_1):
 Reset the from_disp_prop_p flag.
 (SAVE_IT, RESTORE_IT): New macros.
 (pos_visible_p, face_before_or_after_it_pos)
 (back_to_previous_visible_line_start)
 (move_it_in_display_line_to, move_it_in_display_line)
 (move_it_to, move_it_vertically_backward, move_it_by_lines)
 (try_scrolling, redisplay_window, display_line): Use them when
 saving a temporary copy of the iterator and restoring it back.
 (back_to_previous_visible_line_start, reseat_1)
 (init_iterator): Empty the bidi cache "stack".
 (move_it_in_display_line_to): If iterator ended up at
 EOL, but we never saw any buffer positions smaller than
 to_charpos, return MOVE_POS_MATCH_OR_ZV.  Fixes vertical cursor
 motion in bidi-reordered lines.
 (move_it_in_display_line_to): Record prev_method and prev_pos
 immediately before the call to set_iterator_to_next.  Fixes cursor
 motion in bidi-reordered lines with stretch glyphs and strings
 displayed in margins.  (Bug#8133) (Bug#8867)
 Return MOVE_POS_MATCH_OR_ZV only if iterator position is past
 TO_CHARPOS.
 (pos_visible_p): Support positions in bidi-reordered lines.  Save
 and restore bidi cache.
 src/bidi.c (bidi_level_of_next_char): clen should be EMACS_NT, not int.
 (bidi_paragraph_info): Delete unused struct.
 (bidi_cache_idx, bidi_cache_last_idx): Declare EMACS_INT.
 (bidi_cache_start): New variable.
 (bidi_cache_reset): Reset bidi_cache_idx to bidi_cache_start, not
 to zero.
 (bidi_cache_fetch_state, bidi_cache_search)
 (bidi_cache_find_level_change, bidi_cache_iterator_state)
 (bidi_cache_find, bidi_peek_at_next_level)
 (bidi_level_of_next_char, bidi_find_other_level_edge)
 (bidi_move_to_visually_next): Compare cache index with
 bidi_cache_start rather than with zero.
 (bidi_fetch_char): Accept new argument STRING; all callers
 changed.  Support iteration over a string.  Support strings with
 display properties.  Support unibyte strings.  Fix the type of
 `len' according to what STRING_CHAR_AND_LENGTH expects.
 (bidi_paragraph_init, bidi_resolve_explicit_1)
 (bidi_resolve_explicit, bidi_resolve_weak)
 (bidi_level_of_next_char, bidi_move_to_visually_next): Support
 iteration over a string.
 (bidi_set_sor_type, bidi_resolve_explicit_1)
 (bidi_resolve_explicit, bidi_type_of_next_char): ignore_bn_limit
 can now be zero (for strings); special values 0 and -1 were
 changed to -1 and -2, respectively.
 (bidi_char_at_pos): New function.
 (bidi_paragraph_init, bidi_resolve_explicit, bidi_resolve_weak):
 Call it instead of FETCH_MULTIBYTE_CHAR.
 (bidi_move_to_visually_next): Abort if charpos or bytepos were not
 initialized to valid values.
 (bidi_init_it): Don't initialize charpos and bytepos with invalid
 values.
 (bidi_level_of_next_char): Allow the sentinel "position" to pass
 the test for valid cached positions.  Fix the logic for looking up
 the sentinel state in the cache.  GCPRO the Lisp string we are
 iterating.
 (bidi_push_it, bidi_pop_it): New functions.
 (bidi_initialize): Initialize the bidi cache start stack pointer.
 (bidi_cache_ensure_space): New function, refactored from part of
 bidi_cache_iterator_state.  Don't assume the required size is just
 one BIDI_CACHE_CHUNK away.
 (bidi_cache_start_stack, bidi_push_it): Use IT_STACK_SIZE.
 (bidi_count_bytes, bidi_char_at_pos): New functions.
 (bidi_cache_search): Don't assume bidi_cache_last_idx is
 always valid if bidi_cache_idx is valid.
 (bidi_cache_find_level_change): xassert that bidi_cache_last_idx
 is valid if it's going to be used.
 (bidi_shelve_cache, bidi_unshelve_cache): New functions.
 (bidi_cache_fetch_state, bidi_cache_search)
 (bidi_cache_find_level_change, bidi_cache_ensure_space)
 (bidi_cache_iterator_state, bidi_cache_find)
 (bidi_find_other_level_edge, bidi_cache_start_stack): All
 variables related to cache indices are now EMACS_INT.
 src/dispextern.h (struct bidi_string_data): New structure.
 (struct bidi_it): New member `string'.  Make flag members be 1-bit
 fields, and put them last in the struct.
 (compute_display_string_pos, compute_display_string_end): Update
 prototypes.
 (bidi_push_it, bidi_pop_it): Add prototypes.
 (struct iterator_stack_entry): New members bidi_p,
 paragraph_embedding, and from_disp_prop_p.
 (struct it): Member bidi_p is now a bit field 1 bit wide.
 (bidi_shelve_cache, bidi_unshelve_cache): Declare
 prototypes.
 src/.gdbinit (xvectype, xvector, xcompiled, xchartable, xboolvector)
 (xpr, xfont, xbacktrace): Use "header.size" when accessing vectors
 and vector-like objects.
 src/dispnew.c (buffer_posn_from_coords): Save and restore the bidi
 cache around display iteration.
 src/window.c (Fwindow_end, window_scroll_pixel_based)
 (displayed_window_lines, Frecenter): Save and restore the bidi
 cache around display iteration.
 lisp/buff-menu.el (Buffer-menu-buffer+size): Accept an additional
 argument LRM; if non-nil, append an invisible LRM character to the
 buffer name.
 (list-buffers-noselect): Call Buffer-menu-buffer+size with the
 last argument non-nil, when formatting buffer names.
 (Buffer-menu-mode, list-buffers-noselect): Force left-to-right
 paragraph direction.
 doc/lispref/display.texi (Other Display Specs): Document that `left-fringe'
 and `right-fringe' display specifications are of the "replacing"
 kind.

13 years ago`put-image' doc fix
Lars Magne Ingebrigtsen [Thu, 14 Jul 2011 17:20:37 +0000 (19:20 +0200)]
`put-image' doc fix

* image.el (put-image): Mention the `put-image' overlay property
(bug#7834).

13 years ago`set-scroll-bar-mode' doc clarification
Lars Magne Ingebrigtsen [Thu, 14 Jul 2011 17:11:49 +0000 (19:11 +0200)]
`set-scroll-bar-mode' doc clarification

* scroll-bar.el (set-scroll-bar-mode): Mention that
`scroll-bar-mode' lists the values (bug#7772).

13 years ago`image-mode-fit-frame' doc fix
Lars Magne Ingebrigtsen [Thu, 14 Jul 2011 17:05:43 +0000 (19:05 +0200)]
`image-mode-fit-frame' doc fix

* image-mode.el (image-mode-fit-frame): Mention that it's a toggle
command

Fixes: debbugs:7729
13 years agoFix declarations of variables related to bidi cache indices.
Eli Zaretskii [Thu, 14 Jul 2011 16:25:15 +0000 (19:25 +0300)]
Fix declarations of variables related to bidi cache indices.

 src/bidi.c (bidi_cache_fetch_state, bidi_cache_search)
 (bidi_cache_find_level_change, bidi_cache_ensure_space)
 (bidi_cache_iterator_state, bidi_cache_find)
 (bidi_find_other_level_edge, bidi_cache_start_stack): All
 variables related to cache indices are now EMACS_INT.

13 years ago* src/bidi.c: Hold off on these changes for now.
Paul Eggert [Thu, 14 Jul 2011 16:20:47 +0000 (09:20 -0700)]
* src/bidi.c: Hold off on these changes for now.

See <http://debbugs.gnu.org/cgi/bugreport.cgi?bug=9079#11>.

13 years agoMerge from trunk.
Paul Eggert [Thu, 14 Jul 2011 16:18:31 +0000 (09:18 -0700)]
Merge from trunk.

13 years ago* alloc.c (__malloc_size_t): Remove.
Paul Eggert [Thu, 14 Jul 2011 16:07:02 +0000 (09:07 -0700)]
* alloc.c (__malloc_size_t): Remove.

All uses replaced by size_t.  See Andreas Schwab's note
<http://debbugs.gnu.org/cgi/bugreport.cgi?bug=9079#8>.

13 years agoLeave point at the end of the rectangle after replacing text
Lars Magne Ingebrigtsen [Thu, 14 Jul 2011 15:23:08 +0000 (17:23 +0200)]
Leave point at the end of the rectangle after replacing text

* rect.el (apply-on-rectangle): Return the point after the last
operation.
(string-rectangle): Go to the point after the last operation
(bug#7522).

13 years ago`current-kill' doc clarification
Lars Magne Ingebrigtsen [Thu, 14 Jul 2011 15:05:08 +0000 (17:05 +0200)]
`current-kill' doc clarification

* simple.el (current-kill): Clarify what
`interprogram-paste-function' does (bug#7500).

13 years agopr-toggle-region doc clarification
Lars Magne Ingebrigtsen [Thu, 14 Jul 2011 14:54:32 +0000 (16:54 +0200)]
pr-toggle-region doc clarification

* printing.el (pr-toggle-region): Clarify the documentation
slightly (bug#7493).

13 years agoAllow display-time-mail-function to return nil
Lars Magne Ingebrigtsen [Thu, 14 Jul 2011 14:30:35 +0000 (16:30 +0200)]
Allow display-time-mail-function to return nil

* time.el (display-time-update): Allow
`display-time-mail-function' to return nil (bug#7158).  Fix
suggested by Detlev Zundel.

13 years agoMerge changes made in Gnus trunk.
Andrew Cohen [Thu, 14 Jul 2011 14:19:53 +0000 (14:19 +0000)]
Merge changes made in Gnus trunk.

nnimap.el (nnimap-request-thread): Ensure search is performed in correct group.
gnus-int.el (gnus-request-thread): Add group argument.
gnus-sum.el (gnus-request-thread): Use it.

13 years ago`diff' doc clarification
Lars Magne Ingebrigtsen [Thu, 14 Jul 2011 14:15:06 +0000 (16:15 +0200)]
`diff' doc clarification

* vc/diff.el (diff): Clarify the order the file names are read
(bug#7111).

13 years agoManual for for widget-keymap
Lars Magne Ingebrigtsen [Thu, 14 Jul 2011 14:10:51 +0000 (16:10 +0200)]
Manual for for widget-keymap

* widget.texi (Setting Up the Buffer): Remove mention of the
global keymap parent, which doesn't seem to be accurate
(bug#7045).

13 years agomouse-set-region doc fix
Lars Magne Ingebrigtsen [Thu, 14 Jul 2011 14:01:16 +0000 (16:01 +0200)]
mouse-set-region doc fix

* mouse.el (mouse-set-region): Link to `mouse-drag-copy-region' in
the doc string (bug#7015).

13 years ago* font-lock.el (font-lock-maximum-decoration): Mention what numeric levels mean.
Lars Magne Ingebrigtsen [Thu, 14 Jul 2011 13:50:25 +0000 (15:50 +0200)]
* font-lock.el (font-lock-maximum-decoration): Mention what numeric levels mean.

Fixes: debbugs:6935
13 years agoMention that `delete-region' doesn't alter the kill ring.
Lars Magne Ingebrigtsen [Thu, 14 Jul 2011 13:40:24 +0000 (15:40 +0200)]
Mention that `delete-region' doesn't alter the kill ring.

13 years ago* editfns.c (Fdelete_region): Clarify the use of the named parameters.
Lars Magne Ingebrigtsen [Thu, 14 Jul 2011 13:37:20 +0000 (15:37 +0200)]
* editfns.c (Fdelete_region): Clarify the use of the named parameters.

Fixes: debbugs:6788
13 years ago(initial-buffer-choice): Don't mention the `none' selection, which is against policy.
Lars Magne Ingebrigtsen [Thu, 14 Jul 2011 12:57:06 +0000 (14:57 +0200)]
(initial-buffer-choice): Don't mention the `none' selection, which is against policy.

13 years agoAuto-commit of generated files.
Glenn Morris [Thu, 14 Jul 2011 10:19:36 +0000 (06:19 -0400)]
Auto-commit of generated files.

13 years agoFix bugs in vertical-motion and display-buffer-normalize-special.
Martin Rudalics [Thu, 14 Jul 2011 08:30:34 +0000 (10:30 +0200)]
Fix bugs in vertical-motion and display-buffer-normalize-special.

* indent.c (Fvertical_motion): Set and restore w->pointm when
saving and restoring the window's buffer (Bug#9006).

* window.el (display-buffer-normalize-special): Replace
`dedicated' by `dedicate' to dedicate window (Bug#9072).

13 years agoAdd Bug#.
Paul Eggert [Thu, 14 Jul 2011 08:05:10 +0000 (01:05 -0700)]
Add Bug#.

13 years agolisp/subr.el (version-*): Doc fix.
Eli Zaretskii [Thu, 14 Jul 2011 06:50:21 +0000 (02:50 -0400)]
lisp/subr.el (version-*): Doc fix.

 lisp/subr.el (version<, version<=, version=): Mention "-CVS" and
 "-12345" alpha version numbers.

13 years agoMerge from trunk.
Paul Eggert [Thu, 14 Jul 2011 06:41:47 +0000 (23:41 -0700)]
Merge from trunk.

13 years ago* image.c: Improve checking for integer overflow.
Paul Eggert [Thu, 14 Jul 2011 06:20:53 +0000 (23:20 -0700)]
* image.c: Improve checking for integer overflow.

(check_image_size): Assume that f is nonnull, since
it is always nonnull in practice.  This is one less thing to
worry about when checking for integer overflow later.
(x_check_image_size): New function, which checks for integer
overflow issues inside X.
(x_create_x_image_and_pixmap, xbm_read_bitmap_data): Use it.
This removes the need for a memory_full check.
(xbm_image_p): Rewrite to avoid integer multiplication overflow.
(Create_Pixmap_From_Bitmap_Data, xbm_load): Use x_check_image_size.
(xbm_read_bitmap_data): Change locals back to 'int', since
their values must fit in 'int'.
(xpm_load_image, png_load, tiff_load):
Invoke x_create_x_image_and_pixmap earlier,
to avoid much needless work if the image is too large.
(tiff_load): Treat overly large images as if
x_create_x_image_and_pixmap failed, not as malloc failures.
(gs_load): Use x_check_image_size.

13 years ago* bindings.el: Add advertised binding for set-mark-command (Bug#5772).
Chong Yidong [Thu, 14 Jul 2011 01:58:51 +0000 (21:58 -0400)]
* bindings.el: Add advertised binding for set-mark-command (Bug#5772).

13 years agoAdapt 2011-07-05 switch-to-buffer changes to new switch-to-buffer
Chong Yidong [Thu, 14 Jul 2011 01:40:30 +0000 (21:40 -0400)]
Adapt 2011-07-05 switch-to-buffer changes to new switch-to-buffer

* lisp/bindings.el (mode-line-other-buffer):
* lisp/bookmark.el (bookmark-bmenu-2-window):
* lisp/bs.el (bs-cycle-next, bs-cycle-previous):
* lisp/net/tramp-cmds.el (tramp-append-tramp-buffers): Revert to using
switch-to-buffer.

* lisp/net/tramp-compat.el (tramp-compat-pop-to-buffer-same-window):
Deleted.

13 years agoFix typos.
Juanma Barranquero [Thu, 14 Jul 2011 01:09:00 +0000 (03:09 +0200)]
Fix typos.

13 years ago* cl.texi (For Clauses): Add destructuring example processing an
Kevin Ryde [Thu, 14 Jul 2011 00:14:35 +0000 (02:14 +0200)]
* cl.texi (For Clauses): Add destructuring example processing an
alist.

13 years ago(Documentation Basics): Add a link to the Function Documentation node.
Lars Magne Ingebrigtsen [Thu, 14 Jul 2011 00:02:09 +0000 (02:02 +0200)]
(Documentation Basics): Add a link to the Function Documentation node.

Fixes: debbugs:6580
13 years agoFstring_to_char doc clarification
Lars Magne Ingebrigtsen [Wed, 13 Jul 2011 23:48:35 +0000 (01:48 +0200)]
Fstring_to_char doc clarification

* editfns.c (Fstring_to_char): Clarify just what is returned
(bug#6576).  Text by Eli Zaretskii.

13 years agoDoc fix for with-silent-modifications
Lars Magne Ingebrigtsen [Wed, 13 Jul 2011 23:40:11 +0000 (01:40 +0200)]
Doc fix for with-silent-modifications

* subr.el (with-silent-modifications): Clarify somewhat what the
macro inhibits.

Fixes: debbugs:6525
13 years agoDoc fix for eval-expression
Lars Magne Ingebrigtsen [Wed, 13 Jul 2011 23:35:36 +0000 (01:35 +0200)]
Doc fix for eval-expression

* simple.el (eval-expression): Note what it does if called
interactively.

Fixes: debbugs:6495
13 years agoMention :visible menu bar separators
Lars Magne Ingebrigtsen [Wed, 13 Jul 2011 23:17:24 +0000 (01:17 +0200)]
Mention :visible menu bar separators

* keymaps.texi (Menu Bar): Mention :visible and :enable
(bug#6344).  Text by Drew Adams.

Fixes: debbugs:6334
13 years ago(make-directory): Clarify that an error will be raised if there's an error
Lars Magne Ingebrigtsen [Wed, 13 Jul 2011 22:22:08 +0000 (00:22 +0200)]
(make-directory): Clarify that an error will be raised if there's an error

Fixes: debbugs:6387
13 years agoAdd FORCE-SAME-WINDOW argument to switch-to-buffer.
Chong Yidong [Wed, 13 Jul 2011 22:00:48 +0000 (18:00 -0400)]
Add FORCE-SAME-WINDOW argument to switch-to-buffer.

* lisp/window.el (switch-to-buffer): New arg FORCE-SAME-WINDOW.  Use
pop-to-buffer buffer-or-name if it is nil.

* lisp/emacs-lisp/bytecomp.el (byte-compile-interactive-only-functions):
Remove switch-to-buffer.

13 years ago* startup.el (initial-buffer-choice): Add `none' as a choice
Lars Magne Ingebrigtsen [Wed, 13 Jul 2011 21:53:41 +0000 (23:53 +0200)]
* startup.el (initial-buffer-choice): Add `none' as a choice

Fixes: debbugs:6234
13 years ago* modes.texi (Running Hooks): Mention buffer-local hook variables
Lars Magne Ingebrigtsen [Wed, 13 Jul 2011 21:42:54 +0000 (23:42 +0200)]
* modes.texi (Running Hooks): Mention buffer-local hook variables

Fixes: debbugs:6218
13 years agoClarify manual and `add-hook' doc string about buffer-local hooks
Lars Magne Ingebrigtsen [Wed, 13 Jul 2011 21:38:56 +0000 (23:38 +0200)]
Clarify manual and `add-hook' doc string about buffer-local hooks

13 years ago* dired.el (dired-flagged): Clarify doc string.
Lars Magne Ingebrigtsen [Wed, 13 Jul 2011 21:27:13 +0000 (23:27 +0200)]
* dired.el (dired-flagged): Clarify doc string.

Fixes: debbugs:6117
13 years agosrc/gnutls.c (init_gnutls_functions): Honor gnutls_log_level (bug#9059).
Juanma Barranquero [Wed, 13 Jul 2011 20:33:44 +0000 (22:33 +0200)]
src/gnutls.c (init_gnutls_functions): Honor gnutls_log_level (bug#9059).

13 years agoPreserve point when doing untabify
Juanma Barranquero [Wed, 13 Jul 2011 18:12:05 +0000 (20:12 +0200)]
Preserve point when doing untabify

* tabify.el (untabify): Preserve the current column so that point
doesn't move.

Fixes: debbugs:6032
13 years ago* doc/emacs/dired.texi (Dired Enter): Mention --dired. (Bug#9039)
Glenn Morris [Wed, 13 Jul 2011 17:55:04 +0000 (13:55 -0400)]
* doc/emacs/dired.texi (Dired Enter): Mention --dired.  (Bug#9039)

13 years agoDoc string fix.
Lars Magne Ingebrigtsen [Wed, 13 Jul 2011 17:47:17 +0000 (19:47 +0200)]
Doc string fix.

* progmodes/cperl-mode.el (cperl-syntaxify-by-font-lock): Rewrite
to avoid awkward possessive "s".

Fixes: debbugs:5986
13 years agoSmall dired fixes related to bug#9039.
Glenn Morris [Wed, 13 Jul 2011 17:34:31 +0000 (13:34 -0400)]
Small dired fixes related to bug#9039.

* lisp/dired.el (dired-use-ls-dired): Doc fix.
(dired-insert-directory): Give a message the first time
if ls is found not to support --dired.

13 years agoClarify `mark-ring-max' documentation.
Lars Magne Ingebrigtsen [Wed, 13 Jul 2011 16:58:15 +0000 (18:58 +0200)]
Clarify `mark-ring-max' documentation.

* mark.texi (Mark Ring): Clarify how many locations are saved
(bug#5770).
(Global Mark Ring): Ditto.

13 years agoClarify doc string
Lars Magne Ingebrigtsen [Wed, 13 Jul 2011 16:39:49 +0000 (18:39 +0200)]
Clarify doc string

* simple.el (toggle-truncate-lines): Clarify what is toggled
(bug#5580).  Text by Drew Adams.

13 years ago* simple.el (blink-matching-open): Make error message from last change less verbose.
Chong Yidong [Wed, 13 Jul 2011 16:15:07 +0000 (12:15 -0400)]
* simple.el (blink-matching-open): Make error message from last change less verbose.

13 years ago* gtkutil.c: Omit integer casts.
Paul Eggert [Wed, 13 Jul 2011 15:42:12 +0000 (08:42 -0700)]
* gtkutil.c: Omit integer casts.

(xg_get_pixbuf_from_pixmap): Remove unnecessary cast.
(xg_set_toolkit_scroll_bar_thumb): Rewrite to avoid need for cast.

13 years agoUse "yellow" on low color terminals for comments
Dan Nicolaescu [Wed, 13 Jul 2011 15:33:08 +0000 (17:33 +0200)]
Use "yellow" on low color terminals for comments

* font-lock.el (font-lock-comment-face): Use the high contrast
"yellow" color for font-lock-comment-face on low color terminals
using a dark background color.

Fixes: debbugs:4221
13 years ago(dired-insert-set-properties): Make the doc string reflect what it does now
Lars Magne Ingebrigtsen [Wed, 13 Jul 2011 15:15:26 +0000 (17:15 +0200)]
(dired-insert-set-properties): Make the doc string reflect what it does now

Fixes: debbugs:5325
13 years ago(General Escape Syntax): "a with grave accent" is ?xe0, not ?x8e0.
Lars Magne Ingebrigtsen [Wed, 13 Jul 2011 15:07:57 +0000 (17:07 +0200)]
(General Escape Syntax): "a with grave accent" is ?xe0, not ?x8e0.

Fixes: debbugs:5259
13 years agoSay that we were unable to find the match within the limit
Lars Magne Ingebrigtsen [Wed, 13 Jul 2011 14:57:28 +0000 (16:57 +0200)]
Say that we were unable to find the match within the limit

* simple.el (blink-matching-open): Say that we were unable to find
the match within the limit, if we're limited (bug#5122).

13 years ago(prefer-coding-system): Add an example
Lars Magne Ingebrigtsen [Wed, 13 Jul 2011 14:34:10 +0000 (16:34 +0200)]
(prefer-coding-system): Add an example

Fixes: debbugs:4869
13 years ago(tags-search): Document `file-list-form'
Lars Magne Ingebrigtsen [Wed, 13 Jul 2011 14:20:45 +0000 (16:20 +0200)]
(tags-search): Document `file-list-form'

13 years agoCopy over `url-show-status' to the async buffer
Chris Newton [Wed, 13 Jul 2011 14:12:06 +0000 (16:12 +0200)]
Copy over `url-show-status' to the async buffer

* url-http.el (url-http): Copy over `url-show-status' to the async
buffer so that `url-display-percentage' does the right thing
(bug#4680).

13 years agoMake the default browser choice a bit more logical
Lawrence Mitchell [Wed, 13 Jul 2011 13:49:55 +0000 (15:49 +0200)]
Make the default browser choice a bit more logical

* net/browse-url.el (browse-url-default-browser)
(browse-url-browser-function): Make the default browser choice a
bit more logical.  Also clean up the doc string.

Fixes: debbugs:4300
13 years ago(completion-ignored-extensions): Add OpenMCL/Clozure binary endings.
Juanma Barranquero [Wed, 13 Jul 2011 13:39:23 +0000 (15:39 +0200)]
(completion-ignored-extensions): Add OpenMCL/Clozure binary endings.

Fixes: debbugs:4440
13 years ago(info-insert-file-contents): Inhibit jka-compr messages, which can be pretty annoying
Lars Magne Ingebrigtsen [Wed, 13 Jul 2011 13:35:02 +0000 (15:35 +0200)]
(info-insert-file-contents): Inhibit jka-compr messages, which can be pretty annoying

Fixes: debbugs:8971
13 years ago* jka-compr.el (jka-compr-verbose): New variable, and use throughout.
Lars Magne Ingebrigtsen [Wed, 13 Jul 2011 13:25:29 +0000 (15:25 +0200)]
* jka-compr.el (jka-compr-verbose): New variable, and use throughout.

Fixes: debbugs:8971
13 years ago(Info-find-file): Fall back on the installation directory if we can't find the info...
Lars Magne Ingebrigtsen [Wed, 13 Jul 2011 13:10:54 +0000 (15:10 +0200)]
(Info-find-file): Fall back on the installation directory if we can't find the info node anywhere else.

13 years ago* configure.in (GSETTINGS): Check for gio-2.0 >= 2.26.
Jan Djärv [Wed, 13 Jul 2011 10:36:12 +0000 (12:36 +0200)]
* configure.in (GSETTINGS): Check for gio-2.0 >= 2.26.

13 years ago* lisp/vc/vc.el (vc-revert-file): Don't set file time-stamp in the past.
Sergei Organov [Wed, 13 Jul 2011 07:58:34 +0000 (00:58 -0700)]
* lisp/vc/vc.el (vc-revert-file): Don't set file time-stamp in the past.

Fixes: debbugs:5181
13 years agosrc/buffer.c (mmap_find): Fix a typo.
Eli Zaretskii [Wed, 13 Jul 2011 04:09:28 +0000 (00:09 -0400)]
src/buffer.c (mmap_find): Fix a typo.

13 years agoMerge from trunk.
Paul Eggert [Wed, 13 Jul 2011 03:45:56 +0000 (20:45 -0700)]
Merge from trunk.

13 years ago* image.c (png_load): Don't assume height * row_bytes fits in 'int'.
Paul Eggert [Wed, 13 Jul 2011 03:42:26 +0000 (20:42 -0700)]
* image.c (png_load): Don't assume height * row_bytes fits in 'int'.

13 years agoFix execution of x selection hooks.
Johan Bockgård [Wed, 13 Jul 2011 01:48:43 +0000 (03:48 +0200)]
Fix execution of x selection hooks.
* xselect.c (Qx_lost_selection_functions)
(Qx_sent_selection_functions): New vars.
(syms_of_xselect): DEFSYM them.
(x_handle_selection_request): Pass Qx_sent_selection_functions
rather than Vx_sent_selection_functions to Frun_hook_with_args.
(x_handle_selection_clear,x_clear_frame_selections):
Pass Qx_lost_selection_functions rather than
Vx_lost_selection_functions to Frun_hook_with_args.

13 years ago* buffer.c (Fget_buffer_create): Initialized inhibit_shrinking.
Paul Eggert [Wed, 13 Jul 2011 01:15:33 +0000 (18:15 -0700)]
* buffer.c (Fget_buffer_create): Initialized inhibit_shrinking.

The old code sometimes used this field without initializing it.

13 years ago* alloc.c (gc_sweep): Don't read past end of array.
Paul Eggert [Wed, 13 Jul 2011 01:04:29 +0000 (18:04 -0700)]
* alloc.c (gc_sweep): Don't read past end of array.

In theory, the old code could also have corrupted Emacs internals,
though it'd be very unlikely.

13 years agoGive better error messages when trying to load non-existent symlinks
Lars Magne Ingebrigtsen [Tue, 12 Jul 2011 23:25:50 +0000 (01:25 +0200)]
Give better error messages when trying to load non-existent symlinks

* files.el (after-find-file): Give a better error message when
trying to find a symlink that points to a file that doesn't exist
(bug#4398).

13 years ago* progmodes/cc-vars.el: Remove (probably) misleading comment
Lars Magne Ingebrigtsen [Tue, 12 Jul 2011 23:19:33 +0000 (01:19 +0200)]
* progmodes/cc-vars.el: Remove (probably) misleading comment

13 years ago(Table Recognition): Use "at point" instead of "under point"
Lars Magne Ingebrigtsen [Tue, 12 Jul 2011 22:39:21 +0000 (00:39 +0200)]
(Table Recognition): Use "at point" instead of "under point"

Fixes: debbugs:4345
13 years agoManual fixes related to clarifying cursor shapes
Lars Magne Ingebrigtsen [Tue, 12 Jul 2011 22:37:20 +0000 (00:37 +0200)]
Manual fixes related to clarifying cursor shapes

Fixes: debbugs:4345
13 years agoMinor xref additions to Lisp manual.
Chong Yidong [Tue, 12 Jul 2011 22:09:28 +0000 (18:09 -0400)]
Minor xref additions to Lisp manual.

* doc/lispref/display.texi (Face Attributes, Font Selection): Add
references to the Fonts node in the Emacs manual.

Fixes: debbugs:4178
13 years ago* mouse-sel.el (mouse-sel-primary-overlay): Use the `region' face.
Johan Bockgård [Tue, 12 Jul 2011 21:59:09 +0000 (23:59 +0200)]
* mouse-sel.el (mouse-sel-primary-overlay): Use the `region' face.

13 years ago* src/character.c (Fcharacterp): Don't advertise optional ignored
Andreas Schwab [Tue, 12 Jul 2011 21:17:39 +0000 (23:17 +0200)]
* src/character.c (Fcharacterp): Don't advertise optional ignored
argument. (Bug#4026)

13 years ago(syms_of_keymap): Clarify that "modifier" is "modifier key"
Lars Magne Ingebrigtsen [Tue, 12 Jul 2011 21:12:36 +0000 (23:12 +0200)]
(syms_of_keymap): Clarify that "modifier" is "modifier key"

Fixes: debbugs:4257
13 years agowindow.c doc fixes.
Lars Magne Ingebrigtsen [Tue, 12 Jul 2011 21:09:01 +0000 (23:09 +0200)]
window.c doc fixes.

Fixes: debbugs:4199
13 years agoAdd Bug#2490 testcase to compilation.txt.
Chong Yidong [Tue, 12 Jul 2011 19:39:01 +0000 (15:39 -0400)]
Add Bug#2490 testcase to compilation.txt.

13 years agoAdapt Mouse Sel mode to Emacs 24 mouse code.
Chong Yidong [Tue, 12 Jul 2011 18:59:48 +0000 (14:59 -0400)]
Adapt Mouse Sel mode to Emacs 24 mouse code.

* lisp/mouse-sel.el: Hack restoring functionality, while keeping
compatibility with 2010-07-03 changes to mouse selection.
(mouse-sel-primary-overlay): New var.
(mouse-sel-selection-alist): Use it.
(mouse-sel-mode): Doc fix; remove points that are default features
of mouse.el.

13 years agoMerge from trunk.
Paul Eggert [Tue, 12 Jul 2011 17:38:05 +0000 (10:38 -0700)]
Merge from trunk.

13 years ago* bidi.c (bidi_dump_cached_states): Use pD to print ptrdiff_t.
Paul Eggert [Tue, 12 Jul 2011 17:35:56 +0000 (10:35 -0700)]
* bidi.c (bidi_dump_cached_states): Use pD to print ptrdiff_t.

13 years ago* xfaces.c (Fbitmap_spec_p): Fix integer overflow bug.
Paul Eggert [Tue, 12 Jul 2011 17:34:59 +0000 (10:34 -0700)]
* xfaces.c (Fbitmap_spec_p): Fix integer overflow bug.

Without this fix, (bitmap-spec-p '(34359738368 1 "x"))
would wrongly return t on a 64-bit host.

13 years agoRemove frame-local vars from Lisp manual; obsolete since Emacs 22.3.
Chong Yidong [Tue, 12 Jul 2011 17:33:18 +0000 (13:33 -0400)]
Remove frame-local vars from Lisp manual; obsolete since Emacs 22.3.

* display.texi (Window Systems): `window-system' is terminal-local.

* doc/lispref/frames.texi (Frame Parameters, Parameter Access): Don't mention
frame-local variables.

* doc/lispref/variables.texi (Buffer-Local Variables): Don't mention obsolete
frame-local variables.  (Frame-Local Variables): Node deleted.

* doc/lispref/elisp.texi (Top): Update node listing.