a2cfd3029f3755f4137b450815f14e86b762acd6
[bpt/emacs.git] / src / ChangeLog
1 2012-07-05 Dmitry Antipov <dmantipov@yandex.ru>
2
3 * marker.c (set_marker_restricted_both): Simplify by using
4 clip_to_bounds.
5
6 2012-07-05 Paul Eggert <eggert@cs.ucla.edu>
7
8 * editfns.c (region_limit): Simplify by using clip_to_bounds.
9
10 2012-07-05 Jan Djärv <jan.h.d@swipnet.se>
11
12 * gtkutil.c (gtk_scrollbar_new, gtk_box_new): Define when HAVE_GTK3 is
13 not defined (Bug#11768).
14 (xg_create_frame_widgets): Use gtk_plug_new_for_display (Bug#11768).
15 (xg_create_frame_widgets, create_dialog, xg_get_file_with_chooser)
16 (make_widget_for_menu_item, xg_make_tool_item): Use gtk_box_new
17 followed by gtk_box_set_homogeneous (Bug#11768).
18 (xg_update_menu_item): Use GTK_IS_BOX (Bug#11768).
19 (update_theme_scrollbar_width, xg_create_scroll_bar): Use
20 gtk_scrollbar_new (Bug#11768).
21 (xg_event_is_for_scrollbar): Use Gdk Device functions for HAVE_GTK3.
22 (is_box_type): New function (Bug#11768).
23 (xg_tool_item_stale_p): Call is_box_type.
24 (xg_initialize): Get settings by calling gtk_settings_get_for_screen
25 with default display (Bug#11768).
26
27 2012-07-05 Eli Zaretskii <eliz@gnu.org>
28
29 * xdisp.c (window_hscroll_limited): New function.
30 (pos_visible_p, init_iterator): Use it to avoid overflow of pixel
31 coordinates when window's hscroll is set to insanely large
32 values. (Bug#11857)
33
34 2012-07-05 Juanma Barranquero <lekktu@gmail.com>
35
36 * makefile.w32-in ($(BLD)/dired.$(O), $(BLD)/fileio.$(O)): Fix typo.
37 ($(BLD)/terminal.$(O), $(BLD)/syntax.$(O)): Update dependencies.
38
39 2012-07-05 Dmitry Antipov <dmantipov@yandex.ru>
40
41 Cleanup xmalloc.
42 * lisp.h (xzalloc): New prototype. Omit needless casts.
43 * alloc.c (xzalloc): New function. Omit needless casts.
44 * charset.c: Omit needless casts. Convert all calls to
45 xmalloc with following memset to xzalloc.
46 * dispnew.c: Likewise.
47 * fringe.c: Likewise.
48 * image.c: Likewise.
49 * sound.c: Likewise.
50 * term.c: Likewise.
51 * w32fns.c: Likewise.
52 * w32font.c: Likewise.
53 * w32term.c: Likewise.
54 * xfaces.c: Likewise.
55 * xfns.c: Likewise.
56 * xterm.c: Likewise.
57 * atimer.c: Omit needless casts.
58 * buffer.c: Likewise.
59 * callproc.c: Likewise.
60 * ccl.c: Likewise.
61 * coding.c: Likewise.
62 * composite.c: Likewise.
63 * doc.c: Likewise.
64 * doprnt.c: Likewise.
65 * editfns.c: Likewise.
66 * emacs.c: Likewise.
67 * eval.c: Likewise.
68 * filelock.c: Likewise.
69 * fns.c: Likewise.
70 * gtkutil.c: Likewise.
71 * keyboard.c: Likewise.
72 * lisp.h: Likewise.
73 * lread.c: Likewise.
74 * minibuf.c: Likewise.
75 * msdos.c: Likewise.
76 * print.c: Likewise.
77 * process.c: Likewise.
78 * region-cache.c: Likewise.
79 * search.c: Likewise.
80 * sysdep.c: Likewise.
81 * termcap.c: Likewise.
82 * terminal.c: Likewise.
83 * tparam.c: Likewise.
84 * w16select.c: Likewise.
85 * w32.c: Likewise.
86 * w32reg.c: Likewise.
87 * w32select.c: Likewise.
88 * w32uniscribe.c: Likewise.
89 * widget.c: Likewise.
90 * xdisp.c: Likewise.
91 * xmenu.c: Likewise.
92 * xrdb.c: Likewise.
93 * xselect.c: Likewise.
94
95 2012-07-05 Paul Eggert <eggert@cs.ucla.edu>
96
97 * fileio.c (time_error_value): Check the right error number.
98 Problem reported by Troels Nielsen in
99 <http://lists.gnu.org/archive/html/emacs-devel/2012-07/msg00095.html>.
100
101 2012-07-04 Paul Eggert <eggert@cs.ucla.edu>
102
103 * window.c (set_window_hscroll): Revert the 100000 hscroll limit.
104 This should be fixed in a better way; see Eli Zaretskii in
105 <http://lists.gnu.org/archive/html/emacs-devel/2012-07/msg00088.html>.
106 (HSCROLL_MAX): Remove; this is now internal to set_window_hscroll.
107
108 * fileio.c (time_error_value): Rename from special_mtime.
109 The old name's problems were noted by Eli Zaretskii in
110 <http://lists.gnu.org/archive/html/emacs-devel/2012-07/msg00087.html>.
111
112 * emacs.c (gdb_pvec_type): Change it back to enum pvec_type.
113 This variable's comment says Emacs needs at least one GDB-visible
114 symbol of type enum pvec_type, to work around GDB problems.
115 The symbol's value doesn't matter.
116
117 * alloc.c (PSEUDOVECTOR_NBYTES): Remove stray ';'
118 that causes compilation to fail on pre-C99 compilers.
119
120 2012-07-04 Juanma Barranquero <lekktu@gmail.com>
121
122 * s/ms-w32.h (LISP_FLOAT_TYPE, HAVE_MEMCMP, HAVE_MEMCPY)
123 (HAVE_MEMMOVE, HAVE_MEMSET): Don't set, obsolete.
124
125 2012-07-04 Dmitry Antipov <dmantipov@yandex.ru>
126
127 * buffer.c (init_buffer_once): Fix initialization of
128 headers for buffer_defaults and buffer_local_symbols.
129 Reported by Juanma Barranquero <lekktu@gmail.com>.
130
131 2012-07-04 Stefan Monnier <monnier@iro.umontreal.ca>
132
133 Turn VECTOR_FREE_LIST_FLAG into PVEC_FREE.
134 * lisp.h (enum pvec_type): Use fewer bits.
135 (PSEUDOVECTOR_SIZE_BITS): New constant.
136 (PSEUDOVECTOR_SIZE_MASK, PVEC_TYPE_MASK): Use it.
137 (XSETPVECTYPESIZE, XSETTYPED_PSEUDOVECTOR, DEFUN): Adapt code to
138 change in pvec_type.
139 (PSEUDOVECTOR_TYPEP): New macro.
140 (TYPED_PSEUDOVECTORP): Use it.
141 * fns.c (internal_equal): Adapt code to extract pvectype.
142 * emacs.c (gdb_pvec_type): Update type.
143 * alloc.c (PSEUDOVECTOR_NBYTES): New macro.
144 (VECTOR_FREE_LIST_SIZE_MASK): Remove (=> PSEUDOVECTOR_SIZE_MASK).
145 (VECTOR_FREE_LIST_FLAG): Remove (=> PVEC_FREE).
146 (SETUP_ON_FREE_LIST): Use XSETPVECTYPESIZE.
147 (sweep_vectors): Use it. Use local var `total_bytes' instead of
148 abusing vector->header.next.nbytes.
149 (live_vector_p): Use PVEC_TYPE.
150 (mark_object): Adapt code to extract pvectype. Use switch.
151
152 2012-07-04 Paul Eggert <eggert@cs.ucla.edu>
153
154 * doprnt.c (doprnt): Don't assume string length fits in 'int'.
155 Tighten new eassert a bit.
156
157 2012-07-04 Dmitry Antipov <dmantipov@yandex.ru>
158
159 Fix compilation with --enable-gcc-warnings and -O1
160 optimization level.
161 * doprnt.c (doprnt): Change type of tem to int, initialize
162 to avoid compiler warning. Add eassert.
163 * search.c (simple_search): Initialize match_byte to avoid
164 compiler warning. Add eassert.
165
166 2012-07-04 Paul Eggert <eggert@cs.ucla.edu>
167
168 Avoid weird behavior with large horizontal scrolls.
169 Without this change, for example, large hscroll values would
170 mess up Emacs's display on Fedora 15 x86, presumably due to
171 overflows in int calculations in the display code.
172 Also, if buffers had long lines, Emacs would freeze.
173 * window.c (HSCROLL_MAX): Reduce to 100000, and make it visible to GDB.
174 (set_window_hscroll): New function, containing the old guts of
175 Fset_window_hscroll. Return the clipped value.
176 (Fset_window_hscroll, Fscroll_left, Fscroll_right): Use it.
177 This avoids the need to check against PTRDIFF_MAX.
178
179 * buffer.c (Fgenerate_new_buffer_name): Fix sprintf format mismatch.
180
181 2012-07-04 Dmitry Antipov <dmantipov@yandex.ru>
182
183 * buffer.c (Fgenerate_new_buffer_name): Fix type mismatch.
184
185 2012-07-04 Paul Eggert <eggert@cs.ucla.edu>
186
187 * regex.c: Suppress GCC warning on RHEL 6. (Bug#11207)
188 Conditionalize the pragmas on GCC 4.5 or later, not GCC 4.3 or later,
189 since GCC 4.4.6 issues a bogus warning for them.
190
191 Fix bugs in file timestamp newness comparisons.
192 * fileio.c (Ffile_newer_than_file_p):
193 * lread.c (Fload): Use full timestamp resolution of files,
194 not just the 1-second resolution, so that files that are only
195 slightly newer still count as newer.
196 * fileio.c (Ffile_newer_than_file_p): Don't assume file
197 timestamps fit in 'int'; this fixes a Y2038 bug on most hosts.
198
199 2012-07-03 Paul Eggert <eggert@cs.ucla.edu>
200
201 * fileio.c: Improve handling of file time marker. (Bug#11852)
202 (special_mtime): New function.
203 (Finsert_file_contents, Fverify_visited_file_modtime):
204 Use it to set special mtime values consistently.
205
206 2012-07-03 Andreas Schwab <schwab@linux-m68k.org>
207
208 * fileio.c (Finsert_file_contents): Properly handle st_mtime
209 marker for non-existing file. (Bug#11852)
210
211 2012-07-03 Glenn Morris <rgm@gnu.org>
212
213 * lisp.h (Fread_file_name): Restore EXFUN (it's not a normal DEFUN
214 and did not make it into globals.h).
215
216 2012-07-03 Tom Tromey <tromey@redhat.com>
217
218 * window.c (Fset_window_margins, Fset_window_fringes)
219 (Fset_window_scroll_bars, Fset_window_vscroll): No longer static.
220 * textprop.c (Fprevious_property_change): No longer static.
221 * syntax.c (Fsyntax_table_p): No longer static.
222 * process.c (Fget_process, Fprocess_datagram_address): No longer
223 static.
224 * keymap.c (Flookup_key, Fcopy_keymap): No longer static.
225 * keyboard.c (Fcommand_execute): No longer static.
226 Remove EXFUN.
227 * insdel.c (Fcombine_after_change_execute): No longer static.
228 * image.c (Finit_image_library): No longer static.
229 * fileio.c (Fmake_symbolic_link): No longer static.
230 * eval.c (Ffetch_bytecode): No longer static.
231 * editfns.c (Fuser_full_name): No longer static.
232 * doc.c (Fdocumentation_property, Fsnarf_documentation):
233 No longer static.
234 * buffer.c (Fset_buffer_major_mode, Fdelete_overlay): No longer
235 static.
236 * dired.c (Ffile_attributes): No longer static.
237 * composite.c (Fcomposition_get_gstring): No longer static.
238 * callproc.c (Fgetenv_internal): No longer static.
239
240 * ccl.h: Remove EXFUNs.
241 * buffer.h: Remove EXFUNs.
242 * dispextern.h: Remove EXFUNs.
243 * intervals.h: Remove EXFUNs.
244 * fontset.h: Remove EXFUN.
245 * font.h: Remove EXFUNs.
246 * dosfns.c (system_process_attributes): Remove EXFUN.
247 * keymap.h: Remove EXFUNs.
248 * lisp.h: Remove EXFUNs.
249 * w32term.h: Remove EXFUNs.
250 * window.h: Remove EXFUNs.
251 * xsettings.h: Remove EXFUN.
252 * xterm.h: Remove EXFUN.
253
254 2012-07-03 Glenn Morris <rgm@gnu.org>
255
256 * lisp.h (Frandom): Make it visible to C.
257 * buffer.c (Fgenerate_new_buffer_name): Speed up finding a new
258 buffer for invisible buffers. (Bug#1229)
259
260 2012-07-03 Dmitry Antipov <dmantipov@yandex.ru>
261
262 Fix block vector allocation code to allow VECTOR_BLOCK_SIZE
263 values which aren't power of 2.
264 * alloc.c (VECTOR_FREE_LIST_SIZE_MASK): New macro. Verify
265 it's value and the value of VECTOR_BLOCK_SIZE. Adjust users
266 accordingly.
267
268 2012-07-03 Stefan Monnier <monnier@iro.umontreal.ca>
269
270 * lisp.h (Lisp_Misc, Lisp_Fwd): Move around to group better.
271
272 * alloc.c (mark_object): Revert part of last patch to use `switch'.
273
274 2012-07-03 Dmitry Antipov <dmantipov@yandex.ru>
275
276 * alloc.c (allocate_vector_block): Remove redundant
277 calls to mallopt if DOUG_LEA_MALLOC is defined.
278 (allocate_vectorlike): If DOUG_LEA_MALLOC is defined,
279 avoid calls to mallopt if zero_vector is returned.
280
281 2012-07-03 Dmitry Antipov <dmantipov@yandex.ru>
282
283 * alloc.c (check_string_bytes): If GC_CHECK_STRING_BYTES
284 is enabled, avoid dereferencing NULL current_sblock if
285 running undumped.
286
287 2012-07-03 Dmitry Antipov <dmantipov@yandex.ru>
288
289 Cleanup basic buffer management.
290 * buffer.h (struct buffer): Change layout to use generic vector
291 marking code. Fix some comments. Change type of 'clip_changed'
292 to bitfield. Remove unused #ifndef old.
293 (FIRST_FIELD_PER_BUFFER, LAST_FIELD_PER_BUFFER): Remove.
294 (GET_OVERLAYS_AT): Fix indentation.
295 (for_each_per_buffer_object_at): New macro.
296 * buffer.c (clone_per_buffer_values, reset_buffer_local_variables)
297 (Fbuffer_local_variables): Use it.
298 (init_buffer_once, syms_of_buffer): Remove unused #ifndef old.
299 * alloc.c (allocate_buffer): Adjust to match new layout of
300 struct buffer. Fix comment.
301 (mark_overlay): New function.
302 (mark_buffer): Use it. Use mark_vectorlike to mark normal
303 Lisp area of struct buffer.
304 (mark_object): Use it. Adjust marking of misc objects
305 and related comments.
306
307 2012-07-02 Paul Eggert <eggert@cs.ucla.edu>
308
309 * alloc.c (mark_object): Remove "#ifdef GC_CHECK_MARKED_OBJECTS"
310 wrapper that is not needed because the wrapped code is a no-op (zero
311 machine instructions) when GC_CHECK_MARKED_OBJECTS is not defined.
312 This avoids a -Wunused-macros diagnostic with GCC 4.7.1 x86-64.
313
314 2012-07-02 Dmitry Antipov <dmantipov@yandex.ru>
315
316 * alloc.c (mark_buffer): Simplify. Remove prototype.
317 (mark_object): Add comment. Reorganize marking of vector-like
318 objects. Use CHECK_LIVE for all vector-like objects except buffers
319 and subroutines when GC_CHECK_MARKED_OBJECTS is defined. Avoid
320 redundant calls to mark_vectorlike for bool vectors.
321
322 2012-06-30 Glenn Morris <rgm@gnu.org>
323
324 * nsterm.m (ns_init_paths): Ignore site-lisp if --no-site-lisp.
325
326 * epaths.in (PATH_SITELOADSEARCH): New.
327 * lread.c (init_lread): Use PATH_SITELOADSEARCH.
328 This is rather than relying on --enable-locallisppath elements
329 having "site-lisp" in their names. (Bug#10208#25, 11658)
330
331 2012-06-30 Eli Zaretskii <eliz@gnu.org>
332
333 * w32proc.c (sys_select): Accept and ignore one more argument.
334
335 * w32.c (emacs_gnutls_pull): Call select with one more argument.
336
337 * sysselect.h [DOS_NT]: Don't include sys/select.h.
338 (pselect) [!MS_DOS]: Redirect to sys_select.
339
340 * sysdep.c: Don't include dos.h and dosfns.h.
341
342 * process.c (sys_select):
343 * msdos.c (sys_select): Accept one more argument and ignore it.
344
345 * msdos.c (event_timestamp, sys_select): Use gnulib's gettime;
346 adapt data types and code to that.
347
348 * dosfns.c:
349 * msdos.c (gettime, settime): Define away the prototypes in dos.h,
350 which clashes with the gnulib function of the same name.
351
352 2012-06-30 Andreas Schwab <schwab@linux-m68k.org>
353
354 * font.c (font_style_to_value, font_style_symbolic)
355 (font_prop_validate_style): Add type checks for values in
356 font_style_table.
357
358 * lisp.h (CHECK_RANGED_INTEGER): Make value to check the first
359 argument.
360 * character.c, charset.c, menu.c, process.c, window.c: Adjust all
361 uses.
362
363 2012-06-29 Eli Zaretskii <eliz@gnu.org>
364
365 * xdisp.c (try_window_id): Undo last change.
366
367 * w32.c (getwd): Adjust commentary about startup_dir.
368 (init_environment): Always call sys_access, even in non-MSVC
369 builds. Don't chdir to the directory of the Emacs executable.
370 This undoes code from 1997 which was justified by the need to
371 "avoid conflicts when removing and renaming directories". But its
372 downside was that every relative file name was being interpreted
373 relative to the directory of the Emacs executable, which can never
374 be TRT. In particular, it broke sys_access when called with
375 relative file names.
376 (sys_access): Map GetLastError to errno.
377
378 2012-06-29 Dmitry Antipov <dmantipov@yandex.ru>
379
380 * window.h (struct window): Change type of 'fringes_outside_margins'
381 to bitfield. Fix comment. Adjust users accordingly.
382 (struct window): Change type of 'window_end_bytepos' to ptrdiff_t.
383 Adjust comment.
384 * xdisp.c (try_window_id): Change type of 'first_vpos' and 'vpos'
385 to ptrdiff_t.
386
387 2012-06-29 Andreas Schwab <schwab@linux-m68k.org>
388
389 * gnutls.c (emacs_gnutls_handshake):
390 Add QUIT to make the loop interruptible.
391
392 2012-06-29 Glenn Morris <rgm@gnu.org>
393
394 * charset.c (init_charset): Make lack of etc/charsets fatal.
395
396 2012-06-29 Dmitry Antipov <dmantipov@yandex.ru>
397
398 * editfns.c (region_limit): Fix type mismatch.
399
400 2012-06-29 Dmitry Antipov <dmantipov@yandex.ru>
401
402 * nsfns.m: Fix GLYPH_DEBUG usage assuming that it may be
403 undefined. Convert from xassert to eassert.
404 * nsmenu.m: Convert from xassert to eassert.
405 * nsterm.m: Likewise.
406
407 2012-06-28 Stefan Monnier <monnier@iro.umontreal.ca>
408
409 * editfns.c (region_limit): Clip to narrowing (bug#11770).
410
411 2012-06-28 Paul Eggert <eggert@cs.ucla.edu>
412
413 Avoid integer overflow on scroll-left and scroll-right.
414 * window.c (HSCROLL_MAX): New macro.
415 (Fscroll_left, Fscroll_right): Avoid undefined behavior on integer
416 overflow when requested scroll falls outside ptrdiff_t range.
417
418 2012-06-28 Dmitry Antipov <dmantipov@yandex.ru>
419
420 * window.h (struct window): Change type of 'hscroll',
421 'min_hscroll' and 'last_point' from Lisp_Object to ptrdiff_t,
422 'last_modified' and 'last_overlay_modified' to EMACS_INT.
423 Adjust users accordingly.
424 * xdisp.c (try_cursor_movement): Replace type check with eassert.
425 * window.c (Fscroll_left, Fscroll_right): Change type of 'hscroll'
426 from EMACS_INT to ptrdiff_t.
427 (make_window): Omit redundant initialization.
428
429 2012-06-28 Juanma Barranquero <lekktu@gmail.com>
430
431 * makefile.w32-in ($(BLD)/regex.$(O)): Update dependencies.
432
433 2012-06-28 Dmitry Antipov <dmantipov@yandex.ru>
434
435 * window.h (struct window): Change type of 'use_time' and
436 'sequence_number' from Lisp_Object to int.
437 * frame.c (make_frame): Adjust users accordingly.
438 * print.c (print_object): Likewise.
439 * window.c (select_window, Fwindow_use_time, make_parent_window)
440 (make_window): Likewise.
441
442 2012-06-28 Dmitry Antipov <dmantipov@yandex.ru>
443
444 * dispextern.h (GLYPH_DEBUG): Now defined in config.h if
445 enabled with --enable-checking=[all,glyphs] configure option.
446 Fix GLYPH_DEBUG usage assuming that it may be undefined,
447 adjust comments accordingly.
448 * dispnew.c: Fix GLYPH_DEBUG usage assuming that it may be
449 undefined, adjust comments accordingly.
450 * image.c: Likewise.
451 * scroll.c: Likewise.
452 * w32fns.c: Likewise.
453 * w32term.c: Likewise.
454 * xdisp.c: Likewise.
455 * xfaces.c: Likewise.
456 * xfns.c: Likewise.
457 * xterm.c: Likewise.
458
459 2012-06-28 Dmitry Antipov <dmantipov@yandex.ru>
460
461 Generalize run-time debugging checks.
462 * dispextern.h (XASSERTS): Remove.
463 * fontset.c (xassert): Remove.
464 Convert from xassert to eassert.
465 * alloc.c: Convert from xassert to eassert.
466 * bidi.c: Likewise.
467 * dispnew.c: Likewise.
468 * fns.c: Likewise.
469 * fringe.c: Likewise.
470 * ftfont.c: Likewise.
471 * gtkutil.c: Likewise.
472 * image.c: Likewise.
473 * keyboard.c: Likewise.
474 * menu.c: Likewise.
475 * process.c: Likewise.
476 * scroll.c: Likewise.
477 * sound.c: Likewise.
478 * term.c: Likewise.
479 * w32console.c: Likewise.
480 * w32fns.c: Likewise.
481 * w32term.c: Likewise.
482 * window.c: Likewise.
483 * xdisp.c: Likewise.
484 * xfaces.c: Likewise.
485 * xfns.c: Likewise.
486 * xselect.c: Likewise.
487 * xterm.c: Likewise.
488
489 2012-06-27 Stefan Monnier <monnier@iro.umontreal.ca>
490
491 * fns.c (maybe_resize_hash_table): Output message when growing the
492 purify-hashtable.
493
494 2012-06-27 Dmitry Antipov <dmantipov@yandex.ru>
495
496 * alloc.c (allocate_string_data): Remove dead code.
497 * xsettings.c (XSETTINGS_FONT_NAME): Move under HAVE_XFT to
498 avoid GCC warning about unused macro.
499
500 2012-06-27 Dmitry Antipov <dmantipov@yandex.ru>
501
502 * alloc.c (allocate_string): Omit intervals initialization.
503 * alloc.c (make_uninit_multibyte_string): Initialize intervals
504 as in make_pure_string and make_pure_c_string.
505
506 2012-06-27 Dmitry Antipov <dmantipov@yandex.ru>
507
508 * alloc.c (allocate_string): Fix last change.
509
510 2012-06-27 Dmitry Antipov <dmantipov@yandex.ru>
511
512 * alloc.c (allocate_string): Remove two redundant calls
513 to memset, add explicit initialization where appropriate.
514
515 2012-06-27 Glenn Morris <rgm@gnu.org>
516
517 * lisp.mk (lisp): Remove paths.elc.
518
519 2012-06-27 Chong Yidong <cyd@gnu.org>
520
521 * doc.c (Fsubstitute_command_keys): Fix punctuation.
522
523 2012-06-26 John Wiegley <johnw@newartisans.com>
524
525 * unexmacosx.c (copy_data_segment): Add two section names used
526 on Mac OS X Lion: __mod_init_func and __mod_term_func.
527
528 * alloc.c (mark_memory): Do not check with -faddress-sanitizer
529 when building with Clang.
530
531 2012-06-26 Stefan Monnier <monnier@iro.umontreal.ca>
532
533 * eval.c (Fapply): Allow calling it with a single argument.
534
535 2012-06-26 Eli Zaretskii <eliz@gnu.org>
536
537 * s/ms-w32.h (strcasecmp, strncasecmp) [_MSC_VER]: Redirect to
538 _stricmp and _strnicmp.
539 (HAVE_STRCASECMP, HAVE_STRNCASECMP): Define to 1.
540
541 2012-06-26 Dmitry Antipov <dmantipov@yandex.ru>
542
543 * alloc.c (allocate_window): Zero out non-Lisp part of newly
544 allocated window.
545 (allocate_process): Likewise for new process.
546 (allocate_terminal): Change to use offsetof.
547 (allocate_frame): Likewise.
548 * frame.c (make_frame): Omit redundant initialization.
549 * window.c (make_parent_window): Use memset.
550 (make_window): Omit redundant initialization.
551 * process.c (make_process): Omit redundant initialization.
552 * terminal.c (create_terminal): Likewise.
553
554 2012-06-26 Dmitry Antipov <dmantipov@yandex.ru>
555
556 * term.c (delete_tty): Remove redundant call to memset.
557
558 2012-06-26 Dmitry Antipov <dmantipov@yandex.ru>
559
560 * alloc.c: Remove build_string.
561 * lisp.h: Define build_string as static inline. This provides
562 a better opportunity to optimize away calls to strlen when the
563 function is called with compile-time constant argument.
564 * image.c (imagemagick_error): Convert to build_string.
565 * w32proc.c (sys_spawnve): Likewise.
566 * xterm.c (x_term_init): Likewise.
567
568 2012-06-26 Paul Eggert <eggert@cs.ucla.edu>
569
570 Use sprintf return value instead of invoking strlen on result.
571 In the old days this wasn't portable, since some sprintf
572 implementations returned char *. But they died out years ago and
573 Emacs already assumes sprintf returns int.
574 Similarly for float_to_string.
575 This patch speeds up (number-to-string 1000) by 3% on Fedora 15 x86-64.
576 * ccl.c (ccl_driver):
577 * character.c (string_escape_byte8):
578 * data.c (Fnumber_to_string):
579 * doprnt.c (doprnt):
580 * print.c (print_object):
581 * xdisp.c (message_dolog):
582 * xfns.c (syms_of_xfns):
583 Use sprintf or float_to_string result to avoid need to call strlen.
584 * data.c (Fnumber_to_string):
585 Use make_unibyte_string, since the string must be ASCII.
586 * lisp.h, print.c (float_to_string): Now returns int length.
587 * term.c (produce_glyphless_glyph):
588 Use sprintf result rather than recomputing it.
589
590 Clean out last vestiges of the old HAVE_CONFIG_H stuff.
591 * Makefile.in (ALL_CFLAGS):
592 * makefile.w32-in (LOCAL_FLAGS): Remove -DHAVE_CONFIG_H.
593 * gmalloc.c, regex.c: Include <config.h> unconditionally.
594
595 2012-06-25 Dmitry Antipov <dmantipov@yandex.ru>
596
597 * dispextern.h (xstrcasecmp): Define to library function
598 strcasecmp if available.
599 * xfaces.c: Do not use xstrcasecmp if strcasecmp is available.
600
601 2012-06-25 Andreas Schwab <schwab@linux-m68k.org>
602
603 * keyboard.c (menu_bar_items, menu_bar_item, read_key_sequence):
604 Avoid comma operator.
605 * menu.c (push_submenu_start, push_submenu_end)
606 (push_left_right_boundary, push_menu_pane): Likewise.
607 * msdos.c (dos_rawgetc): Likewise.
608
609 2012-06-25 Dmitry Antipov <dmantipov@yandex.ru>
610
611 * xfns.c (xic_create_fontsetname): Remove redundant calls
612 to memset.
613
614 2012-06-25 Paul Eggert <eggert@cs.ucla.edu>
615
616 * gtkutil.c (get_utf8_string): Remove redundant assignment.
617 sprintf already null-terminates its output.
618
619 * xfns.c (x_window): Remove redundant cast.
620
621 2012-06-25 Dmitry Antipov <dmantipov@yandex.ru>
622
623 * xmenu.c (xmenu_show, xdialog_show): Explicit cast from
624 `const char *' to `char *' to avoid compiler warning.
625
626 2012-06-24 Paul Eggert <eggert@cs.ucla.edu>
627
628 * xterm.c (x_term_init): Build proper-sized _XSETTINGS_Snnn string
629 instead of truncating it to 63 (admittedly a generous limit).
630
631 * process.c: Fix spelling and caps in comments.
632
633 2012-06-24 Dan Nicolaescu <dann@ics.uci.edu>
634
635 * emacs.c (setpgrp): Remove definition, unused.
636 * sysdep.c (setpgrp): Remove definition, not used in this file.
637
638 2012-06-24 Juanma Barranquero <lekktu@gmail.com>
639
640 * makefile.w32-in: Update dependencies.
641
642 2012-06-24 Eli Zaretskii <eliz@gnu.org>
643
644 * makefile.w32-in (TIMESPEC_H): Remove nt/inc/sys/time.h.
645 (SYSTIME_H): Add nt/inc/sys/time.h.
646
647 * systime.h [WINDOWSNT]: Include sys/time.h.
648
649 * s/ms-w32.h (struct timespec): Definition moved from
650 nt/inc/sys/time.h. Suggested by Paul Eggert <eggert@cs.ucla.edu>.
651
652 2012-06-24 Paul Eggert <eggert@cs.ucla.edu>
653
654 Switch from NO_RETURN to C11's _Noreturn (Bug#11750).
655 * buffer.h (buffer_slot_type_mismatch):
656 * data.c (arith_error) [!FORWARD_SIGNAL_TO_MAIN_THREAD]:
657 * eval.c (unwind_to_catch):
658 * image.c (my_png_error, my_error_exit):
659 * keyboard.c (quit_throw_to_read_char, user_error)
660 (Fexit_recursive_edit, Fabort_recursive_edit):
661 * lisp.h (die, args_out_of_range, args_out_of_range_3)
662 (wrong_type_argument, buffer_overflow, __executable_start)
663 (memory_full, buffer_memory_full, string_overflow, Fthrow)
664 (xsignal, xsignal0, xsignal1, xsignal2, xsignal3, signal_error)
665 (error, verror, nsberror, report_file_error, Ftop_level, Fkill_emacs)
666 (fatal):
667 (child_setup) [!DOS_NT]:
668 * lread.c (end_of_file_error, invalid_syntax):
669 * process.c (send_process_trap) [!FORWARD_SIGNAL_TO_MAIN_THREAD]:
670 * puresize.h (pure_write_error):
671 * search.c (matcher_overflow):
672 * sound.c (sound_perror, alsa_sound_perror):
673 * sysdep.c, syssignal.h (croak):
674 * term.c (maybe_fatal, vfatal):
675 * textprop.c (text_read_only):
676 * undo.c (user_error):
677 * unexmacosx.c (unexec_error):
678 * xterm.c (x_ins_del_lines, x_delete_glyphs):
679 Use _Noreturn rather than NO_RETURN.
680 No need for separate decl merely because of _Noreturn.
681 * sound.c (sound_warning, parse_sound):
682 Remove unnecessary forward decls.
683
684 2012-06-24 Paul Eggert <eggert@cs.ucla.edu>
685
686 Fix bug when time_t is unsigned and as wide as intmax_t (Bug#9000).
687 * lisp.h (WAIT_READING_MAX): New macro.
688 * dispnew.c (Fsleep_for, sit_for):
689 * keyboard.c (kbd_buffer_get_event):
690 * process.c (Faccept_process_output):
691 Use it to avoid bogus compiler warnings with obsolescent GCC versions.
692 This improves on the previous patch, which introduced a bug
693 when time_t is unsigned and as wide as intmax_t.
694 See <http://bugs.gnu.org/9000#51>.
695
696 2012-06-23 Eli Zaretskii <eliz@gnu.org>
697
698 * dispnew.c (sit_for, Fsleep_for):
699 * keyboard.c (kbd_buffer_get_event):
700 * process.c (Faccept_process_output): Avoid compiler warnings when
701 comparing a 32-bit time_t with a 64-bit INTMAX_MAX.
702
703 2012-06-23 Juanma Barranquero <lekktu@gmail.com>
704
705 * makefile.w32-in: Update dependencies.
706
707 * w32.c (ltime): Add return type and declare static.
708 (w32_get_internal_run_time): Remove usused variable `time_100ns'.
709
710 2012-06-23 Paul Eggert <eggert@cs.ucla.edu>
711
712 * sysdep.c [__FreeBSD__]: Fix more recently-introduced typos.
713 Privately reported by Herbert J. Skuhra.
714 (make_lisp_timeval) [__FreeBSD__]: Rename from TIMELIST.
715 All uses changed.
716 (system_process_attributes) [__FreeBSD__]: Invoke make_lisp_time,
717 not make_lisp_timeval, when the argument is of type EMACS_TIME.
718
719 2012-06-23 Eli Zaretskii <eliz@gnu.org>
720
721 * w32proc.c (Fw32_get_locale_info): Fix an off-by-one error in
722 last argument of make_unibyte_string.
723
724 * keyboard.c (kbd_buffer_get_event): Include the codepage and the
725 language ID in the event parameters.
726
727 * w32term.c (w32_read_socket): Put the new keyboard codepage into
728 event.code, not the obscure "character set ID".
729
730 2012-06-23 Chong Yidong <cyd@gnu.org>
731
732 * xmenu.c (x_menu_wait_for_event): Adapt GTK3 to new xg_select.
733
734 2012-06-23 Eli Zaretskii <eliz@gnu.org>
735
736 Fix the MS-Windows build broken by 2012-06-22T21:17:42Z!eggert@cs.ucla.edu.
737 * w32.c (fdutimens): New function.
738
739 * w32proc.c (sys_select): Adapt to change in the EMACS_TIME type.
740
741 * s/ms-w32.h (pselect): Redirect to sys_select.
742
743 * sysselect.h [WINDOWSNT]: Don't include sys/select.h.
744
745 * ralloc.c (r_alloc_inhibit_buffer_relocation): Fix stupid thinko
746 in the logic of incrementing and decrementing the value of
747 use_relocatable_buffers.
748
749 2012-06-23 Paul Eggert <eggert@cs.ucla.edu>
750
751 * sysdep.c [__FreeBSD__]: Fix recently-introduced typos.
752 Privately reported by Herbert J. Skuhra.
753 [__FreeBSD__]: Remove "*/" typo after "#include".
754 (timeval_to_EMACS_TIME) [__FreeBSD__]: New static function.
755 (TIMEVAL) [__FreeBSD__]: Now a static function rather than a macro.
756 (TIMEVAL, system_process_attributes) [__FreeBSD__]:
757 Don't assume EMACS_TIME and struct timeval are the same type.
758
759 2012-06-22 Paul Eggert <eggert@cs.ucla.edu>
760
761 Support higher-resolution time stamps (Bug#9000).
762 The time stamps are only nanosecond-resolution at the C level,
763 since that's the best that any real-world system supports now.
764 But they are picosecond-resolution at the Lisp level, as that's
765 easy, and leaves room for future OS improvements.
766
767 * Makefile.in (LIB_CLOCK_GETTIME): New macro.
768 (LIBES): Use it.
769
770 * alloc.c (Fgarbage_collect): Port to higher-res time stamps.
771 Don't get current time unless it's needed.
772
773 * atimer.c: Include <sys/time.h> unconditionally, since gnulib
774 now provides it if it's absent.
775 (start_atimer): Port to higher-res time stamps.
776 Check for time stamp overflow. Don't get current time more
777 often than is needed.
778
779 * buffer.h (struct buffer): Buffer modtime now has high resolution.
780 Include systime.h, not time.h.
781 (NONEXISTENT_MODTIME_NSECS, UNKNOWN_MODTIME_NSECS): New macros.
782
783 * dired.c: Include stat-time.h.
784 (Ffile-attributes): File times now have higher resolution.
785
786 * dispextern.h [HAVE_WINDOW_SYSTEM]: Include systime.h.
787 (struct image): Timestamp now has higher resolution.
788
789 * dispnew.c (PERIODIC_PREEMPTION_CHECKING): Remove, as Emacs always
790 has at least microseconds now. All uses removed.
791 (update_frame, update_single_window, update_window, update_frame_1)
792 (Fsleep_for, sit_for): Port to higher-resolution time stamps.
793
794 * editfns.c (time_overflow): Now extern.
795 (Fcurrent_time, Fget_internal_run_time, make_time, lisp_time_argument)
796 (float-time, Fformat_time_string, Fcurrent_time_string)
797 (Fcurrent_time_zone): Accept and generate higher-resolution
798 time stamps.
799 (make_time_tail, make_lisp_time, dissassemble_lisp_time)
800 (decode_time_components, lisp_seconds_argument): New functions.
801 (make_time): Now static.
802 (lisp_time_argument): Now returns EMACS_TIME. New arg ppsec.
803 Report an error if the time is invalid, rather than having the caller
804 do that.
805
806 * fileio.c: Include <stat-time.h>
807 (Fcopy_file): Copy higher-resolution time stamps.
808 Prefer to set the time stamp via a file descriptor if that works.
809 (Fset_file_times, Finsert_file_contents, Fwrite_region)
810 (Fverify_visited_file_modtime, Fclear_visited_file_modtime)
811 (Fvisited_file_modtime, Fset_visited_file_modtime):
812 Support higher-resolution time stamps.
813
814 * fns.c (Frandom): Use nanoseconds, not microseconds, for seed.
815
816 * gtkutil.c (xg_maybe_add_timer): Port to higher-res time stamps.
817
818 * image.c (prepare_image_for_display, clear_image_cache)
819 (lookup_image): Port to higer-resolution time stamps.
820
821 * keyboard.c (start_polling, bind_polling_period):
822 Check for time stamp overflow.
823 (read_char, kbd_buffer_get_event, timer_start_idle)
824 (timer_stop_idle, timer_resume_idle, timer_check_2, timer_check)
825 (Fcurrent_idle_time, init_keyboard, set_waiting_for_input):
826 Port to higher-resolution time stamps. Do not assume time_t is signed.
827 (decode_timer): New function. Timers are now vectors of length 9,
828 not 8, to accommodate the picosecond component.
829 (timer_check_2): Use it.
830
831 * nsterm.m (select_timeout, timeval_subtract): Remove.
832 (ns_timeout): Use Emacs's facilities for time stamp arithmetic,
833 as they're a bit more accurate and handle overflow better.
834 (ns_select): Change prototype to be compatible with pselect.
835 (ns_select, ns_term_shutdown): Port to ns-resolution time stamps.
836 * nsterm.h (ns_select): Adjust prototype.
837
838 * msdos.c (EMACS_TIME_ZERO_OR_NEG_P): Remove, as it assumes
839 us-resolution time stamps.
840 (sys_select): Use the new EMACS_TIME_SIGN macro instead.
841
842 * lread.c (read_filtered_event): Port to ns-resolution time stamps.
843
844 * lisp.h (time_overflow): New decl.
845 (wait_reading_process_output): First arg is now intmax_t, not int,
846 to accommodate larger waits.
847
848 * process.h (struct Lisp_Process.read_output_delay):
849 Now counts nanoseconds, not microseconds.
850 * process.c (ADAPTIVE_READ_BUFFERING): Don't worry about
851 EMACS_HAS_USECS.
852 (READ_OUTPUT_DELAY_INCREMENT, Faccept_process_output)
853 (wait_reading_process_output):
854 Port to ns-resolution time stamps.
855 (Faccept_process_output, wait_reading_process_output):
856 Check for time stamp overflow. Do not assume time_t is signed.
857 (select_wrapper): Remove; we now use pselect.
858 (Fprocess_attributes): Now generates ns-resolution time stamps.
859
860 * sysdep.c: Include utimens.h. Don't include utime.h
861 or worry about struct utimbuf; gnulib does that for us now.
862 (gettimeofday): Remove; gnulib provides a substitute.
863 (make_timeval): New function.
864 (set_file_times): Now sets ns-resolution time stamps.
865 New arg FD; all uses changed.
866 (time_from_jiffies, ltime_from_jiffies, get_up_time)
867 (system_process_attributes):
868 Now returns ns-resolution time stamp. All uses changed.
869 Check for time stamp overflow.
870
871 * sysselect.h: Don't depend on HAVE_SYS_SELECT_H; gnulib
872 provides a substitute now.
873
874 * systime.h: Include timespec.h rather than sys/time.h and time.h,
875 since it guarantees struct timespec.
876 (EMACS_TIME): Now struct timespec, so that we can support
877 ns-resolution time stamps.
878 (EMACS_TIME_RESOLUTION, LOG10_EMACS_TIME_RESOLUTION): New macros.
879 (EMACS_HAS_USECS): Remove; Emacs always has sub-second time stamps now.
880 (EMACS_USECS): Remove.
881 (EMACS_SET_USECS): The underlying time stamp now has ns resolution,
882 so multiply the arg by 1000 before storing it.
883 (EMACS_NSECS, EMACS_SECS_ADDR, EMACS_SET_NSECS, EMACS_SET_SECS_NSECS):
884 New macros.
885 (EMACS_GET_TIME, EMACS_ADD_TIME, EMACS_SUB_TIME):
886 Port to ns-resolution time stamps.
887 (EMACS_TIME_NEG_P): Remove; replaced by....
888 (EMACS_TIME_SIGN): New macro.
889 (EMACS_SET_INVALID_TIME, EMACS_TIME_VALID_P)
890 (EMACS_TIME_FROM_DOUBLE, EMACS_TIME_TO_DOUBLE): New macros.
891 (set_file_times, make_time, lisp_time_argument): Adjust signature.
892 (make_timeval, make_lisp_time, decode_time_components): New decls.
893 (EMACS_TIME_CMP): Remove; no longer used. Plus, it was buggy, in
894 that it mishandled time_t overflow. You can't compare by subtracting!
895 (EMACS_TIME_EQ, EMACS_TIME_NE, EMACS_TIME_GT, EMACS_TIME_GE)
896 (EMACS_TIME_LT, EMACS_TIME_LE): Rewrite in terms of timespec_cmp.
897
898 * term.c: Include <sys/time.h>.
899 (timeval_to_Time): New function, for proper overflow wraparound.
900 (term_mouse_position, term_mouse_click): Use it.
901
902 * undo.c (record_first_change): Support higher-resolution time stamps
903 in the undo buffer.
904 (Fprimitive_undo): Use them when restoring time stamps.
905
906 * w32.c (ltime, U64_TO_LISP_TIME, process_times, emacs_gnutls_pull)
907 (w32_get_internal_run_time):
908 Port to higher-resolution Emacs time stamps.
909 (ltime): Now accepts single 64-bit integer, as that's more convenient
910 for callers.
911
912 * xdisp.c (start_hourglass): Port to ns-resolution time stamps.
913
914 * xgselect.c, xgselect.h (xg_select): Add sigmask argument,
915 for compatibility with pselect. Support ns-resolution time stamps.
916
917 * xmenu.c (x_menu_wait_for_event): Support ns-resolution time stamps.
918
919 * xselect.c (wait_for_property_change, x_get_foreign_selection):
920 Check for time stamp overflow, and support ns-resolution time stamps.
921
922 * xterm.c: Don't include sys/time.h; gnulib does that for us now.
923 Don't worry about whether HAVE_TIMEVAL and HAVE_SELECT are set.
924 (timeval_subtract): Remove; no longer needed.
925 (XTflash, XTring_bell, x_wait_for_event):
926 Port to ns-resolution time stamps. Don't assume time_t is signed.
927
928 2012-06-22 Chong Yidong <cyd@gnu.org>
929
930 * xdisp.c (x_consider_frame_title): Revert last change.
931
932 2012-06-22 Eli Zaretskii <eliz@gnu.org>
933
934 * alloc.c (NSTATICS): Enlarge to 0x650. Otherwise, Emacs compiled
935 with -DENABLE_CHECKING -DXASSERTS -DGLYPH_DEBUG=1 -DBYTE_CODE_METER
936 aborts in staticpro during startup. (Without -DBYTE_CODE_METER,
937 staticidx goes up to 1597 out of 1600 = 0x640.)
938
939 2012-06-20 Paul Eggert <eggert@cs.ucla.edu>
940
941 * fileio.c (Fdefault_file_modes): Block input while fiddling with umask.
942 Otherwise, the umask might be mistakenly 0 while handling input signals.
943
944 2012-06-19 Stefan Monnier <monnier@iro.umontreal.ca>
945
946 * minibuf.c (Fread_string): Bind minibuffer-completion-table.
947
948 2012-06-19 Dmitry Antipov <dmantipov@yandex.ru>
949
950 * alloc.c, bytecode.c, ccl.c, coding.c, composite.c, data.c, dosfns.c:
951 * font.c, image.c, keyboard.c, lread.c, menu.c, minibuf.c, msdos.c:
952 * print.c, syntax.c, window.c, xmenu.c, xselect.c: Replace direct
953 access to `contents' member of Lisp_Vector objects with AREF and ASET
954 where appropriate.
955
956 2012-06-19 Chong Yidong <cyd@gnu.org>
957
958 * frame.c (delete_frame): When selecting a frame on a different
959 text terminal, do not alter the terminal's top-frame.
960
961 * xdisp.c (format_mode_line_unwind_data): Record the target
962 frame's selected window and its terminal's top-frame.
963 (unwind_format_mode_line): Restore them.
964 (x_consider_frame_title, display_mode_line, Fformat_mode_line):
965 Callers changed.
966 (x_consider_frame_title): Do not condition on HAVE_WINDOW_SYSTEM,
967 since tty frames can be explicitly named.
968 (prepare_menu_bars): Likewise.
969
970 * term.c (Ftty_top_frame): New function.
971
972 2012-06-18 Paul Eggert <eggert@cs.ucla.edu>
973
974 Port byte-code-meter to modern targets.
975 * bytecode.c (METER_CODE) [BYTE_CODE_METER]: Don't assume
976 !CHECK_LISP_OBJECT_TYPE && !USE_LSB_TAG. Problem with
977 CHECK_LISP_OBJECT_TYPE reported by Dmitry Antipov in
978 <http://lists.gnu.org/archive/html/emacs-devel/2012-06/msg00282.html>.
979 (METER_1, METER_2): Simplify.
980
981 2012-06-18 Stefan Monnier <monnier@iro.umontreal.ca>
982
983 * data.c (Fdefalias): Return `symbol' (bug#11686).
984
985 2012-06-18 Martin Rudalics <rudalics@gmx.at>
986
987 * buffer.c (Fkill_buffer): Don't throw an error when the buffer
988 gets killed during executing of this function (Bug#11665).
989 Try to always return Qt when the buffer has been actually killed.
990 (Vkill_buffer_query_functions): In doc-string say that functions
991 run by this hook should not change the current buffer.
992
993 2012-06-18 Paul Eggert <eggert@cs.ucla.edu>
994
995 Fix recently-introduced process.c problems found by static checking.
996 * process.c (write_queue_push, write_queue_pop, send_process):
997 Use ptrdiff_t, not int or EMACS_INT, for buffer lengths and offsets.
998 (write_queue_pop): Fix pointer signedness problem.
999 (send_process): Remove unused local.
1000
1001 2012-06-17 Chong Yidong <cyd@gnu.org>
1002
1003 * xdisp.c (redisplay_internal): No need to redisplay terminal
1004 frames that are not on top.
1005
1006 2012-06-17 Troels Nielsen <bn.troels@gmail.com>
1007
1008 * process.c (make_process): Initialize write_queue.
1009 (write_queue_push, write_queue_pop): New functions.
1010 (send_process): Use them to maintain correct ordering of process
1011 writes (Bug#10815).
1012
1013 2012-06-17 Paul Eggert <eggert@cs.ucla.edu>
1014
1015 * lisp.h (eassert): Assume C89 or later.
1016 This removes the need for CHECK.
1017 (CHECK): Remove. Its comments about always evaluating its
1018 argument were confusing, as 'eassert' typically does not evaluate
1019 its argument.
1020
1021 * coding.c (produce_chars): Use ptrdiff_t, not int.
1022
1023 * xterm.c (x_draw_underwave): Check for integer overflow.
1024 This pacifies gcc 4.7.0 -Wunsafe-loop-optimizations on x86-64.
1025
1026 2012-06-17 Jan Djärv <jan.h.d@swipnet.se>
1027
1028 * nsterm.m (x_free_frame_resources): Move xfree so freed memory isn't
1029 referenced (Bug#11583).
1030
1031 2012-06-16 Aurelien Aptel <aurelien.aptel@gmail.com>
1032
1033 Implement wave-style variant of underlining.
1034 * dispextern.h (face_underline_type): New enum.
1035 (face): Add field for underline type.
1036 * nsterm.m (ns_draw_underwave): New function.
1037 (ns_draw_text_decoration): Use it.
1038 * w32term.c (w32_restore_glyph_string_clip, w32_draw_underwave):
1039 New functions.
1040 (x_draw_glyph_string): Use them.
1041 * xfaces.c (Qline, Qwave): New Lisp objects.
1042 (check_lface_attrs, merge_face_ref)
1043 (Finternal_set_lisp_face_attribute, realize_x_face):
1044 Handle wave-style underline face attributes.
1045 * xterm.c (x_draw_underwave): New function.
1046 (x_draw_glyph_string): Use it.
1047
1048 2012-06-16 Juanma Barranquero <lekktu@gmail.com>
1049
1050 * makefile.w32-in ($(BLD)/emacs.$(O), $(BLD)/fringe.$(O))
1051 ($(BLD)/xml.$(O), $(BLD)/intervals.$(O), $(BLD)/macros.$(O))
1052 ($(BLD)/minibuf.$(O), $(BLD)/regex.$(O), $(BLD)/region-cache.$(O))
1053 ($(BLD)/textprop.$(O), $(BLD)/undo.$(O), $(BLD)/window.$(O))
1054 ($(BLD)/w32select.$(O)): Update dependencies.
1055
1056 2012-06-16 Andreas Schwab <schwab@linux-m68k.org>
1057
1058 * buffer.h (FETCH_MULTIBYTE_CHAR): Define as inline.
1059 (BUF_FETCH_MULTIBYTE_CHAR): Likewise.
1060 * character.c (_fetch_multibyte_char_p): Remove.
1061 * alloc.c: Include "character.h" before "buffer.h".
1062 * bidi.c: Likewise.
1063 * buffer.c: Likewise.
1064 * bytecode.c: Likewise.
1065 * callint.c: Likewise.
1066 * callproc.c: Likewise.
1067 * casefiddle.c: Likewise.
1068 * casetab.c: Likewise.
1069 * category.c: Likewise.
1070 * cmds.c: Likewise.
1071 * coding.c: Likewise.
1072 * composite.c: Likewise.
1073 * dired.c: Likewise.
1074 * dispnew.c: Likewise.
1075 * doc.c: Likewise.
1076 * dosfns.c: Likewise.
1077 * editfns.c: Likewise.
1078 * emacs.c: Likewise.
1079 * fileio.c: Likewise.
1080 * filelock.c: Likewise.
1081 * font.c: Likewise.
1082 * fontset.c: Likewise.
1083 * fringe.c: Likewise.
1084 * indent.c: Likewise.
1085 * insdel.c: Likewise.
1086 * intervals.c: Likewise.
1087 * keyboard.c: Likewise.
1088 * keymap.c: Likewise.
1089 * lread.c: Likewise.
1090 * macros.c: Likewise.
1091 * marker.c: Likewise.
1092 * minibuf.c: Likewise.
1093 * nsfns.m: Likewise.
1094 * nsmenu.m: Likewise.
1095 * print.c: Likewise.
1096 * process.c: Likewise.
1097 * regex.c: Likewise.
1098 * region-cache.c: Likewise.
1099 * search.c: Likewise.
1100 * syntax.c: Likewise.
1101 * term.c: Likewise.
1102 * textprop.c: Likewise.
1103 * undo.c: Likewise.
1104 * unexsol.c: Likewise.
1105 * w16select.c: Likewise.
1106 * w32fns.c: Likewise.
1107 * w32menu.c: Likewise.
1108 * window.c: Likewise.
1109 * xdisp.c: Likewise.
1110 * xfns.c: Likewise.
1111 * xmenu.c: Likewise.
1112 * xml.c: Likewise.
1113 * xselect.c: Likewise.
1114
1115 2012-06-16 Eli Zaretskii <eliz@gnu.org>
1116
1117 * xdisp.c (set_cursor_from_row): Don't dereference glyphs_end.
1118 If all the glyphs of the glyph row came from strings, and we have no
1119 cursor positioning clues, put the cursor on the first glyph of the
1120 row.
1121 (handle_face_prop): Use chunk-relative overlay string index when
1122 indexing into it->string_overlays array. (Bug#11653)
1123 (set_cursor_from_row): Use the leftmost glyph as GLYPH_BEFORE, not
1124 the rightmost. (Bug#11720)
1125
1126 2012-06-16 Andreas Schwab <schwab@linux-m68k.org>
1127
1128 * category.h (CHAR_HAS_CATEGORY): Define as inline.
1129 (CATEGORY_MEMBER): Enforce 1/0 value.
1130 * category.c (_temp_category_set): Remove.
1131
1132 2012-06-16 Eli Zaretskii <eliz@gnu.org>
1133
1134 * window.c (Fdelete_other_windows_internal)
1135 (Fdelete_window_internal): Don't access frame's mouse highlight
1136 info of the initial frame. (Bug#11677)
1137
1138 2012-06-14 Paul Eggert <eggert@cs.ucla.edu>
1139
1140 * .gdbinit (xgetint): Fix recently-introduced paren typo.
1141 Assume USE_2_TAGS_FOR_INTS.
1142 (xreload): Adjust $tagmask width to match recent lisp.h change.
1143
1144 Simplify lisp.h in minor ways that should not affect code.
1145 * lisp.h (USE_2_TAGS_FOR_INTS): Remove, as it was always defined.
1146 (LISP_INT_TAG, case_Lisp_Int, LISP_STRING_TAG, LISP_INT_TAG_P)
1147 (LISP_INT1_TAG, enum Lisp_Type, XINT, XUINT, make_number):
1148 Simplify under the assumption that USE_2_TAGS_FOR_INTS is defined.
1149 (INTTYPEBITS): New macro, for clarity.
1150 (INTMASK, MOST_POSITIVE_FIXNUM): Use it.
1151 (LISP_INT1_TAG, LISP_STRING_TAG, LISP_INT_TAG_P):
1152 Simplify now that USE_LSB_TAG is always defined.
1153 (TYPEMASK, XINT) [USE_LSB_TAG]: Remove unnecessary cast.
1154 (make_number) [!USE_LSB_TAG]: Use INTMASK; that's simpler.
1155
1156 2012-06-13 Juanma Barranquero <lekktu@gmail.com>
1157
1158 * makefile.w32-in ($(BLD)/data.$(O)): Update dependencies.
1159
1160 2012-06-13 Glenn Morris <rgm@gnu.org>
1161
1162 * s/bsd-common.h (BSD4_3):
1163 * s/usg5-4-common.h (USG5_4): No longer define; unused.
1164
1165 2012-06-13 Andreas Schwab <schwab@linux-m68k.org>
1166
1167 * lisp.h (Lisp_Object) [CHECK_LISP_OBJECT_TYPE]: Define as struct
1168 instead of union.
1169 (XLI, XIL): Define.
1170 (XHASH, XTYPE, XINT, XUINT, make_number, XSET, XPNTR, XUNTAG):
1171 Use them.
1172 * emacs.c (gdb_use_struct): Rename from gdb_use_union.
1173 * .gdbinit: Check gdb_use_struct instead of gdb_use_union.
1174 * alloc.c (widen_to_Lisp_Object): Remove.
1175 (mark_memory): Use XIL instead of widen_to_Lisp_Object.
1176 * frame.c (delete_frame): Remove outdated comment.
1177 * w32fns.c (Fw32_register_hot_key): Use XLI instead of checking
1178 USE_LISP_UNION_TYPE.
1179 (Fw32_unregister_hot_key): Likewise.
1180 (Fw32_toggle_lock_key): Likewise.
1181 * w32menu.c (add_menu_item): Likewise.
1182 (w32_menu_display_help): Use XIL instead of checking
1183 USE_LISP_UNION_TYPE.
1184 * w32heap.c (allocate_heap): Don't check USE_LISP_UNION_TYPE.
1185 (init_heap): Likewise.
1186 * w32term.c (w32_read_socket): Update comment.
1187
1188 2012-06-13 Glenn Morris <rgm@gnu.org>
1189
1190 * s/usg5-4-common.h, src/s/unixware.h:
1191 Remove define/undef of HAVE_SYSV_SIGPAUSE (not used since 2010-05-04).
1192
1193 * s/gnu.h (POSIX_SIGNALS): Remove (not used since 2010-05-04).
1194
1195 2012-06-13 Paul Eggert <eggert@cs.ucla.edu>
1196
1197 USE_LISP_UNION_TYPE + USE_LSB_TAG cleanup (Bug#11604)
1198 * alloc.c (make_number) [!defined make_number]:
1199 Remove, as lisp.h always defines this now.
1200 (mark_maybe_pointer): Simplify since USE_LSB_TAG is always defined now.
1201 (roundup_size): Verify that it is a power of 2.
1202 * data.c (Fmake_variable_buffer_local, Fmake_local_variable):
1203 * ftfont.c (ftfont_driver): Use LISP_INITIALLY_ZERO.
1204 * lisp.h (USE_LSB_TAG): Allow the builder to compile with
1205 -DUSE_LSB_TAG=0, to override the automatically-selected default.
1206 USE_LSB_TAG now is always defined to be either 0 or 1.
1207 All uses changed.
1208 (union Lisp_Object): Don't worry about WORDS_BIGENDIAN; the
1209 code works fine either way, and efficiency is not a concern here,
1210 as the union type is for debugging, not for production.
1211 (LISP_MAKE_RVALUE, make_number) [USE_LISP_UNION_TYPE]:
1212 Use an inline function on all platforms when using the union type,
1213 since this is simpler and 'static inline' can be used portably
1214 within Emacs now.
1215 (LISP_INITIALLY_ZERO): New macro.
1216 (XFASTINT, XSETFASTINT) [USE_LISP_UNION_TYPE]: Remove.
1217 (XSET) [USE_LISP_UNION_TYPE]: Don't overparenthesize.
1218
1219 2012-06-12 Glenn Morris <rgm@gnu.org>
1220
1221 * s/gnu-kfreebsd.h, s/hpux11.h, s/openbsd.h, s/sol2-10.h: Remove files.
1222
1223 * s/gnu-linux.h (HAVE_PROCFS): Move to configure.
1224
1225 * s/hpux10-20.h, s/openbsd.h, s/usg5-4-common.h:
1226 Move BROKEN_SIGIO to configure.
1227
1228 * s/bsd-common.h, s/darwin.h, s/gnu-kfreebsd.h, s/hpux10-20.h:
1229 Move NO_TERMIO to configure.
1230
1231 2012-06-12 Chong Yidong <cyd@gnu.org>
1232
1233 * image.c (imagemagick_load_image): Use MagickFlattenImage if
1234 MagickMergeImageLayers is undefined. Use pixel pusher loop if
1235 MagickExportImagePixels is undefined.
1236
1237 2012-06-12 Paul Eggert <eggert@cs.ucla.edu>
1238
1239 * image.c (imagemagick_load_image): Remove unused label.
1240
1241 2012-06-11 Glenn Morris <rgm@gnu.org>
1242
1243 * s/aix4-2.h, s/bsd-common.h, s/cygwin.h, s/darwin.h:
1244 * s/gnu-kfreebsd.h, s/gnu-linux.h, s/gnu.h, s/hpux10-20.h:
1245 * s/irix6-5.h, s/ms-w32.h, s/msdos.h, s/template.h:
1246 * s/usg5-4-common.h: Move SYSTEM_TYPE to configure.
1247
1248 2012-06-11 Stefan Monnier <monnier@iro.umontreal.ca>
1249
1250 * alloc.c (make_byte_code): New function.
1251 (Fmake_byte_code): Use it. Don't purify here.
1252 * lread.c (read1): Use it as well to avoid extra allocation.
1253
1254 2012-06-11 Chong Yidong <cyd@gnu.org>
1255
1256 * image.c (imagemagick_load_image): Implement transparency.
1257
1258 2012-06-10 Andreas Schwab <schwab@linux-m68k.org>
1259
1260 * regex.c (at_begline_loc_p): Also recognize `(?N:' and correctly
1261 account for preceding backslashes. (Bug#11663)
1262
1263 2012-06-09 Chong Yidong <cyd@gnu.org>
1264
1265 * term.c: Support italics in capable terminals (Bug#9652).
1266 (no_color_bit): Replace unused NC_BLINK with NC_ITALIC.
1267 (turn_on_face): Output using TS_enter_italic_mode if available.
1268 Don't handle unused blinking and alt-charset cases.
1269 (turn_off_face): Handle italic case; discard unused tty_blinking_p
1270 and tty_alt_charset_p cases.
1271 (tty_capable_p, init_tty): Support italics.
1272
1273 * termchar.h (struct tty_display_info): Add field for italics.
1274 Remove unused blink field.
1275
1276 * xfaces.c (tty_supports_face_attributes_p, realize_tty_face):
1277 Handle slant.
1278
1279 * dispextern.h: Replace unused TTY_CAP_BLINK with TTY_CAP_ITALIC.
1280 (struct face): Remove unused fields tty_dim_p, tty_blinking_p, and
1281 tty_alt_charset_p. Add tty_italic_p.
1282
1283 2012-06-09 Michael Albinus <michael.albinus@gmx.de>
1284
1285 * dbusbind.c (XD_BASIC_DBUS_TYPE): Use dbus_type_is_valid and
1286 dbus_type_is_basic if available.
1287 (xd_extract_signed, xd_extract_unsigned): Rename from
1288 extract_signed and extract_unsigned, respectively. Adapt callers.
1289
1290 2012-06-09 Chong Yidong <cyd@gnu.org>
1291
1292 * xfaces.c (face_for_overlay_string): Handle face remapping (Bug#2066).
1293
1294 * fringe.c (Fset_fringe_bitmap_face): Handle the noninteractive
1295 case (Bug#9752).
1296
1297 2012-06-08 Paul Eggert <eggert@cs.ucla.edu>
1298
1299 * xdisp.c (vmessage): Treat frame message as multibyte.
1300 Without this change, (let ((§ 1)) (make-variable-buffer-local '§))
1301 would generate the diagnostic "Making \302\247 buffer-local while
1302 let-bound!".
1303
1304 2012-06-08 Eli Zaretskii <eliz@gnu.org>
1305
1306 * dispnew.c (showing_window_margins_p): Undo last change, which
1307 was done due to an inadvertent commit.
1308 (adjust_frame_glyphs_for_frame_redisplay): Do call
1309 showing_window_margins_p.
1310
1311 2012-06-08 Stefan Monnier <monnier@iro.umontreal.ca>
1312
1313 * eval.c (Fmake_var_non_special): New primitive.
1314 (syms_of_eval): Defsubr it.
1315 * lread.c (syms_of_lread): Mark `values' as lexically scoped.
1316
1317 2012-06-08 Juanma Barranquero <lekktu@gmail.com>
1318
1319 * dispnew.c (showing_window_margins_p): Wrap in #if 0 to prevent unused
1320 function warning (the only call is inside #if 0 since 2012-06-08T08:44:45Z!eliz@gnu.org).
1321
1322 2012-06-08 Eli Zaretskii <eliz@gnu.org>
1323
1324 * alloc.c (allocate_vectorlike): Fix last change.
1325
1326 2012-06-08 Dmitry Antipov <dmantipov@yandex.ru>
1327
1328 Block-based vector allocation of small vectors.
1329 * lisp.h (struct vectorlike_header): New field `nbytes',
1330 adjust comment accordingly.
1331 * alloc.c (enum mem_type): New type `MEM_TYPE_VECTOR_BLOCK'
1332 to denote vector blocks. Adjust users (live_vector_p,
1333 mark_maybe_pointer, valid_lisp_object_p) accordingly.
1334 (COMMON_MULTIPLE): Move outside #if USE_LSB_TAG.
1335 (VECTOR_BLOCK_SIZE, vroundup, VECTOR_BLOCK_BYTES),
1336 (VBLOCK_BYTES_MIN, VBLOCK_BYTES_MAX, VECTOR_MAX_FREE_LIST_INDEX),
1337 (VECTOR_FREE_LIST_FLAG, ADVANCE, VINDEX, SETUP_ON_FREE_LIST),
1338 (VECTOR_SIZE, VECTOR_IN_BLOCK): New macros.
1339 (roundup_size): New constant.
1340 (struct vector_block): New data type.
1341 (vector_blocks, vector_free_lists, zero_vector): New variables.
1342 (all_vectors): Rename to `large_vectors'.
1343 (allocate_vector_from_block, init_vectors, allocate_vector_from_block)
1344 (sweep_vectors): New functions.
1345 (allocate_vectorlike): Return `zero_vector' as the only vector of
1346 0 items. Allocate new vector from block if vector size is less than
1347 or equal to VBLOCK_BYTES_MAX.
1348 (Fgarbage_collect): Move all vector sweeping code to sweep_vectors.
1349 (init_alloc_once): Add call to init_vectors.
1350
1351 2012-06-08 Stefan Monnier <monnier@iro.umontreal.ca>
1352
1353 * eval.c (Fmacroexpand): Stop if the macro returns the same form.
1354
1355 2012-06-07 Paul Eggert <eggert@cs.ucla.edu>
1356
1357 * doprnt.c (doprnt): Truncate multibyte char correctly.
1358 Without this change, doprnt (buf, 2, "%s", FORMAT_END, AP)
1359 would mishandle a string argument "Xc" if X was a multibyte
1360 character of length 2: it would truncate after X's first byte
1361 rather than including all of X.
1362
1363 2012-06-06 Chong Yidong <cyd@gnu.org>
1364
1365 * buffer.c (word_wrap): Doc fix.
1366
1367 2012-06-04 Paul Eggert <eggert@cs.ucla.edu>
1368
1369 * xdisp.c (note_mode_line_or_margin_highlight): Pacify gcc -Wall.
1370
1371 2012-06-03 Glenn Morris <rgm@gnu.org>
1372
1373 * xdisp.c (tool-bar-style): Doc fix.
1374
1375 2012-06-03 Ulrich Müller <ulm@gentoo.org>
1376
1377 * Makefile.in (PAXCTL): Define.
1378 (temacs$(EXEEXT)): Disable memory randomization for the temacs
1379 binary via PaX flags if the paxctl utility is available.
1380 (emacs$(EXEEXT), bootstrap-emacs$(EXEEXT)):
1381 Restore PaX flags to their default. (Bug#11398)
1382
1383 2012-06-03 Chong Yidong <cyd@gnu.org>
1384
1385 * xdisp.c (decode_mode_spec_coding): Display a space for a unibyte
1386 buffer (Bug#11226).
1387
1388 2012-06-03 Chong Yidong <cyd@gnu.org>
1389
1390 * xdisp.c (calc_pixel_width_or_height): Use Fbuffer_local_value.
1391 (note_mode_line_or_margin_highlight): If there is no help echo,
1392 use mode-line-default-help-echo. Handle the case where the mouse
1393 position is past the end of the mode line string.
1394
1395 * buffer.c (buffer_local_value_1): New function, split from
1396 Fbuffer_local_value; can return Qunbound.
1397 (Fbuffer_local_value): Use it.
1398 (Vmode_line_format): Docstring tweaks.
1399
1400 2012-06-02 Paul Eggert <eggert@cs.ucla.edu>
1401
1402 * sysdep.c (system_process_attributes): Improve comment.
1403
1404 2012-06-02 Stefan Monnier <monnier@iro.umontreal.ca>
1405
1406 * keyboard.c: Export real-this-command to Elisp.
1407 (syms_of_keyboard): Rename real_this_command to Vreal_this_command
1408 and DEFVAR it. Update all users.
1409
1410 2012-06-02 Paul Eggert <eggert@cs.ucla.edu>
1411
1412 * minibuf.c (Fassoc_string): Remove duplicate declaration.
1413
1414 * sysdep.c (system_process_attributes) [SOLARIS2 && HAVE_PROCFS]:
1415 Convert pctcpu and pctmem to Lisp float properly.
1416 Let the compiler fold better, as 100.0/0x8000 is exact.
1417
1418 2012-06-02 Andreas Schwab <schwab@linux-m68k.org>
1419
1420 * alloc.c (CONS_BLOCK_SIZE): Account for padding at the end of
1421 cons_block.
1422
1423 2012-06-01 Paul Eggert <eggert@cs.ucla.edu>
1424
1425 * xfns.c (x_set_tool_bar_lines) [USE_GTK]: Adjust to bitfield change.
1426
1427 2012-06-01 Dmitry Antipov <dmantipov@yandex.ru>
1428
1429 For a 'struct window', replace some Lisp_Object fields to
1430 bitfields where appropriate, remove unused fields.
1431 * window.h (struct window): Remove unused 'last_mark_x' and
1432 'last_mark_y' fields. Rename 'mini_p' field to 'mini',
1433 change it's type from Lisp_Object to bitfield.
1434 Change type of 'force_start', 'optional_new_start',
1435 'last_had_star', 'update_mode_line' and 'start_at_line_beg'
1436 fields from Lisp_Object to bitfield. Adjust users accordingly.
1437
1438 2012-05-31 Paul Eggert <eggert@cs.ucla.edu>
1439
1440 Pacify gcc -Wdouble-precision when using Xaw.
1441 * xterm.c (xaw_jump_callback, x_set_toolkit_scroll_bar_thumb)
1442 [HAVE_X_WINDOWS && USE_TOOLKIT_SCROLL_BARS && !USE_MOTIF && !USE_GTK]:
1443 Use 'float' consistently, rather than 'float' in most places
1444 and 'double' in a couple of places.
1445
1446 2012-05-31 Eli Zaretskii <eliz@gnu.org>
1447
1448 * xdisp.c (handle_stop): Detect whether we have overlay strings
1449 loaded by testing it->current.overlay_string_index to be
1450 non-negative, instead of checking whether n_overlay_strings is
1451 positive. (Bug#11587)
1452
1453 2012-05-31 Chong Yidong <cyd@gnu.org>
1454
1455 * keymap.c (describe_map_tree): Revert 2011-07-07 change (Bug#1169).
1456
1457 * doc.c (Fsubstitute_command_keys): Doc fix.
1458
1459 2012-05-31 Eli Zaretskii <eliz@gnu.org>
1460
1461 * search.c (search_buffer): Remove calls to
1462 r_alloc_inhibit_buffer_relocation, as it is now called by
1463 maybe_unify_char, which was the cause of relocation of buffer text
1464 in bug#11519.
1465
1466 2012-05-31 Eli Zaretskii <eliz@gnu.org>
1467
1468 * charset.c (maybe_unify_char): Inhibit relocation of buffer text
1469 for the duration of call to load_charset, to avoid problems with
1470 callers of maybe_unify_char that access buffer text through C
1471 pointers.
1472
1473 * ralloc.c (r_alloc_inhibit_buffer_relocation): Increment and
1474 decrement the inhibition flag, instead of just setting or
1475 resetting it.
1476
1477 2012-05-31 Paul Eggert <eggert@cs.ucla.edu>
1478
1479 Remove obsolete '#define static' cruft.
1480 * s/hpux10-20.h (_FILE_OFFSET_BITS): Don't #undef.
1481 This #undef was "temporary" in 2000; it is no longer needed
1482 now that '#define static' has gone away.
1483 * xfns.c, xterm.h (gray_bitmap_width, gray_bitmap_height)
1484 (gray_bitmap_bits): Remove; no longer needed.
1485 All uses replaced with definiens.
1486 * xterm.c: Include "bitmaps/gray.xbm".
1487
1488 2012-05-30 Paul Eggert <eggert@cs.ucla.edu>
1489
1490 Clean up __executable_start, monstartup when --enable-profiling.
1491 The following changes affect the code only when profiling.
1492 * dispnew.c (__executable_start): Rename from safe_bcopy.
1493 Define only on platforms that need it.
1494 * emacs.c: Include <sys/gmon.h> when profiling.
1495 (_mcleanup): Remove decl, since <sys/gmon.h> does it now.
1496 (__executable_start): Remove decl, since lisp.h does it now.
1497 (safe_bcopy): Remove decl; no longer has that name.
1498 (main): Coalesce #if into single bit of code, for simplicity.
1499 Cast pointers to uintptr_t, since standard libraries want integers
1500 and not pointers.
1501 * lisp.h (__executable_start): New decl.
1502
1503 2012-05-31 Glenn Morris <rgm@gnu.org>
1504
1505 * image.c (Fimagemagick_types): Doc fix.
1506
1507 2012-05-30 Jim Meyering <meyering@redhat.com>
1508
1509 * callproc.c (Fcall_process_region): Include directory component
1510 in mkstemp error message (Bug#11586).
1511
1512 2012-05-30 Paul Eggert <eggert@cs.ucla.edu>
1513
1514 * alloc.c, lisp.h (make_pure_vector): Now static.
1515
1516 2012-05-30 Stefan Monnier <monnier@iro.umontreal.ca>
1517
1518 * eval.c (Fdefun, Fdefmacro, Vmacro_declaration_function):
1519 Move to byte-run.el.
1520 (Fautoload): Do the hash-doc more carefully.
1521 * data.c (Fdefalias): Purify definition, except for keymaps.
1522 (Qdefun): Move from eval.c.
1523 * lisp.h (Qdefun): Remove.
1524 * lread.c (read1): Tiny simplification.
1525
1526 2012-05-29 Troels Nielsen <bn.troels@gmail.com>
1527
1528 Do not create empty overlays with the evaporate property (Bug#9642).
1529 * buffer.c (Fmove_overlay): Reinstate the earlier fix for
1530 Bug#9642, but explicitly check that the buffer the overlay would
1531 be moved to is live and rearrange lines to make sure that errors
1532 will not put the overlay in an inconsistent state.
1533 (Fdelete_overlay): Cosmetics.
1534
1535 2012-05-28 Eli Zaretskii <eliz@gnu.org>
1536
1537 * w32term.c (my_bring_window_to_top): New function.
1538 (x_raise_frame): Use handle returned by DeferWindowPos, which
1539 could be different from the original one.
1540 Call my_bring_window_to_top instead of my_set_foreground_window.
1541 (Bug#11513)
1542
1543 * w32fns.c (w32_wnd_proc): Accept and process WM_EMACS_BRINGTOTOP
1544 by calling BringWindowToTop.
1545
1546 * w32term.h (WM_EMACS_BRINGTOTOP): New message.
1547 (WM_EMACS_END): Increase by one.
1548
1549 2012-05-28 Paul Eggert <eggert@cs.ucla.edu>
1550
1551 * bidi.c (bidi_mirror_char): Put eassert before conversion to int.
1552 This avoids undefined behavior that might cause the eassert
1553 to not catch an out-of-range value.
1554
1555 2012-05-28 Juanma Barranquero <lekktu@gmail.com>
1556
1557 * makefile.w32-in ($(BLD)/w32inevt.$(O), $(BLD)/w32console.$(O)):
1558 Update dependencies.
1559
1560 2012-05-27 Eli Zaretskii <eliz@gnu.org>
1561
1562 * bidi.c (bidi_mirror_char): Fix last change.
1563
1564 2012-05-27 Andreas Schwab <schwab@linux-m68k.org>
1565
1566 * unexmacosx.c (copy_data_segment): Truncate after 16 characters
1567 when referring to sectname field in printf format.
1568
1569 2012-05-27 Paul Eggert <eggert@cs.ucla.edu>
1570
1571 * lisp.h [REL_ALLOC]: Omit duplicate prototypes.
1572 Only r_alloc_inhibit_buffer_relocation needed to be added;
1573 the others were already declared.
1574
1575 * bidi.c (bidi_mirror_char): Don't possibly truncate the integer
1576 before checking whether it's out of range. Put the check inside
1577 eassert. See
1578 <http://lists.gnu.org/archive/html/emacs-devel/2012-05/msg00485.html>.
1579
1580 2012-05-27 Ken Brown <kbrown@cornell.edu>
1581
1582 * callproc.c (Fcall_process): Restore a line that was accidentally
1583 commented out in the 2011-02-13 change (bug#11547).
1584
1585 2012-05-27 Eli Zaretskii <eliz@gnu.org>
1586
1587 * lisp.h [REL_ALLOC]: Add prototypes for external functions
1588 defined on ralloc.c.
1589
1590 * buffer.c [REL_ALLOC]: Remove prototypes of
1591 r_alloc_reset_variable, r_alloc, r_re_alloc, and r_alloc_free,
1592 they are now on lisp.h.
1593
1594 * ralloc.c (r_alloc_inhibit_buffer_relocation): New function.
1595
1596 * search.c (search_buffer): Use it to inhibit relocation of buffer
1597 text while re_search_2 is doing its job, because re_search_2 is
1598 passed C pointers to buffer text. (Bug#11519)
1599
1600 * msdos.c (internal_terminal_init) <Vwindow_system_version>:
1601 Update value to 24.
1602
1603 * xdisp.c (move_it_to): Under MOVE_TO_Y, when restoring iterator
1604 state after an additional call to move_it_in_display_line_to, keep
1605 the values of it->max_ascent and it->max_descent found for the
1606 entire line.
1607 (pos_visible_p): Revert the comparison against bottom_y to what it
1608 was in revid eliz@gnu.org-20120513182235-4p6386j761ld0nwb.
1609 (Bug#11464)
1610
1611 2012-05-26 Paul Eggert <eggert@cs.ucla.edu>
1612
1613 Fix coding-related core dumps with gcc -ftrapv.
1614 The code was computing A - B, where A and B are pointers, and B is
1615 random garbage. This can lead to core dumps on platforms that
1616 have special pointer registers, and it also leads to core dumps on
1617 x86-64 when compiled with gcc -ftrapv. The fix is to compute
1618 A - B only when B is initialized properly.
1619 * coding.c (coding_set_source, coding_set_destination): Return void.
1620 (coding_change_source, coding_change_destinations): New functions,
1621 with the old behaviors of coding_set_source and coding_set_destination.
1622 All callers that need an offset changed to use these new functions.
1623
1624 2012-05-26 Glenn Morris <rgm@gnu.org>
1625
1626 * nsterm.m (ns_init_paths): Don't mess with INFOPATH. (Bug#2791)
1627
1628 2012-05-26 Eli Zaretskii <eliz@gnu.org>
1629
1630 Extend mouse support on W32 text-mode console.
1631 * xdisp.c (draw_row_with_mouse_face):
1632 Call tty_draw_row_with_mouse_face for WINDOWSNT as well.
1633
1634 * w32console.c: Include window.h.
1635 (w32con_write_glyphs_with_face, tty_draw_row_with_mouse_face):
1636 New functions.
1637 (initialize_w32_display): Initialize mouse-highlight data.
1638
1639 * w32inevt.c: Include termchar.h and window.h.
1640 (do_mouse_event): Support mouse-autoselect-window. When the mouse
1641 moves, call note_mouse_highlight. If help_echo changed, call
1642 gen_help_event to produce help-echo message in the echo area.
1643 Call clear_mouse_face if mouse_face_hidden is set in the mouse
1644 highlight info.
1645
1646 2012-05-26 Paul Eggert <eggert@cs.ucla.edu>
1647
1648 * lread.c (read1): Simplify slightly to avoid an overflow warning
1649 with GCC 4.7.0 on x86-64.
1650
1651 2012-05-26 Eli Zaretskii <eliz@gnu.org>
1652
1653 * bidi.c (bidi_mirror_char): Revert last change: an int is
1654 definitely wide enough here.
1655
1656 2012-05-25 Paul Eggert <eggert@cs.ucla.edu>
1657
1658 Fix integer width and related bugs (Bug#9874).
1659 * alloc.c (pure_bytes_used_lisp, pure_bytes_used_non_lisp):
1660 (allocate_vectorlike, buffer_memory_full, struct sdata, SDATA_SIZE)
1661 (string_bytes, check_sblock, allocate_string_data):
1662 (compact_small_strings, Fmake_bool_vector, make_string)
1663 (make_unibyte_string, make_multibyte_string)
1664 (make_string_from_bytes, make_specified_string)
1665 (allocate_vectorlike, Fmake_vector, find_string_data_in_pure)
1666 (make_pure_string, make_pure_c_string, make_pure_vector, Fpurecopy)
1667 (mark_vectorlike):
1668 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
1669 (allocate_pseudovector):
1670 Use int, not EMACS_INT, where int is wide enough.
1671 (inhibit_garbage_collection, Fgarbage_collect):
1672 Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts.
1673 * bidi.c (bidi_mirror_char): Use EMACS_INT, not int, where
1674 int might not be wide enough.
1675 (bidi_cache_search, bidi_cache_find, bidi_init_it)
1676 (bidi_count_bytes, bidi_char_at_pos, bidi_fetch_char)
1677 (bidi_at_paragraph_end, bidi_find_paragraph_start)
1678 (bidi_paragraph_init, bidi_resolve_explicit, bidi_resolve_weak)
1679 (bidi_level_of_next_char, bidi_move_to_visually_next):
1680 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
1681 * buffer.c (copy_overlays, Fgenerate_new_buffer_name)
1682 (Fkill_buffer, Fset_buffer_major_mode)
1683 (advance_to_char_boundary, Fbuffer_swap_text)
1684 (Fset_buffer_multibyte, overlays_at, overlays_in)
1685 (overlay_touches_p, struct sortvec, record_overlay_string)
1686 (overlay_strings, recenter_overlay_lists)
1687 (adjust_overlays_for_insert, adjust_overlays_for_delete)
1688 (fix_start_end_in_overlays, fix_overlays_before, modify_overlay)
1689 (Fmove_overlay, Fnext_overlay_change, Fprevious_overlay_change)
1690 (Foverlay_recenter, last_overlay_modification_hooks_used)
1691 (report_overlay_modification, evaporate_overlays, enlarge_buffer_text):
1692 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
1693 (validate_region): Omit unnecessary test for b <= e,
1694 since that's guaranteed by the previous test.
1695 (adjust_overlays_for_delete): Avoid pos + length overflow.
1696 (Fmove_overlay, Fdelete_overlay, add_overlay_mod_hooklist)
1697 (report_overlay_modification):
1698 Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts.
1699 (Foverlays_at, Fnext_overlay_change, Fprevious_overlay_change):
1700 Omit pointer cast, which isn't needed anyway, and doesn't work
1701 after the EMACS_INT -> ptrdiff_t change.
1702 (Fmove_overlay): Clip BEG and END to ptrdiff_t to avoid overflow.
1703 * buffer.h: Adjust decls to match defn changes elsewhere.
1704 (struct buffer_text, struct buffer):
1705 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
1706 Use EMACS_INT, not int, where int might not be wide enough.
1707 * bytecode.c (unmark_byte_stack, exec_byte_code): Use ptrdiff_t,
1708 not int, to avoid needless 32-bit limit on 64-bit hosts.
1709 (exec_byte_code): Use tighter memory-full test, one that checks
1710 for alloca overflow. Don't compute the address of the object just
1711 before an array, as that's not portable. Use EMACS_INT, not
1712 ptrdiff_t or int, where ptrdiff_t or int might not be wide enough.
1713 * callint.c (Fcall_interactively):
1714 Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts.
1715 * callproc.c (call_process_kill, Fcall_process):
1716 Don't assume pid_t fits into an Emacs fixnum.
1717 (call_process_cleanup, Fcall_process, child_setup):
1718 Don't assume pid_t fits into int.
1719 (call_process_cleanup, Fcall_process, delete_temp_file)
1720 (Fcall_process_region):
1721 Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts.
1722 (Fcall_process): Simplify handling of volatile integers.
1723 Use int, not EMACS_INT, where int will do.
1724 * casefiddle.c (casify_object, casify_region, operate_on_word)
1725 (Fupcase_word, Fdowncase_word, Fcapitalize_word):
1726 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
1727 (casify_object): Avoid integer overflow when overallocating buffer.
1728 * casetab.c (set_identity, shuffle): Prefer int to unsigned when
1729 either works. Use lint_assume to convince GCC 4.6.1 that it's OK.
1730 * category.c (Fchar_category_set): Don't assume fixnum fits in int.
1731 * category.h (CATEGORYP): Don't assume arg is nonnegative.
1732 * ccl.c (GET_CCL_INT): Remove; no longer needed, since the
1733 integers are now checked earlier. All uses replaced with XINT.
1734 (ccl_driver):
1735 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
1736 For CCL_MapSingle, check that content and value are in int range.
1737 (ccl_driver, Fregister_code_conversion_map):
1738 Check that Vcode_version_map_vector is a vector.
1739 (resolve_symbol_ccl_program): Check that vector header is in range.
1740 Always copy the vector, so that we can check its contents reliably
1741 now rather than having to recheck each instruction as it's being
1742 executed. Check that vector words fit in 'int'.
1743 (ccl_get_compiled_code, Fregister_ccl_program)
1744 (Fregister_code_conversion_map): Use ptrdiff_t, not int, for
1745 program indexes, to avoid needless 32-bit limit on 64-bit hosts.
1746 (Fccl_execute, Fccl_execute_on_string): Check that initial reg
1747 contents are in range.
1748 (Fccl_execute_on_string): Check that status is in range.
1749 * ccl.h (struct ccl_program.idx): Now ptrdiff_t, not int.
1750 * character.c (char_resolve_modifier_mask, Fchar_resolve_modifiers):
1751 Accept and return EMACS_INT, not int, because callers can pass values
1752 out of 'int' range.
1753 (c_string_width, strwidth, lisp_string_width, chars_in_text)
1754 (multibyte_chars_in_text, parse_str_as_multibyte)
1755 (str_as_multibyte, count_size_as_multibyte, str_to_multibyte)
1756 (str_as_unibyte, str_to_unibyte, string_count_byte8)
1757 (string_escape_byte8, Fget_byte):
1758 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
1759 (Funibyte_string): Use CHECK_RANGED_INTEGER, not CHECK_NATNUM, to
1760 avoid mishandling large integers.
1761 * character.h: Adjust decls to match defn changes elsewhere.
1762 * charset.c (load_charset_map_from_file, find_charsets_in_text)
1763 (Ffind_charset_region):
1764 Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts.
1765 (load_charset_map_from_file): Redo idx calculation to avoid overflow.
1766 (load_charset_map_from_vector, Fdefine_charset_internal):
1767 Don't assume fixnum fits in int.
1768 (load_charset_map_from_vector, Fmap_charset_chars):
1769 Remove now-unnecessary CHECK_NATNUMs.
1770 (Fdefine_charset_internal): Check ranges here, more carefully.
1771 Don't rely on undefined behavior with signed left shift overflow.
1772 Don't assume unsigned int fits into fixnum, or that fixnum fits
1773 into unsigned int. Don't require max_code to be a valid fixnum;
1774 that's not true for gb10830 4-byte on a 32-bit host. Allow
1775 invalid_code to be a cons, for the same reason. Require code_offset
1776 to be a character. Avoid int overflow if max_char is close
1777 to INT_MAX.
1778 (CODE_POINT_TO_INDEX): On 32-bit hosts, return int, not unsigned;
1779 this is intended anyway and avoids some undefined behavior.
1780 (load_charset_map): Pass unsigned, not int, as 2nd arg of
1781 INDEX_TO_CODE_POINT, as that's what it expects.
1782 (Funify_charset, encode_char): Don't stuff unsigned vals into int vars.
1783 * charset.h (DECODE_CHAR): Return int, not unsigned;
1784 this is what was intended anyway, and it avoids undefined behavior.
1785 (CHARSET_OFFSET): Remove unused macro, instead of fixing its
1786 integer-overflow issues.
1787 (ENCODE_CHAR): Return unsigned on all hosts, not just on 32-bit hosts.
1788 Formerly, it returned EMACS_INT on 64-bit hosts in the common case
1789 where the argument is EMACS_INT, and this behavior is not intended.
1790 * chartab.c (Fmake_char_table, Fset_char_table_range)
1791 (uniprop_get_decoder, uniprop_get_encoder):
1792 Don't assume fixnum fits in int.
1793 * cmds.c (move_point): New function, that does the gist of
1794 Fforward_char and Fbackward_char, but does so while checking
1795 for integer overflow more accurately.
1796 (Fforward_char, Fbackward_char): Use it.
1797 (Fforward_line, Fend_of_line, internal_self_insert)
1798 (internal_self_insert):
1799 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
1800 Fix a FIXME, by checking for integer overflow when calculating
1801 target_clm and actual_clm.
1802 * coding.c (detect_coding_XXX, encode_coding_XXX, CODING_DECODE_CHAR)
1803 (CODING_ENCODE_CHAR, CODING_CHAR_CHARSET, CODING_CHAR_CHARSET_P)
1804 (ASSURE_DESTINATION, coding_alloc_by_realloc)
1805 (coding_alloc_by_making_gap, alloc_destination)
1806 (detect_coding_utf_8, encode_coding_utf_8, decode_coding_utf_16)
1807 (encode_coding_utf_16, detect_coding_emacs_mule)
1808 (decode_coding_emacs_mule, encode_coding_emacs_mule)
1809 (detect_coding_iso_2022, decode_coding_iso_2022)
1810 (encode_invocation_designation, encode_designation_at_bol)
1811 (encode_coding_iso_2022, detect_coding_sjis, detect_coding_big5)
1812 (decode_coding_sjis, decode_coding_big5, encode_coding_sjis)
1813 (encode_coding_big5, detect_coding_ccl, decode_coding_ccl)
1814 (encode_coding_ccl, encode_coding_raw_text)
1815 (detect_coding_charset, decode_coding_charset)
1816 (encode_coding_charset, detect_eol, decode_eol, produce_chars)
1817 (produce_composition, produce_charset, produce_annotation)
1818 (decode_coding, handle_composition_annotation)
1819 (handle_charset_annotation, consume_chars, decode_coding_gap)
1820 (decode_coding_object, encode_coding_object, detect_coding_system)
1821 (Ffind_coding_systems_region_internal, Fcheck_coding_systems_region)
1822 (code_convert_region, code_convert_string)
1823 (Fdefine_coding_system_internal)
1824 (coding_set_source, coding_set_destination):
1825 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
1826 (setup_iso_safe_charsets, consume_chars, Funencodable_char_position)
1827 (Fdefine_coding_system_internal):
1828 Don't assume fixnums fit in int.
1829 (decode_coding_gap, decode_coding_object, encode_coding_object)
1830 (Fread_coding_system, Fdetect_coding_region)
1831 (Funencodable_char_position, Fcheck_coding_systems_region)
1832 (get_translation, handle_composition_annotation, consume_chars):
1833 Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts.
1834 (consume_chars): Rewrite to not calculate an address outside buffer.
1835 (Ffind_operation_coding_system): NATNUMP can eval its arg twice.
1836 Don't access memory outside of the args array.
1837 (Fdefine_coding_system_internal): Check for charset-id overflow.
1838 (ENCODE_ISO_CHARACTER): Use unsigned, not int, to store the unsigned
1839 result of ENCODE_CHAR.
1840 * coding.h: Adjust decls to match defn changes elsewhere.
1841 (struct coding_system):
1842 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
1843 * composite.c (get_composition_id, find_composition)
1844 (run_composition_function, update_compositions)
1845 (compose_text, composition_gstring_put_cache)
1846 (composition_gstring_p, composition_gstring_width)
1847 (fill_gstring_header, fill_gstring_body, autocmp_chars)
1848 (composition_compute_stop_pos, composition_reseat_it)
1849 (composition_update_it, struct position_record)
1850 (find_automatic_composition, composition_adjust_point)
1851 (Fcomposition_get_gstring, Ffind_composition_internal):
1852 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
1853 (update_compositions):
1854 Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts.
1855 * composite.h: Adjust decls to match defn changes elsewhere.
1856 (struct composition):
1857 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
1858 * data.c (let_shadows_buffer_binding_p, let_shadows_global_binding_p):
1859 Do not attempt to compute the address of the object just before a
1860 buffer; this is not portable.
1861 (Faref, Faset):
1862 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
1863 (Faset): Use int, not EMACS_INT, where int is wide enough.
1864 (Fstring_to_number): Don't assume fixnums fit in int.
1865 (Frem): Don't assume arg is nonnegative.
1866 * dbusbind.c (xd_append_arg): Check for integers out of range.
1867 (Fdbus_call_method): Don't overflow the timeout int.
1868 (extract_signed, extract_unsigned): New functions.
1869 (XD_CHECK_DBUS_SERIAL): Remove; superseded by extract_unsigned.
1870 (xd_get_connection_references): Return ptrdiff_t, not int.
1871 All uses changed.
1872 (xd_signature, xd_append_arg, xd_retrieve_arg, Fdbus_message_internal)
1873 (xd_read_message_1):
1874 Use int, not unsigned, where the dbus API uses int.
1875 (Fdbus_message_internal): Don't overflow mtype.
1876 (syms_of_dbusbind): Allocate right-sized buffer for integers.
1877 * dired.c (directory_files_internal, file_name_completion, scmp)
1878 (file_name_completion_stat):
1879 Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts.
1880 (file_name_completion): Don't overflow matchcount.
1881 (file_name_completion_stat): Use SAFE_ALLOCA, not alloca.
1882 * dispextern.h: Adjust decls to match defn changes elsewhere.
1883 (struct text_pos, struct glyph, struct bidi_saved_info)
1884 (struct bidi_string_data, struct bidi_it, struct composition_it)
1885 (struct it):
1886 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
1887 (struct display_pos, struct composition_it, struct it):
1888 Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts.
1889 * dispnew.c (increment_matrix_positions)
1890 (increment_row_positions, mode_line_string)
1891 (marginal_area_string):
1892 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
1893 (change_frame_size_1, Fredisplay, Fframe_or_buffer_changed_p):
1894 Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts.
1895 (duration_to_sec_usec): New function, to check for overflow better.
1896 (Fsleep_for, sit_for): Use it.
1897 * doc.c (get_doc_string, store_function_docstring):
1898 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
1899 (get_doc_string, Fsnarf_documentation):
1900 Use int, not EMACS_INT, where int is wide enough.
1901 (get_doc_string):
1902 Use SAFE_ALLOCA, not alloca.
1903 Check for overflow when converting EMACS_INT to off_t.
1904 * doprnt.c (doprnt):
1905 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
1906 * editfns.c (init_editfns, Fuser_uid, Fuser_real_uid):
1907 Don't assume uid_t fits into fixnum.
1908 (buildmark, Fgoto_char, overlays_around, find_field, Fdelete_field)
1909 (Ffield_string, Ffield_string_no_properties, Ffield_beginning)
1910 (Ffield_end, Fconstrain_to_field, Fline_beginning_position)
1911 (Fline_end_position, Fprevious_char, Fchar_after, Fchar_before)
1912 (general_insert_function)
1913 (Finsert_char, make_buffer_string, make_buffer_string_both)
1914 (update_buffer_properties, Fbuffer_substring)
1915 (Fbuffer_substring_no_properties, Fcompare_buffer_substrings)
1916 (Fsubst_char_in_region, check_translation)
1917 (Ftranslate_region_internal, save_restriction_restore, Fformat)
1918 (transpose_markers, Ftranspose_regions):
1919 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
1920 (clip_to_bounds): Move to lisp.h as an inline function).
1921 (Fconstrain_to_field): Don't assume integers are nonnegative.
1922 (Fline_beginning_position, Fsave_excursion, Fsave_current_buffer):
1923 (Fsubst_char_in_region, Fsave_restriction):
1924 Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts.
1925 (Femacs_pid): Don't assume pid_t fits into fixnum.
1926 (lo_time): Use int, not EMACS_INT, when int suffices.
1927 (lisp_time_argument): Check for usec out of range.
1928 (Fencode_time): Don't assume fixnum fits in int.
1929 (Fuser_login_name, Fuser_full_name): Signal an error
1930 if a uid argument is out of range, rather than relying on
1931 undefined behavior.
1932 (Fformat_time_string): Remove now-unnecessary check.
1933 lisp_time_argument checks for out-of-range usec now.
1934 Use ptrdiff_t, not size_t, where ptrdiff_t will do.
1935 * emacs.c (gdb_valbits, gdb_gctypebits): Now int, not EMACS_INT.
1936 (gdb_data_seg_bits): Now uintptr_t, not EMACS_INT.
1937 (PVEC_FLAG, gdb_array_mark_flag): Now ptrdiff_t, not EMACS_INT.
1938 (init_cmdargs, Fdump_emacs):
1939 Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts.
1940 (Fkill_emacs): Don't assume fixnum fits in int; instead, take just
1941 the bottom (typically) 32 bits of the fixnum.
1942 * eval.c (specpdl_size, call_debugger):
1943 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
1944 (when_entered_debugger, Fbacktrace_debug):
1945 Don't assume fixnum can fit in int.
1946 (Fdefvaralias, Fdefvar): Do not attempt to compute the address of
1947 the object just before a buffer; this is not portable.
1948 (FletX, Flet, Funwind_protect, do_autoload, Feval, funcall_lambda)
1949 (grow_specpdl, unbind_to):
1950 Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts.
1951 (Fapply, apply_lambda): Don't assume ptrdiff_t can hold fixnum.
1952 (grow_specpdl): Simplify allocation by using xpalloc.
1953 (Fprog1, Fprog2): Don't assume list length fits in int. Simplify.
1954 * fileio.c (Ffind_file_name_handler, Fcopy_file, Frename_file)
1955 (Finsert_file_contents, Fwrite_region, Fdo_auto_save):
1956 Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts.
1957 (Ffind_file_name_handler, non_regular_inserted, Finsert_file_contents)
1958 (a_write, e_write):
1959 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
1960 (Fcopy_file, non_regular_nbytes, read_non_regular)
1961 (Finsert_file_contents):
1962 Use int, not EMACS_INT, where int is wide enough.
1963 (READ_BUF_SIZE): Verify that it fits in int.
1964 (Finsert_file_contents): Check that counts are in proper range,
1965 rather than assuming fixnums fit into ptrdiff_t etc.
1966 Don't assume fixnums fit into int.
1967 * floatfns.c (Fexpt): Avoid undefined signed * signed overflow.
1968 * fns.c (Fcompare_strings, Fstring_lessp, struct textprop_rec, concat)
1969 (string_char_byte_cache_charpos, string_char_byte_cache_bytepos)
1970 (string_char_to_byte, string_byte_to_char)
1971 (string_make_multibyte, string_to_multibyte)
1972 (string_make_unibyte, Fstring_as_unibyte, Fstring_as_multibyte)
1973 (Fstring_to_unibyte, Fsubstring, Fsubstring_no_properties)
1974 (substring_both, Fdelete, internal_equal, Ffillarray)
1975 (Fclear_string, mapcar1)
1976 (Fbase64_encode_region, Fbase64_encode_string, base64_encode_1)
1977 (Fbase64_decode_region, Fbase64_decode_string, base64_decode_1)
1978 (larger_vector, make_hash_table, maybe_resize_hash_table)
1979 (hash_lookup, hash_remove_from_table, hash_clear, sweep_weak_table)
1980 (Fmaphash, secure_hash):
1981 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
1982 (concat): Check for string index and length overflow.
1983 (Fmapconcat): Don't assume fixnums fit into ptrdiff_t.
1984 (Frequire):
1985 Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts.
1986 (larger_vector): New API (vec, incr_min, size_max) replaces old
1987 one (vec, new_size, init). This catches size overflow.
1988 INIT was removed because it was always Qnil.
1989 All callers changed.
1990 (INDEX_SIZE_BOUND): New macro, which calculates more precisely
1991 the upper bound on a hash table index size.
1992 (make_hash_table, maybe_resize_hash_table): Use it.
1993 (secure_hash): Computer start_byte and end_byte only after
1994 they're known to be in ptrdiff_t range.
1995 * font.c (font_intern_prop, font_at, font_range, Ffont_shape_gstring)
1996 (Ffont_get_glyphs, Ffont_at):
1997 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
1998 (font_style_to_value, font_prop_validate_style, font_expand_wildcards)
1999 (Flist_fonts, Fopen_font):
2000 Don't assume fixnum can fit in int.
2001 (check_gstring): Don't assume index can fit in int.
2002 (font_match_p): Check that fixnum is a character, not a nonnegative
2003 fixnum, since the later code needs to stuff it into an int.
2004 (font_find_for_lface): Use SAFE_ALLOCA_LISP, not alloca.
2005 (font_fill_lglyph_metrics): Use unsigned, not EMACS_INT, to avoid
2006 conversion overflow issues.
2007 (Fopen_font): Check for integer out of range.
2008 (Ffont_get_glyphs): Don't assume index can fit in int.
2009 * font.h: Adjust decls to match defn changes elsewhere.
2010 * fontset.c (reorder_font_vector): Redo score calculation to avoid
2011 integer overflow.
2012 (num_auto_fontsets, fontset_from_font): Use ptrdiff_t, not
2013 printmax_t, where ptrdiff_t is wide enough.
2014 (Finternal_char_font):
2015 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
2016 * frame.c (Fset_mouse_position, Fset_mouse_pixel_position)
2017 (Fset_frame_height, Fset_frame_width, Fset_frame_size)
2018 (Fset_frame_position, x_set_frame_parameters)
2019 (x_set_line_spacing, x_set_border_width)
2020 (x_set_internal_border_width, x_set_alpha, x_figure_window_size):
2021 Check that fixnums are in proper range for system types.
2022 (frame_name_fnn_p, Fframe_parameter, Fmodify_frame_parameters):
2023 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
2024 (Fmodify_frame_parameters): Don't assume fixnum fits in int.
2025 Use SAFE_ALLOCA_LISP, not alloca.
2026 * frame.h (struct frame): Use intptr_t, not EMACS_INT, where
2027 intptr_t is wide enough.
2028 * fringe.c (lookup_fringe_bitmap, get_logical_fringe_bitmap)
2029 (Fdefine_fringe_bitmap): Don't assume fixnum fits in int.
2030 (Ffringe_bitmaps_at_pos): Don't assume index fits in int.
2031 Check for fixnum out of range.
2032 * ftfont.c (ftfont_list): Don't assume index fits in int.
2033 Check that fixnums are in proper range for system types.
2034 (ftfont_shape_by_flt):
2035 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
2036 * gnutls.c (emacs_gnutls_write, emacs_gnutls_read):
2037 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
2038 (Fgnutls_error_fatalp, Fgnutls_error_string, Fgnutls_boot):
2039 Check that fixnums are in proper range for system types.
2040 * gnutls.h: Adjust decls to match defn changes elsewhere.
2041 * gtkutil.c (xg_dialog_run):
2042 Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts.
2043 (update_frame_tool_bar):
2044 Check that fixnums are in proper range for system types.
2045 * image.c (parse_image_spec): Redo count calculation to avoid overflow.
2046 (lookup_image): Check that fixnums are in range for system types.
2047 * indent.c (last_known_column, last_known_column_point):
2048 (current_column_bol_cache):
2049 (skip_invisible, current_column, check_display_width):
2050 (check_display_width, scan_for_column, current_column_1)
2051 (Findent_to, Fcurrent_indentation, position_indentation)
2052 (indented_beyond_p, Fmove_to_column, compute_motion):
2053 (Fcompute_motion, Fvertical_motion):
2054 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
2055 (last_known_column_modified): Use EMACS_INT, not int.
2056 (check_display_width):
2057 (Fcompute_motion):
2058 Check that fixnums and floats are in proper range for system types.
2059 (compute_motion): Don't assume index or fixnum fits in int.
2060 (compute_motion, Fcompute_motion):
2061 Use int, not EMACS_INT, when it is wide enough.
2062 (vmotion): Omit local var start_hpos that is always 0; that way
2063 we don't need to worry about overflow in expressions involving it.
2064 * indent.h: Adjust decls to match defn changes elsewhere.
2065 (struct position):
2066 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
2067 Use int, not EMACS_INT, where int is wide enough.
2068 Remove unused members ovstring_chars_done and tab_offset;
2069 all uses removed.
2070 * insdel.c (move_gap, move_gap_both, gap_left, gap_right)
2071 (adjust_markers_for_delete, adjust_markers_for_insert, adjust_point)
2072 (adjust_markers_for_replace, make_gap_larger, make_gap_smaller)
2073 (make_gap, copy_text, insert, insert_and_inherit)
2074 (insert_before_markers, insert_before_markers_and_inherit)
2075 (insert_1, count_combining_before, count_combining_after)
2076 (insert_1_both, insert_from_string)
2077 (insert_from_string_before_markers, insert_from_string_1)
2078 (insert_from_gap, insert_from_buffer, insert_from_buffer_1)
2079 (adjust_after_replace, adjust_after_insert, replace_range)
2080 (replace_range_2, del_range, del_range_1, del_range_byte)
2081 (del_range_both, del_range_2, modify_region)
2082 (prepare_to_modify_buffer, signal_before_change)
2083 (signal_after_change, Fcombine_after_change_execute):
2084 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
2085 * intervals.c (traverse_intervals, rotate_right, rotate_left)
2086 (balance_an_interval, split_interval_right, split_interval_left)
2087 (find_interval, next_interval, update_interval)
2088 (adjust_intervals_for_insertion, delete_node, delete_interval)
2089 (interval_deletion_adjustment, adjust_intervals_for_deletion)
2090 (static_offset_intervals, offset_intervals)
2091 (merge_interval_right, merge_interval_left, make_new_interval)
2092 (graft_intervals_into_buffer, temp_set_point_both)
2093 (temp_set_point, set_point, adjust_for_invis_intang)
2094 (set_point_both, move_if_not_intangible, get_property_and_range)
2095 (get_local_map, copy_intervals, copy_intervals_to_string)
2096 (compare_string_intervals, set_intervals_multibyte_1):
2097 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
2098 * intervals.h: Adjust decls to match defn changes elsewhere.
2099 (struct interval):
2100 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
2101 * keyboard.c (this_command_key_count, this_single_command_key_start)
2102 (before_command_key_count, before_command_echo_length, echo_now)
2103 (echo_length, recursive_edit_1, Frecursive_edit, Ftrack_mouse)
2104 (command_loop_1, safe_run_hooks, read_char, timer_check_2)
2105 (menu_item_eval_property, read_key_sequence, Fread_key_sequence)
2106 (Fread_key_sequence_vector, Fexecute_extended_command, Fsuspend_emacs):
2107 Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts.
2108 (last_non_minibuf_size, last_point_position, echo_truncate)
2109 (command_loop_1, adjust_point_for_property, read_char, gen_help_event)
2110 (make_lispy_position, make_lispy_event, parse_modifiers_uncached)
2111 (parse_modifiers, modify_event_symbol, Fexecute_extended_command)
2112 (stuff_buffered_input):
2113 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
2114 (last_auto_save, command_loop_1, read_char):
2115 Use EMACS_INT, not int, to avoid integer overflow.
2116 (record_char): Avoid overflow in total_keys computation.
2117 (parse_modifiers_uncached): Redo index calculation to avoid overflow.
2118 * keyboard.h: Adjust decls to match defn changes elsewhere.
2119 * keymap.c (Fdefine_key, Fcurrent_active_maps, accessible_keymaps_1)
2120 (Fkey_description, Fdescribe_vector, Flookup_key):
2121 Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts.
2122 (click_position): New function, to check that positions are in range.
2123 (Fcurrent_active_maps):
2124 (describe_command):
2125 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
2126 (Faccessible_keymaps, Fkey_description):
2127 (preferred_sequence_p):
2128 Don't assume fixnum can fit into int.
2129 (Fkey_description): Use SAFE_ALLOCA_LISP, not alloca.
2130 Check for integer overflow in size calculations.
2131 (Ftext_char_description): Use CHECK_CHARACTER, not CHECK_NUMBER, to
2132 avoid mishandling large integers.
2133 * lisp.h: Adjust decls to match defn changes elsewhere.
2134 (ARRAY_MARK_FLAG, PSEUDOVECTOR_FLAG, struct Lisp_String)
2135 (struct vectorlike_header, struct Lisp_Subr, struct Lisp_Hash_Table)
2136 (struct Lisp_Marker):
2137 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
2138 (clip_to_bounds): Now an inline function, moved here from editfns.c.
2139 (GLYPH_CODE_P): Check for overflow in system types, subsuming the
2140 need for GLYPH_CODE_CHAR_VALID_P and doing proper checking ourselves.
2141 All callers changed.
2142 (GLYPH_CODE_CHAR, GLYPH_CODE_FACE):
2143 Assume the arg has valid form, since it always does.
2144 (TYPE_RANGED_INTEGERP): Avoid bug when checking against a wide
2145 unsigned integer system type.
2146 (CHECK_RANGED_INTEGER, CHECK_TYPE_RANGED_INTEGER): New macros.
2147 (struct catchtag, specpdl_size, SPECPDL_INDEX, USE_SAFE_ALLOCA):
2148 Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts.
2149 (struct catchtag): Use EMACS_INT, not int, since it may be a fixnum.
2150 (duration_to_sec_usec): New decl.
2151 * lread.c (read_from_string_index, read_from_string_index_byte)
2152 (read_from_string_limit, readchar, unreadchar, openp)
2153 (read_internal_start, read1, oblookup):
2154 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
2155 (Fload, readevalloop, Feval_buffer, Feval_region):
2156 Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts.
2157 (openp): Check for out-of-range argument to 'access'.
2158 (read1): Use int, not EMACS_INT, where int is wide enough.
2159 Don't assume fixnum fits into int.
2160 Fix off-by-one error that can read outside a buffer.
2161 (read_filtered_event): Use duration_to_sec_usec
2162 to do proper overflow checking on durations.
2163 * macros.c (Fstart_kbd_macro): Use xpalloc to check for overflow
2164 in size calculation.
2165 (Fexecute_kbd_macro):
2166 Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts.
2167 * marker.c (cached_charpos, cached_bytepos, CONSIDER)
2168 (byte_char_debug_check, buf_charpos_to_bytepos, verify_bytepos)
2169 (buf_bytepos_to_charpos, Fset_marker, set_marker_restricted)
2170 (set_marker_both, set_marker_restricted_both, marker_position)
2171 (marker_byte_position, Fbuffer_has_markers_at):
2172 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
2173 (Fset_marker, set_marker_restricted): Don't assume fixnum fits in int.
2174 * menu.c (ensure_menu_items): Rename from grow_menu_items.
2175 It now merely ensures that the menu is large enough, without
2176 necessarily growing it, as this avoids some integer overflow issues.
2177 All callers changed.
2178 (keymap_panes, parse_single_submenu, Fx_popup_menu):
2179 Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts.
2180 (parse_single_submenu, Fx_popup_menu): Don't assume fixnum fits in int.
2181 Use SAFE_ALLOCA_LISP, not alloca.
2182 (find_and_return_menu_selection): Avoid unnecessary casts of pointers
2183 to EMACS_INT. Check that fixnums are in proper range for system types.
2184 * minibuf.c (minibuf_prompt_width, string_to_object)
2185 (Fminibuffer_contents, Fminibuffer_contents_no_properties)
2186 (Fminibuffer_completion_contents, Ftry_completion, Fall_completions):
2187 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
2188 (get_minibuffer, read_minibuf_unwind):
2189 Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts.
2190 (read_minibuf): Omit unnecessary arg BACKUP_N, which is always nil;
2191 this simplifies overflow checking. All callers changed.
2192 (read_minibuf, Fread_buffer, Ftry_completion, Fall_completions)
2193 (Ftest_completion):
2194 Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts.
2195 * nsfns.m (check_ns_display_info): Don't assume fixnum fits in long.
2196 (x_set_menu_bar_lines, x_set_tool_bar_lines, Fx_create_frame):
2197 Check that fixnums are in proper range for system types.
2198 (Fx_create_frame, Fx_show_tip):
2199 Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts.
2200 * nsfont.m (ns_findfonts, nsfont_list_family):
2201 Don't assume fixnum fits in long.
2202 * nsmenu.m (ns_update_menubar, ns_menu_show, ns_popup_dialog):
2203 Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts.
2204 (ns_update_menubar): Use intptr_t, not EMACS_INT, when intptr_t is
2205 wide enough.
2206 * nsselect.m (ns_get_local_selection, clean_local_selection_data):
2207 Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts.
2208 * print.c (print_buffer_size, print_buffer_pos, print_buffer_pos_byte)
2209 (PRINTDECLARE, PRINTPREPARE):
2210 (strout, print_string):
2211 (print, print_preprocess, print_check_string_charset_prop)
2212 (print_object):
2213 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
2214 (PRINTDECLARE):
2215 (temp_output_buffer_setup, Fprin1_to_string, print_object):
2216 Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts.
2217 (PRINTPREPARE): Use int, not ptrdiff_t, where int is wide enough.
2218 (printchar, strout): Use xpalloc to catch size calculation overflow.
2219 (Fexternal_debugging_output): Don't overflow EMACS_INT->int conversion.
2220 (print_error_message): Use SAFE_ALLOCA, not alloca.
2221 (print_object): Use int, not EMACS_INT, where int is wide enough.
2222 (print_depth, new_backquote_output, print_number_index):
2223 Use ptrdiff_t, not int, where int might not be wide enough.
2224 * process.c (Fdelete_process): Don't assume pid fits into EMACS_INT.
2225 (Fset_process_window_size, Fformat_network_address)
2226 (get_lisp_to_sockaddr_size, set_socket_option, Fmake_network_process)
2227 (sigchld_handler):
2228 Check that fixnums are in proper range for system types.
2229 (Fsignal_process): Simplify by avoiding a goto.
2230 Check for process-ids out of pid_t range rather than relying on
2231 undefined behavior.
2232 (process_tick, update_tick): Use EMACS_INT, not int.
2233 (Fformat_network_address, read_process_output, send_process)
2234 (Fprocess_send_region, status_notify):
2235 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
2236 (Fformat_network_address, Fmake_serial_process, Fmake_network_process)
2237 (wait_reading_process_output, read_process_output, exec_sentinel):
2238 Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts.
2239 (conv_lisp_to_sockaddr): Don't assume fixnums fit into int.
2240 (Faccept_process_output): Use duration_to_sec_usec to do proper
2241 overflow checking on durations.
2242 (emacs_get_tty_pgrp, Fprocess_running_child_p, process_send_signal):
2243 Don't assume pid_t fits in int.
2244 * process.h (struct Lisp_Process): Members tick and update_tick
2245 are now of type EMACS_INT, not int.
2246 * puresize.h (PURESIZE_RATIO): Shrink this to 8/6 on 32-bit hosts
2247 configured --with-wide-int.
2248 * scroll.c (calculate_scrolling, calculate_direct_scrolling)
2249 (line_ins_del): Use int, not EMACS_INT, where int is wide enough.
2250 * search.c (looking_at_1, string_match_1):
2251 (fast_string_match, fast_c_string_match_ignore_case)
2252 (fast_string_match_ignore_case, fast_looking_at, scan_buffer)
2253 (scan_newline, find_before_next_newline, search_command)
2254 (trivial_regexp_p, search_buffer, simple_search, boyer_moore)
2255 (set_search_regs, wordify):
2256 (Freplace_match):
2257 (Fmatch_data):
2258 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
2259 (string_match_1, search_buffer, set_search_regs):
2260 (Fmatch_data):
2261 Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts.
2262 (wordify): Check for overflow in size calculation.
2263 (Freplace_match): Avoid potential buffer overflow in search_regs.start.
2264 (Fset_match_data): Don't assume fixnum fits in ptrdiff_t.
2265 Check that fixnums are in proper range for system types.
2266 * sound.c (struct sound_device)
2267 (wav_play, au_play, vox_write, alsa_period_size, alsa_write):
2268 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
2269 (Fplay_sound_internal):
2270 Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts.
2271 * syntax.c (struct lisp_parse_state, find_start_modiff)
2272 (Finternal_describe_syntax_value, scan_lists, scan_sexps_forward):
2273 (Fparse_partial_sexp):
2274 Don't assume fixnums can fit in int.
2275 (struct lisp_parse_state, find_start_pos, find_start_value)
2276 (find_start_value_byte, find_start_begv)
2277 (update_syntax_table, char_quoted, dec_bytepos)
2278 (find_defun_start, prev_char_comend_first, back_comment):
2279 (scan_words, skip_chars, skip_syntaxes, forw_comment, Fforward_comment)
2280 (scan_lists, Fbackward_prefix_chars, scan_sexps_forward):
2281 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
2282 (Finternal_describe_syntax_value): Check that match_lisp is a
2283 character, not an integer, since the code stuffs it into int.
2284 (scan_words, scan_sexps_forward):
2285 Check that fixnums are in proper range for system types.
2286 (Fforward_word):
2287 Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts.
2288 (scan_sexps_forward):
2289 Use CHARACTERP, not INTEGERP, since the value must fit into int.
2290 (Fparse_partial_sexp): Fix doc; element 8 is not ignored.
2291 * syntax.h: Adjust decls to match defn changes elsewhere.
2292 (struct gl_state_s):
2293 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
2294 (SETUP_SYNTAX_TABLE_FOR_OBJECT): Use PTRDIFF_MAX, not
2295 MOST_POSITIVE_FIXNUM.
2296 * sysdep.c (wait_for_termination_1, wait_for_termination)
2297 (interruptible_wait_for_termination, mkdir):
2298 Don't assume pid_t fits in int; on 64-bit AIX pid_t is 64-bit.
2299 (emacs_read, emacs_write):
2300 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
2301 (system_process_attributes): Don't assume uid_t, gid_t, EMACS_INT,
2302 and double all fit in int.
2303 * term.c (set_tty_color_mode):
2304 Check that fixnums are in proper range for system types.
2305 * termhooks.h (struct input_event):
2306 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
2307 * textprop.c (validate_interval_range, interval_of)
2308 (Fadd_text_properties, set_text_properties_1)
2309 (Fremove_text_properties, Fremove_list_of_text_properties)
2310 (Ftext_property_any, Ftext_property_not_all)
2311 (copy_text_properties, text_property_list, extend_property_ranges)
2312 (verify_interval_modification):
2313 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
2314 (Fnext_single_char_property_change)
2315 (Fprevious_single_char_property_change):
2316 Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts.
2317 (copy_text_properties):
2318 Check for integer overflow in index calculation.
2319 * undo.c (last_boundary_position, record_point, record_insert)
2320 (record_delete, record_marker_adjustment, record_change)
2321 (record_property_change):
2322 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
2323 (truncate_undo_list, Fprimitive_undo): Don't assume fixnum fits in int.
2324 Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts.
2325 * w32fns.c (Fx_create_frame, x_create_tip_frame, Fx_show_tip)
2326 (Fx_hide_tip, Fx_file_dialog):
2327 * w32menu.c (set_frame_menubar):
2328 Use ptrdiff_t, not int, for consistency with rest of code.
2329 * window.c (window_scroll_preserve_hpos, window_scroll_preserve_vpos)
2330 (select_window, Fdelete_other_windows_internal)
2331 (window_scroll_pixel_based, window_scroll_line_based)
2332 (Frecenter, Fset_window_configuration):
2333 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
2334 (Fset_window_hscroll, run_window_configuration_change_hook)
2335 (set_window_buffer, temp_output_buffer_show, scroll_command)
2336 (Fscroll_other_window, Frecenter):
2337 Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts.
2338 (Fwindow_line_height, window_scroll, Fscroll_left, Fscroll_right):
2339 Don't assume fixnum fits in int.
2340 (Fset_window_scroll_bars):
2341 Check that fixnums are in proper range for system types.
2342 * xdisp.c (help_echo_pos, pos_visible_p, string_pos_nchars_ahead)
2343 (string_pos, c_string_pos, number_of_chars, init_iterator)
2344 (in_ellipses_for_invisible_text_p, init_from_display_pos)
2345 (compute_stop_pos, next_overlay_change, compute_display_string_pos)
2346 (compute_display_string_end, handle_face_prop)
2347 (face_before_or_after_it_pos, handle_invisible_prop)
2348 (handle_display_prop, handle_display_spec, handle_single_display_spec)
2349 (display_prop_intangible_p, string_buffer_position_lim)
2350 (string_buffer_position, handle_composition_prop, load_overlay_strings)
2351 (get_overlay_strings_1, get_overlay_strings)
2352 (iterate_out_of_display_property, forward_to_next_line_start)
2353 (back_to_previous_visible_line_start, reseat, reseat_to_string)
2354 (get_next_display_element, set_iterator_to_next)
2355 (get_visually_first_element, compute_stop_pos_backwards)
2356 (handle_stop_backwards, next_element_from_buffer)
2357 (move_it_in_display_line_to, move_it_in_display_line)
2358 (move_it_to, move_it_vertically_backward, move_it_by_lines)
2359 (add_to_log, message_dolog, message_log_check_duplicate)
2360 (message2, message2_nolog, message3, message3_nolog
2361 (with_echo_area_buffer, display_echo_area_1, resize_mini_window_1)
2362 (current_message_1, truncate_echo_area, truncate_message_1)
2363 (set_message, set_message_1, store_mode_line_noprop)
2364 (hscroll_window_tree, debug_delta, debug_delta_bytes, debug_end_vpos)
2365 (text_outside_line_unchanged_p, check_point_in_composition)
2366 (reconsider_clip_changes)
2367 (redisplay_internal, set_cursor_from_row, try_scrolling)
2368 (try_cursor_movement, set_vertical_scroll_bar, redisplay_window)
2369 (redisplay_window, find_last_unchanged_at_beg_row)
2370 (find_first_unchanged_at_end_row, row_containing_pos, try_window_id)
2371 (trailing_whitespace_p, find_row_edges, display_line)
2372 (RECORD_MAX_MIN_POS, Fcurrent_bidi_paragraph_direction)
2373 (display_mode_element, store_mode_line_string)
2374 (pint2str, pint2hrstr, decode_mode_spec)
2375 (display_count_lines, display_string, draw_glyphs)
2376 (x_produce_glyphs, x_insert_glyphs)
2377 (rows_from_pos_range, mouse_face_from_buffer_pos)
2378 (fast_find_string_pos, mouse_face_from_string_pos)
2379 (note_mode_line_or_margin_highlight, note_mouse_highlight):
2380 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
2381 (safe_call, init_from_display_pos, handle_fontified_prop)
2382 (handle_single_display_spec, load_overlay_strings)
2383 (with_echo_area_buffer, setup_echo_area_for_printing)
2384 (display_echo_area, echo_area_display)
2385 (x_consider_frame_title, prepare_menu_bars, update_menu_bar)
2386 (update_tool_bar, hscroll_window_tree, redisplay_internal)
2387 (redisplay_window, dump_glyph_row, display_mode_line)
2388 (Fformat_mode_line, decode_mode_spec, on_hot_spot_p):
2389 (handle_display_spec, display_prop_string_p):
2390 Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts.
2391 (handle_single_display_spec, build_desired_tool_bar_string)
2392 (redisplay_tool_bar, scroll_window_tree, Fdump_glyph_matrix)
2393 (get_specified_cursor_type):
2394 Check that fixnums are in proper range for system types.
2395 (struct overlay_entry, resize_mini_window, Fdump_glyph_row)
2396 (Flookup_image_map):
2397 Don't assume fixnums fit in int.
2398 (compare_overlay_entries):
2399 Avoid mishandling comparisons due to subtraction overflow.
2400 (load_overlay_strings): Use SAFE_NALLOCA, not alloca.
2401 (last_escape_glyph_face_id, last_glyphless_glyph_face_id):
2402 (handle_tool_bar_click):
2403 Use int, not unsigned, since we prefer signed and the signedness
2404 doesn't matter here.
2405 (get_next_display_element, next_element_from_display_vector):
2406 Use int, not EMACS_INT, when int is wide enough.
2407 (start_hourglass): Use duration_to_sec_usec to do proper
2408 overflow checking on durations.
2409 * xfaces.c (Fbitmap_spec_p):
2410 Check that fixnums are in proper range for system types.
2411 (compare_fonts_by_sort_order):
2412 Avoid mishandling comparisons due to subtraction overflow.
2413 (Fx_family_fonts, realize_basic_faces):
2414 Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts.
2415 (Fx_family_fonts):
2416 Don't assume fixnum fits in int.
2417 Use SAFE_ALLOCA_LISP, not alloca.
2418 (merge_face_heights): Remove unnecessary cast to EMACS_INT.
2419 (Finternal_make_lisp_face): Don't allocate more than MAX_FACE_ID.
2420 (face_at_buffer_position, face_for_overlay_string)
2421 (face_at_string_position):
2422 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
2423 (merge_faces): Use int, not EMACS_INT, where int is wide enough.
2424 * xfns.c (x_set_menu_bar_lines, x_set_tool_bar_lines, x_icon_verify)
2425 (Fx_show_tip):
2426 Check that fixnums are in proper range for system types.
2427 (Fx_create_frame, x_create_tip_frame, Fx_show_tip)
2428 (Fx_hide_tip, Fx_file_dialog, Fx_select_font):
2429 Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts.
2430 (Fx_change_window_property): Don't assume fixnums fit in int.
2431 * xfont.c (xfont_chars_supported):
2432 Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts.
2433 * xmenu.c (Fx_popup_dialog, set_frame_menubar)
2434 (create_and_show_popup_menu, create_and_show_dialog, xmenu_show):
2435 Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts.
2436 * xml.c (parse_region):
2437 * xrdb.c (magic_file_p):
2438 Use ptrdiff_t, not EMACS_INT, where ptrdiff_t is wide enough.
2439 * xselect.c (TRACE1): Don't assume pid_t promotes to int.
2440 (x_get_local_selection, x_reply_selection_request)
2441 (x_handle_selection_request, wait_for_property_change):
2442 Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts.
2443 (selection_data_to_lisp_data): Use short, not EMACS_INT, where
2444 short is wide enough.
2445 (x_send_client_event): Don't assume fixnum fits in int.
2446 * xterm.c (x_x_to_emacs_modifiers):
2447 Don't assume EMACS_INT overflows nicely into int.
2448 (x_emacs_to_x_modifiers): Use EMACS_INT, not int, because values
2449 may come from Lisp.
2450 (handle_one_xevent): NATNUMP can eval its arg twice.
2451 (x_connection_closed):
2452 Use ptrdiff_t, not int, to avoid needless 32-bit limit on 64-bit hosts.
2453 * xterm.h: Adjust decls to match defn changes elsewhere.
2454 (struct scroll_bar): Use struct vectorlike_header
2455 rather than rolling our own approximation.
2456 (SCROLL_BAR_VEC_SIZE): Remove; not used.
2457
2458 2012-05-25 Glenn Morris <rgm@gnu.org>
2459
2460 * lisp.mk (lisp): Update for more files being compiled now.
2461
2462 2012-05-25 Stefan Monnier <monnier@iro.umontreal.ca>
2463
2464 * lread.c: Remove `read_pure' which makes no difference.
2465 (read_pure): Remove var.
2466 (unreadpure): Remove function.
2467 (readevalloop): Don't call read_list with -1 flag.
2468 (read1, read_vector): Don't test read_pure any more.
2469 (read_list): Simplify.
2470
2471 * fileio.c, character.h: Minor style tweaks.
2472
2473 2012-05-24 Dmitry Antipov <dmantipov@yandex.ru>
2474
2475 * window.h (clip_changed): Remove useless declaration.
2476
2477 2012-05-22 Juanma Barranquero <lekktu@gmail.com>
2478
2479 * makefile.w32-in: Follow-up to 2012-05-22T16:20:27Z!eggert@cs.ucla.edu.
2480 (TAGS, TAGS-gmake, CONFIG_H): Remove further references to m/intel386.h.
2481
2482 2012-05-22 Paul Eggert <eggert@cs.ucla.edu>
2483
2484 Remove src/m/*.
2485 This directory predates autoconf and is no longer needed nowadays.
2486 Move its few remaining bits of functionality to where they're needed.
2487 * m/README, m/alpha.h, m/amdx86-64.h, m/ia64.h, m/ibmrs6000.h:
2488 * m/ibms390x.h, m/intel386.h, m/m68k.h, m/macppc.h, m/sparc.h:
2489 * m/template.h: Remove.
2490 * Makefile.in (M_FILE): Remove. All uses removed.
2491 * alloc.c (POINTERS_MIGHT_HIDE_IN_OBJECTS):
2492 * lisp.h (USE_LSB_TAG):
2493 * mem-limits.h (EXCEEDS_LISP_PTR):
2494 Use VAL_MAX, not VALBITS, in #if.
2495 * lisp.h (EMACS_INT_MAX): New macro, useful in #if.
2496 (EMACS_UINT): Define unconditionally now.
2497 (BITS_PER_CHAR, BITS_PER_SHORT, BITS_PER_INT, BITS_PER_LONG)
2498 (BITS_PER_EMACS_INT): New constants, replacing
2499 what used to be in config.h, but not useful in #if.
2500 (GCTYPEBITS, VALBITS): Define unconditionally, since m/* files don't
2501 define them any more.
2502 (VAL_MAX): New macro.
2503 (VALMASK): Use it.
2504 * puresize.h (PURESIZE_RATIO): Use EMACS_INT_MAX, not
2505 BITS_PER_EMACS_INT, in #if.
2506 * s/aix4-2.h (BROKEN_FIONREAD, BROKEN_SIGAIO, BROKEN_SIGPTY)
2507 (BROKEN_SIGPOLL): Move here from m/ibmrs6000.h, which was removed.
2508 * s/gnu-linux.h (ULIMIT_BREAK_VALUE) [__i386__]:
2509 * s/ms-w32.h (DATA_START):
2510 Move here from removed file m/intel386.h.
2511 * s/gnu.h (NLIST_STRUCT): Remove undef; 'configure' does this.
2512 * s/irix6-5.h (_LP64): Remove; lisp.h no longer needs this.
2513
2514 2012-05-21 Paul Eggert <eggert@cs.ucla.edu>
2515
2516 Assume C89 or later.
2517 * alloc.c, buffer.c, lisp.h: Replace POINTER_TYPE with void.
2518 * alloc.c (overrun_check_malloc, overrun_check_realloc, xmalloc)
2519 (xrealloc):
2520 * buffer.c (mmap_free_1, mmap_enlarge): Omit needless casts.
2521 * editfns.c, fns.c, gmalloc.c, insdel.c, sysdep.c, termcap.c (NULL):
2522 * textprop.c, tparam.c (NULL): Remove.
2523 * ralloc.c, vm-limit.c (POINTER): Assume void * works.
2524 * regex.c (SIGN_EXTEND_CHAR): Assume signed char works.
2525 * regex.h (_RE_ARGS): Remove. All uses rewritten to use prototypes.
2526 * unexelf.c (ElfBitsW): Assume c89 preprocessor or better.
2527 * xterm.c (input_signal_count): Assume volatile works.
2528
2529 2012-05-21 Ken Brown <kbrown@cornell.edu>
2530
2531 * xgselect.c (xg_select): Fix first argument in call to 'select'
2532 (bug#11508).
2533
2534 2012-05-20 Ken Brown <kbrown@cornell.edu>
2535
2536 * gmalloc.c (_free_internal_nolock, _realloc_internal_nolock)
2537 [CYGWIN]: Cast ptr to (char *) before comparing to _heapbase.
2538
2539 2012-05-19 Ken Brown <kbrown@cornell.edu>
2540
2541 * xfns.c (x_in_use): Remove `static' qualifier.
2542 * xterm.h (x_in_use): Declare.
2543 * xgselect.c: Include xterm.h.
2544 (xg_select): Test `x_in_use' instead of `inhibit_window_system'
2545 and `display_arg' (bug#9754).
2546
2547 2012-05-19 Paul Eggert <eggert@cs.ucla.edu>
2548
2549 * s/ms-w32.h (HAVE_GETDOMAINNAME): Remove; not needed.
2550
2551 * m/vax.h: Remove; no longer needed since HAVE_FTIME is being removed.
2552 * s/ms-w32.h (HAVE_FTIME): Remove; not needed.
2553
2554 2012-05-18 Eli Zaretskii <eliz@gnu.org>
2555
2556 Fix compilation with -DGLYPH_DEBUG=1 on MS-Windows.
2557
2558 * w32term.c [GLYPH_DEBUG]: Add prototype for x_check_font.
2559 (x_check_font) [GLYPH_DEBUG]: New function, copied from xterm.c
2560
2561 * w32fns.c (unwind_create_frame) [GLYPH_DEBUG]: Fix broken
2562 reference to image_cache->refcount.
2563 (x_create_tip_frame): Fix broken use of FRAME_IMAGE_CACHE.
2564
2565 2012-05-17 Juri Linkov <juri@jurta.org>
2566
2567 * search.c (Fword_search_regexp, Fword_search_backward)
2568 (Fword_search_forward, Fword_search_backward_lax)
2569 (Fword_search_forward_lax): Move functions to isearch.el
2570 (bug#10145, bug#11381).
2571
2572 2012-05-16 Paul Eggert <eggert@cs.ucla.edu>
2573
2574 * xgselect.c (xg_select): Just invoke 'select' if -nw (Bug#9754).
2575
2576 2012-05-15 Stefan Monnier <monnier@iro.umontreal.ca>
2577
2578 * lread.c (init_obarray): Declare Qt and Qnil as special.
2579
2580 2012-05-14 Glenn Morris <rgm@gnu.org>
2581
2582 * nsterm.m (ns_init_paths): Fix typo ("libexec" not "lib-exec").
2583 Put "libexec" before "bin", for the sake of init_callproc_1.
2584
2585 2012-05-14 Paul Eggert <eggert@cs.ucla.edu>
2586
2587 * keyboard.c (kbd_buffer_get_event) [!HAVE_DBUS]: Omit unused local.
2588
2589 * unexaix.c: Port to more-recent AIX compilers.
2590 (report_error, report_error_1, make_hdr, copy_sym)
2591 (mark_x, adjust_lnnoptrs, unrelocate_symbols):
2592 Make arguments const char *, not char *, to avoid violations of C
2593 standard and to fix some AIX warnings reported by Gilles Pion.
2594
2595 2012-05-14 Eli Zaretskii <eliz@gnu.org>
2596
2597 * xdisp.c (handle_stop): Don't call get_overlay_strings_1 if we
2598 already have overlays loaded.
2599 (handle_single_display_spec): Before returning without displaying
2600 fringe bitmap, synchronize the bidi iterator with the main display
2601 iterator, by calling iterate_out_of_display_property.
2602 (iterate_out_of_display_property): Detect buffer iteration by
2603 testing that it->string is a Lisp string.
2604 (get_next_display_element): When the current object is exhausted,
2605 and there's something on it->stack, call set_iterator_to_next to
2606 proceed with what's on the stack, instead of returning zero.
2607 (set_iterator_to_next): If called at the end of a Lisp string,
2608 proceed to consider_string_end without incrementing string
2609 position. Don't increment display vector index past the end of
2610 the display vector. (Bug#11417)
2611 (pos_visible_p): Don't report a position visible when move_it_to
2612 stopped at the last line of window, which happens to be scanned
2613 backwards by the bidi iteration. (Bug#11464)
2614
2615 2012-05-14 Eli Zaretskii <eliz@gnu.org>
2616
2617 * xdisp.c (handle_single_display_spec): Return 1 for left-margin
2618 and right-margin display specs even if the spec is invalid or we
2619 are on a TTY, and thus unable to display on the fringes.
2620 That's because the text with the property will not be displayed anyway,
2621 so we need to signal to the caller that this is a "replacing"
2622 display spec. This fixes display when the spec is invalid or we
2623 are on a TTY.
2624
2625 2012-05-14 Paul Eggert <eggert@cs.ucla.edu>
2626
2627 * unexaix.c (make_hdr): Fix typo in prototype.
2628 This bug broke the build on AIX. Problem reported by Gilles Pion.
2629
2630 2012-05-14 Michael Albinus <michael.albinus@gmx.de>
2631
2632 * keyboard.c (kbd_buffer_get_event): Read special events also in
2633 batch mode. (Bug#11415)
2634
2635 2012-05-12 Glenn Morris <rgm@gnu.org>
2636
2637 * ns.mk: Update for ns_appbindir no longer having trailing "/".
2638
2639 2012-05-12 Eli Zaretskii <eliz@gnu.org>
2640
2641 * lisp.mk (lisp): Add newcomment.elc.
2642
2643 2012-05-12 Glenn Morris <rgm@gnu.org>
2644
2645 * Makefile.in (MKDIR_P): New, set by configure.
2646 * ns.mk (${ns_appdir}, ${ns_appbindir}Emacs): Use $MKDIR_P.
2647
2648 2012-05-11 Paul Eggert <eggert@cs.ucla.edu>
2649
2650 Remove unused function hourglass_started.
2651 * dispextern.h (hourglass_started):
2652 * w32fns.c (hourglass_started):
2653 * xdisp.c (hourglass_started): Remove.
2654
2655 2012-05-10 Juanma Barranquero <lekktu@gmail.com>
2656
2657 * makefile.w32-in ($(BLD)/gmalloc.$(O), $(BLD)/w32menu.$(O)):
2658 Update dependencies.
2659
2660 2012-05-10 Paul Eggert <eggert@cs.ucla.edu>
2661
2662 * xgselect.c (xg_select): Put maxfds+1 into a var.
2663 This is slightly clearer, and pacifies Ubuntu 12.04 gcc.
2664
2665 * sound.c (DEFAULT_ALSA_SOUND_DEVICE): Define only if HAVE_ALSA.
2666
2667 2012-05-10 Dave Abrahams <dave@boostpro.com>
2668
2669 * filelock.c (syms_of_filelock): New boolean create-lockfiles.
2670 (lock_file): If create_lockfiles is 0, do nothing. (Bug#11227)
2671
2672 2012-05-09 Michael Albinus <michael.albinus@gmx.de>
2673
2674 * dbusbind.c (xd_registered_buses): New internal Lisp object.
2675 Rename all occurences of Vdbus_registered_buses to xd_registered_buses.
2676 (syms_of_dbusbind): Remove declaration of Vdbus_registered_buses.
2677 Initialize xd_registered_buses.
2678
2679 2012-05-09 Paul Eggert <eggert@cs.ucla.edu>
2680
2681 Untag more efficiently if USE_LSB_TAG.
2682 This is based on a proposal by YAMAMOTO Mitsuharu in
2683 <http://lists.gnu.org/archive/html/emacs-devel/2008-01/msg01876.html>.
2684 For an admittedly artificial (nth 8000 longlist) benchmark on
2685 Fedora 15 x86-64, this yields a 25% CPU speedup. Also, it shrinks
2686 Emacs's overall text size by 1%.
2687 * lisp.h (XUNTAG): New macro.
2688 (XCONS, XVECTOR, XSTRING, XSYMBOL, XFLOAT, XMISC, XPROCESS, XWINDOW)
2689 (XTERMINAL, XSUBR, XBUFFER, XCHAR_TABLE, XSUB_CHAR_TABLE, XBOOL_VECTOR)
2690 (XSETTYPED_PSEUDOVECTOR, XHASH_TABLE, TYPED_PSEUDOVECTORP): Use it.
2691 * eval.c (Fautoload):
2692 * font.h (XFONT_SPEC, XFONT_ENTITY, XFONT_OBJECT):
2693 * frame.h (XFRAME): Use XUNTAG.
2694
2695 Port recent dbusbind.c changes to 32-bit --with-wide-int.
2696 * dbusbind.c (xd_append_arg, xd_retrieve_arg, Fdbus_message_internal):
2697 Remove unportable assumptions about print widths of types like
2698 dbus_uint32_t.
2699 (xd_get_connection_address, Fdbus_init_bus): Cast Emacs integer to
2700 intptr_t when converting between pointer and integer, to avoid GCC
2701 warnings about wrong width.
2702
2703 2012-05-09 Eli Zaretskii <eliz@gnu.org>
2704
2705 * w32proc.c (new_child): Force Windows to reserve only 64KB of
2706 stack for each reader_thread, instead of defaulting to 8MB
2707 determined by the linker. This avoids failures in creating
2708 subprocesses on Windows 7, see the discussion in this thread:
2709 http://lists.gnu.org/archive/html/emacs-devel/2012-03/msg00119.html.
2710
2711 2012-05-07 Jérémy Compostella <jeremy.compostella@gmail.com>
2712
2713 Fix up display of the *Minibuf-0* buffer in the mini window.
2714 * keyboard.c (read_char): Don't clear the echo area if there's no
2715 message to clear.
2716 * xdisp.c (redisplay_internal): Redisplay the mini window (with the
2717 contents of *Minibuf-0*) if there's no message displayed in its stead.
2718
2719 2012-05-07 Michael Albinus <michael.albinus@gmx.de>
2720
2721 * dbusbind.c (XD_DEBUG_MESSAGE): Don't print message twice in
2722 batch mode.
2723
2724 2012-05-06 Chong Yidong <cyd@gnu.org>
2725
2726 * lisp.mk (lisp): Update.
2727
2728 2012-05-05 Jim Meyering <meyering@redhat.com>
2729
2730 * w32font.c (fill_in_logfont): NUL-terminate a string (Bug#11372).
2731
2732 2012-05-04 Stefan Monnier <monnier@iro.umontreal.ca>
2733
2734 * data.c (PUT_ERROR): New macro.
2735 (syms_of_data): Use it. Add new error type `user-error'.
2736 * undo.c (user_error): New function.
2737 (Fprimitive_undo): Use it.
2738 * print.c (print_error_message): Adjust print style for `user-error'.
2739 * keyboard.c (user_error): New function.
2740 (Fexit_recursive_edit, Fabort_recursive_edit): Use it.
2741
2742 2012-05-03 Paul Eggert <eggert@cs.ucla.edu>
2743
2744 Do not limit current-time-string to years 1000..9999.
2745 * editfns.c (TM_YEAR_IN_ASCTIME_RANGE): Remove.
2746 (Fcurrent_time_string): Support any year that is supported by the
2747 underlying localtime representation. Don't use asctime, as it
2748 has undefined behavior for years outside the range -999..9999.
2749
2750 2012-05-02 Paul Eggert <eggert@cs.ucla.edu>
2751
2752 Fix race conditions involving setenv, gmtime, localtime, asctime.
2753 Without this fix, interrupts could mess up code that uses these
2754 nonreentrant functions, since setting TZ invalidates existing
2755 tm_zone or tzname values, and since most of these functions return
2756 pointers to static storage.
2757 * editfns.c (format_time_string, Fdecode_time, Fencode_time)
2758 (Fcurrent_time_string, Fcurrent_time_zone, Fset_time_zone_rule):
2759 Grow the critical sections to include not just invoking
2760 localtime/gmtime, but also accessing these functions' results
2761 including their tm_zone values if any, and any related TZ setting.
2762 (format_time_string): Last arg is now struct tm *, not struct tm **,
2763 so that the struct tm is saved in the critical section.
2764 All callers changed. Simplify allocation of initial buffer, partly
2765 motivated by the fact that memory allocation needs to be outside
2766 the critical section.
2767
2768 2012-05-02 Dmitry Antipov <dmantipov@yandex.ru>
2769
2770 * intervals.c (adjust_intervals_for_insertion): Initialize `newi'
2771 with RESET_INTERVAL.
2772
2773 * buffer.c (Fget_buffer_create, Fmake_indirect_buffer):
2774 Remove duplicated buffer name initialization.
2775
2776 2012-05-02 Jim Meyering <jim@meyering.net>
2777
2778 * xterm.c (x_term_init): Use memcpy instead of strncpy (Bug#11373).
2779
2780 * xfns.c (x_window): Use xstrdup (Bug#11375).
2781
2782 2012-05-02 Eli Zaretskii <eliz@gnu.org>
2783
2784 * xdisp.c (pos_visible_p): If already at a newline from the
2785 display string before the 'while' loop, don't walk back the glyphs
2786 from it3.glyph_row. Solves assertion violation when the display
2787 string begins with a newline (egg.el). (Bug#11367)
2788
2789 2012-05-01 Stefan Monnier <monnier@iro.umontreal.ca>
2790
2791 * keyboard.c (Fexecute_extended_command, Vsuggest_key_bindings):
2792 Move to simple.el.
2793
2794 2012-05-01 Glenn Morris <rgm@gnu.org>
2795
2796 * syssignal.h: Remove reference to BROKEN_SIGINFO (last used in
2797 s/ptx4.h), BROKEN_SIGTSTP (last used in m/ustation.h, m/dpx2.h),
2798 and BROKEN_SIGURG (was in s/gnu-linux.h prior to 2008-02-10).
2799 All were removed before 23.1.
2800
2801 * dispnew.c: Remove HAVE_LIBNCURSES test;
2802 it is always true on relevant platforms.
2803
2804 * Makefile.in (LD_SWITCH_X_SITE_RPATH):
2805 Rename from LD_SWITCH_X_SITE_AUX_RPATH.
2806
2807 * Makefile.in (LD_SWITCH_X_SITE_AUX): Remove; no longer used.
2808
2809 2012-04-30 Andreas Schwab <schwab@linux-m68k.org>
2810
2811 * .gdbinit (xpr): Remove checks for no longer existing misc types.
2812 (xintfwd, xboolfwd, xobjfwd, xbufobjfwd, xkbobjfwd, xbuflocal):
2813 Remove.
2814
2815 2012-04-28 Paul Eggert <eggert@cs.ucla.edu>
2816
2817 Do not avoid creating empty evaporating overlays (Bug#9642).
2818 * buffer.c (Fmove_overlay): Revert the change of 2012-04-23.
2819 That is, do not delete an evaporating overlay if it becomes
2820 empty after its bounds are adjusted to fit within its buffer.
2821 This fix caused other problems, and I'm reverting it until we get
2822 to the bottom of them.
2823
2824 2012-04-27 Chong Yidong <cyd@gnu.org>
2825
2826 * xselect.c (x_convert_selection): Initialize a pointer (Bug#11315).
2827
2828 2012-04-27 Eli Zaretskii <eliz@gnu.org>
2829
2830 * xdisp.c (pos_visible_p): If the window start position is beyond
2831 ZV, start the display from buffer beginning. Prevents assertion
2832 violation in init_iterator when the minibuffer window is scrolled
2833 via the scroll bar.
2834
2835 * window.c (window_scroll_pixel_based): Likewise.
2836
2837 2012-04-27 Chong Yidong <cyd@gnu.org>
2838
2839 * keymap.c (where_is_internal): Doc fix (Bug#10872).
2840
2841 2012-04-27 Glenn Morris <rgm@gnu.org>
2842
2843 * fileio.c (Fcopy_file, Fset_file_selinux_context):
2844 Ignore ENOTSUP failures from setfilecon functions. (Bug#11245)
2845
2846 2012-04-27 Eli Zaretskii <eliz@gnu.org>
2847
2848 * dispnew.c (swap_glyph_pointers, copy_row_except_pointers):
2849 Don't overrun array limits of glyph row's used[] array. (Bug#11288)
2850
2851 2012-04-26 Eli Zaretskii <eliz@gnu.org>
2852
2853 * xdisp.c (IT_DISPLAYING_WHITESPACE): In addition to the loaded
2854 display element, check also the underlying string or buffer
2855 character. (Bug#11341)
2856
2857 * w32menu.c: Include w32heap.h.
2858 (add_menu_item): If the call to AppendMenuW (via
2859 unicode_append_menu) fails, disable Unicode menus only if we are
2860 running on Windows 9X/Me.
2861
2862 2012-04-24 Andreas Schwab <schwab@linux-m68k.org>
2863
2864 * .gdbinit (xpr): Handle USE_2_TAGS_FOR_INTS.
2865 (xgetint): Add missing shift for LSB tags.
2866
2867 2012-04-24 Martin Rudalics <rudalics@gmx.at>
2868
2869 * keyboard.c (read_char): Don't wipe echo area for select window
2870 events: These might get delayed via `mouse-autoselect-window'
2871 (Bug#11304).
2872
2873 2012-04-24 Juanma Barranquero <lekktu@gmail.com>
2874
2875 * gnutls.c (init_gnutls_functions): Protect against (unlikely)
2876 manipulation of :loaded-from data.
2877
2878 2012-04-23 Juanma Barranquero <lekktu@gmail.com>
2879
2880 * gnutls.c (init_gnutls_functions): The value of :loaded-from is
2881 now a cons (bug#11311).
2882
2883 2012-04-23 Paul Eggert <eggert@cs.ucla.edu>
2884
2885 Do not create empty overlays with the evaporate property (Bug#9642).
2886 * buffer.c (Fmove_overlay): Delete an evaporating overlay
2887 if it becomes empty after its bounds are adjusted to fit within
2888 its buffer. Without this fix, in a nonempty buffer (let ((o
2889 (make-overlay 1 2))) (overlay-put o 'evaporate t) (move-overlay o 0 1))
2890 yields an empty overlay that has the evaporate property, which is
2891 not supposed to happen.
2892
2893 Fix minor GTK3 problems found by static checking.
2894 * emacsgtkfixed.c (EMACS_TYPE_FIXED, EMACS_FIXED, EmacsFixed)
2895 (EmacsFixedPrivate, EmacsFixedClass, struct _EmacsFixed)
2896 (struct _EmacsFixedClass, emacs_fixed_get_type):
2897 Move decls here from emacsgtkfixed.h, since they needn't be public.
2898 (emacs_fixed_get_type): Now static.
2899 (emacs_fixed_class_init): Omit unused local.
2900 (emacs_fixed_child_type): Remove; unused.
2901 * emacsgtkfixed.h (EMACS_TYPE_FIXED, EMACS_FIXED, EmacsFixed)
2902 (EmacsFixedPrivate, EmacsFixedClass, struct _EmacsFixed)
2903 (struct _EmacsFixedClass): Move to emacsgtkfixed.c.
2904 (EMACS_FIXED_CLASS, EMACS_IS_FIXED, EMACS_IS_FIXED_CLASS)
2905 (EMACS_FIXED_GET_CLASS): Remove; unused.
2906 * gtkutil.c (xg_create_frame_widgets) [!HAVE_GTK3]: Omit unused local.
2907
2908 * keyboard.c (handle_async_input): Define only if SYNC_INPUT || SIGIO.
2909 Problem reported by Juanma Barranquero for Windows -Wunused-function.
2910
2911 2012-04-22 Paul Eggert <eggert@cs.ucla.edu>
2912
2913 Modernize and clean up gmalloc.c to assume C89 (Bug#9119).
2914 * gmalloc.c (_MALLOC_INTERNAL, _MALLOC_H, _PP, __ptr_t)
2915 (__malloc_size_t, __malloc_ptrdiff_t):
2916 Remove. All uses removed, replaced by the definiens if needed,
2917 since we can assume C89 or better now.
2918 Include <stdint.h>, for PTRDIFF_MAX, uintptr_t.
2919 (protect_malloc_state, align, get_contiguous_space)
2920 (malloc_atfork_handler_prepare, malloc_atfork_handler_parent)
2921 (malloc_atfork_handler_child, malloc_enable_thread)
2922 (malloc_initialize_1, __malloc_initialize, morecore_nolock)
2923 (_malloc_internal_nolock, _malloc_internal, malloc, _malloc)
2924 (_free, _realloc, _free_internal_nolock, _free_internal, free, cfree)
2925 (special_realloc, _realloc_internal_nolock, _realloc_internal)
2926 (realloc, calloc, __default_morecore, memalign, valloc, checkhdr)
2927 (freehook, mallochook, reallochook, mabort, mcheck, mprobe):
2928 Define using prototypes, not old style.
2929 (align, _malloc_internal_nolock, _free_internal_nolock, memalign):
2930 Don't assume ptrdiff_t and uintptr_t are no wider than unsigned long.
2931 (align): Don't assume that signed integer overflow wraps around.
2932 Omit unused local var.
2933 (malloc_initialize_1, morecore_nolock, _malloc_internal_nolock)
2934 (_free_internal_nolock, memalign, mallochook, reallochook):
2935 Omit no-longer-needed casts.
2936 (valloc): Use getpagesize, not __getpagesize.
2937 (MAGICWORD, MAGICFREE): Now randomish size_t values, not 32-bit.
2938 (struct hdr): The 'magic' member is now size_t, not unsigned long.
2939
2940 * dbusbind.c (XD_DBUS_VALIDATE_OBJECT): Define only if needed.
2941
2942 2012-04-22 Michael Albinus <michael.albinus@gmx.de>
2943
2944 Move functions from C to Lisp. Make non-blocking method calls
2945 the default. Implement further D-Bus standard interfaces.
2946
2947 * dbusbind.c (DBUS_NUM_MESSAGE_TYPES): Declare.
2948 (QCdbus_request_name_allow_replacement)
2949 (QCdbus_request_name_replace_existing)
2950 (QCdbus_request_name_do_not_queue)
2951 (QCdbus_request_name_reply_primary_owner)
2952 (QCdbus_request_name_reply_in_queue)
2953 (QCdbus_request_name_reply_exists)
2954 (QCdbus_request_name_reply_already_owner): Move to dbus.el.
2955 (QCdbus_registered_serial, QCdbus_registered_method)
2956 (QCdbus_registered_signal): New Lisp objects.
2957 (XD_DEBUG_MESSAGE): Use sizeof.
2958 (XD_MESSAGE_TYPE_TO_STRING, XD_OBJECT_TO_STRING)
2959 (XD_DBUS_VALIDATE_BUS_ADDRESS, XD_DBUS_VALIDATE_OBJECT)
2960 (XD_DBUS_VALIDATE_BUS_NAME, XD_DBUS_VALIDATE_PATH)
2961 (XD_DBUS_VALIDATE_INTERFACE, XD_DBUS_VALIDATE_MEMBER): New macros.
2962 (XD_CHECK_DBUS_SERIAL): Rename from CHECK_DBUS_SERIAL_GET_SERIAL.
2963 (xd_signature, xd_append_arg): Allow float for integer types.
2964 (xd_get_connection_references): New function.
2965 (xd_get_connection_address): Rename from xd_initialize.
2966 Return cached address.
2967 (xd_remove_watch): Do not unset $DBUS_SESSION_BUS_ADDRESS.
2968 (xd_close_bus): Rename from Fdbus_close_bus. Not needed on Lisp
2969 level.
2970 (Fdbus_init_bus): New optional arg PRIVATE. Cache address.
2971 Return number of refcounts.
2972 (Fdbus_get_unique_name): Make stronger parameter check.
2973 (Fdbus_message_internal): New defun.
2974 (Fdbus_call_method, Fdbus_call_method_asynchronously)
2975 (Fdbus_method_return_internal, Fdbus_method_error_internal)
2976 (Fdbus_send_signal, Fdbus_register_service)
2977 (Fdbus_register_signal, Fdbus_register_method): Move to dbus.el.
2978 (xd_read_message_1): Obey new structure of Vdbus_registered_objects.
2979 (xd_read_queued_messages): Obey new structure of Vdbus_registered_buses.
2980 (Vdbus_compiled_version, Vdbus_runtime_version)
2981 (Vdbus_message_type_invalid, Vdbus_message_type_method_call)
2982 (Vdbus_message_type_method_return, Vdbus_message_type_error)
2983 (Vdbus_message_type_signal): New defvars.
2984 (Vdbus_registered_buses, Vdbus_registered_objects_table):
2985 Adapt docstring.
2986
2987 2012-04-22 Paul Eggert <eggert@cs.ucla.edu>
2988
2989 Fix GC_MALLOC_CHECK debugging output on 64-bit hosts.
2990 * alloc.c (emacs_blocked_malloc) [GC_MALLOC_CHECK]:
2991 Do not assume ptrdiff_t is the same width as 'int'.
2992
2993 * alloc.c: Handle unusual debugging option combinations.
2994 (GC_CHECK_MARKED_OBJECTS): Undef if ! GC_MARK_STACK,
2995 since the two debugging options are incompatible.
2996 (GC_MALLOC_CHECK): Similarly, undef if GC_CHECK_MARKED_OBJECTS
2997 is defined.
2998 (mem_init, mem_insert, mem_insert_fixup):
2999 Define if GC_MARK_STACK || GC_MALLOC_CHECK.
3000 (NEED_MEM_INSERT): Remove; no longer needed.
3001
3002 2012-04-22 Leo Liu <sdl.web@gmail.com>
3003
3004 * sysdep.c (list_system_processes): Support Darwin (Bug#5725).
3005
3006 2012-04-22 Paul Eggert <eggert@cs.ucla.edu>
3007
3008 * sysdep.c [__FreeBSD__]: Minor cleanups.
3009 (list_system_processes, system_process_attributes) [__FreeBSD__]:
3010 Use Emacs indenting style more consistently. Avoid some casts.
3011 Use 'double' consistently rather than mixing 'float' and 'double'.
3012
3013 2012-04-21 Eduard Wiebe <usenet@pusto.de>
3014
3015 * sysdep.c (list_system_processes, system_process_attributes):
3016 Add implementation for FreeBSD (Bug#5243).
3017
3018 2012-04-21 Andreas Schwab <schwab@linux-m68k.org>
3019
3020 * lisp.mk (lisp): Update.
3021
3022 2012-04-20 Paul Eggert <eggert@cs.ucla.edu>
3023
3024 * keyboard.c (process_pending_signals): Define only if SYNC_INPUT.
3025 It is never used otherwise.
3026
3027 2012-04-20 Stefan Monnier <monnier@iro.umontreal.ca>
3028
3029 * print.c (print_preprocess): Only check print_depth if print-circle
3030 is nil.
3031 (print_object): Check for cycles even when print-circle is nil and
3032 print-gensym is t, but only check print_depth if print-circle is nil.
3033
3034 2012-04-20 Chong Yidong <cyd@gnu.org>
3035
3036 * process.c (wait_reading_process_output): If EIO occurs on a pty,
3037 set the status to "failed" and ensure that sentinel is run.
3038
3039 2012-04-20 Glenn Morris <rgm@gnu.org>
3040
3041 * process.c (Fset_process_inherit_coding_system_flag)
3042 (Fset_process_query_on_exit_flag): Doc fix (mention return value).
3043 (Fmake_network_process, Fmake_serial_process): Doc fix.
3044
3045 2012-04-20 Eli Zaretskii <eliz@gnu.org>
3046
3047 * xdisp.c (string_buffer_position_lim): Limit starting position to
3048 BEGV.
3049 (set_cursor_from_row): If called for a mode-line or header-line
3050 row, return zero immediately.
3051 (try_cursor_movement): If inside continuation line, don't back up
3052 farther than the first row after the header line, if any.
3053 Don't consider the header-line row as "partially visible", even if
3054 MATRIX_ROW_PARTIALLY_VISIBLE_P returns non-zero. (Bug#11261)
3055
3056 2012-04-20 Atsuo Ohki <ohki@gssm.otsuka.tsukuba.ac.jp> (tiny change)
3057
3058 * lread.c (lisp_file_lexically_bound_p): Fix hang at ";-*-\n"
3059 (bug#11238).
3060
3061 2012-04-20 Teodor Zlatanov <tzz@lifelogs.com>
3062 2012-04-18 Paul Eggert <eggert@cs.ucla.edu>
3063
3064 configure: new option --enable-gcc-warnings (Bug#11207)
3065 * Makefile.in (C_WARNINGS_SWITCH): Remove.
3066 (WARN_CFLAGS, WERROR_CFLAGS): New macros.
3067 (ALL_CFLAGS): Use new macros rather than old.
3068 * process.c: Ignore -Wstrict-overflow to work around GCC bug 52904.
3069 * regex.c: Ignore -Wstrict-overflow. If !emacs, also ignore
3070 -Wunused-but-set-variable, -Wunused-function, -Wunused-macros,
3071 -Wunused-result, -Wunused-variable. This should go away once
3072 the Emacs and Gnulib regex code is merged.
3073 (xmalloc, xrealloc): Now static.
3074
3075 2012-04-17 Paul Eggert <eggert@cs.ucla.edu>
3076
3077 * dired.c (Fsystem_groups): Remove unused local.
3078
3079 2012-04-17 Glenn Morris <rgm@gnu.org>
3080
3081 * dired.c (Fsystem_users): Doc fix.
3082
3083 2012-04-17 Dmitry Antipov <dmantipov@yandex.ru>
3084
3085 * dired.c (Fsystem_users, Fsystem_groups): New functions. (Bug#7900)
3086 (syms_of_dired): Add them.
3087
3088 2012-04-16 Paul Eggert <eggert@cs.ucla.edu>
3089
3090 Fix minor alloc.c problems found by static checking.
3091 * alloc.c (_malloc_internal, _free_internal) [!DOUG_LEA_MALLOC]:
3092 New extern decls, to avoid calling undeclared functions.
3093 (dont_register_blocks): Define if ((!SYSTEM_MALLOC && !SYNC_INPUT)
3094 && GC_MALLOC_CHECK), not if ((GC_MARK_STACK || defined
3095 GC_MALLOC_CHECK) && GC_MALLOC_CHECK), to match when it's used.
3096 (NEED_MEM_INSERT): New macro.
3097 (mem_insert, mem_insert_fixup) [!NEED_MEM_INSERT]: Remove; unused.
3098 Remove one incorrect comment and fix another.
3099
3100 Fix minor ralloc.c problems found by static checking.
3101 See http://lists.gnu.org/archive/html/emacs-devel/2011-12/msg00720.html
3102 * ralloc.c (ALIGNED, ROUND_TO_PAGE, HEAP_PTR_SIZE)
3103 (r_alloc_size_in_use, r_alloc_freeze, r_alloc_thaw): Remove; unused.
3104 (r_alloc_sbrk): Now static.
3105
3106 Improve ralloc.c interface checking.
3107 See http://lists.gnu.org/archive/html/emacs-devel/2011-12/msg00720.html
3108 * buffer.c (ralloc_reset_variable, r_alloc, r_re_alloc)
3109 (r_alloc_free) [REL_ALLOC]: Move decls from here ...
3110 * lisp.h (r_alloc, r_alloc_free, r_re_alloc, r_alloc_reset_variable)
3111 [REL_ALLOC]: ... to here, to check interface.
3112 * m/ia64.h (r_alloc, r_alloc_free) [REL_ALLOC && !_MALLOC_INTERNAL]:
3113 Remove decls. This fixes an "It stinks!".
3114
3115 * alloc.c (which_symbols): Fix alignment issue / type clash.
3116
3117 2012-04-15 Andreas Schwab <schwab@linux-m68k.org>
3118
3119 * lisp.h (struct Lisp_Symbol): Remove explicit padding.
3120 (struct Lisp_Misc_Any): Likewise.
3121 (struct Lisp_Free): Likewise.
3122 * alloc.c (union aligned_Lisp_Symbol): Define.
3123 (SYMBOL_BLOCK_SIZE, struct symbol_block): Use union
3124 aligned_Lisp_Symbol instead of struct Lisp_Symbol.
3125 (union aligned_Lisp_Misc): Define.
3126 (MARKER_BLOCK_SIZE, struct marker_block): Use union
3127 aligned_Lisp_Misc instead of union Lisp_Misc.
3128 (Fmake_symbol, allocate_misc, gc_sweep): Adjust.
3129
3130 2012-04-14 Paul Eggert <eggert@cs.ucla.edu>
3131
3132 Make GC_MAKE_GCPROS_NOOPS the default (Bug#9926).
3133 * lisp.h (GC_MARK_STACK): Default to GC_MAKE_GCPROS_NOOPS.
3134 * s/cygwin.h, s/darwin.h, s/freebsd.h, s/gnu.h, s/irix6-5.h, s/msdos.h:
3135 * s/netbsd.h, s/sol2-6.h:
3136 Remove definition of GC_MARK_STACK, since the default now works.
3137 * s/aix4-2.h, s/hpux10-20.h, s/unixware.h:
3138 Define GC_MARK_STACK to GC_USE_GCPROS_AS_BEFORE, since that's
3139 no longer the default.
3140 * s/gnu-linux.h (GC_MARK_STACK): Adjust to change in default.
3141
3142 2012-04-14 Atsuo Ohki <ohki@gssm.otsuka.tsukuba.ac.jp> (tiny change)
3143
3144 * lread.c (lisp_file_lexically_bound_p):
3145 Fix hang at ";-*-\n" (bug#11238).
3146
3147 2012-04-14 Eli Zaretskii <eliz@gnu.org>
3148
3149 * xdisp.c (find_last_unchanged_at_beg_row): Don't consider a row
3150 "unchanged" if its end.pos is beyond ZV. (Bug#11199)
3151
3152 2012-04-14 Jan Djärv <jan.h.d@swipnet.se>
3153
3154 * nsterm.m (constrainFrameRect): Always constrain when there is only
3155 one screen (Bug#10962).
3156
3157 2012-04-13 Ken Brown <kbrown@cornell.edu>
3158
3159 * s/cygwin.h (PTY_OPEN): Don't try to close a bogus file descriptor.
3160
3161 2012-04-13 Reuben Thomas <rrt@sc3d.org>
3162
3163 * indent.c (Fmove_to_column): Change interactive spec (Bug#739).
3164
3165 2012-04-11 Daniel Colascione <dancol@dancol.org>
3166
3167 * s/cygwin.h: The vfork the #define in cygwin.h was protecting
3168 against is gone. It's better to use vfork now so that when Cygwin
3169 gains a new, working vfork, we use it automatically (bug#10398).
3170
3171 2012-04-11 Stefan Monnier <monnier@iro.umontreal.ca>
3172
3173 * window.c (save_window_save): Obey window-point-insertion-type.
3174
3175 2012-04-11 Glenn Morris <rgm@gnu.org>
3176
3177 * Makefile.in (GNUSTEP_CFLAGS): Rename from C_SWITCH_X_SYSTEM.
3178
3179 2012-04-11 Stefan Monnier <monnier@iro.umontreal.ca>
3180
3181 * alloc.c (lisp_align_malloc): Remove unneeded prototype.
3182
3183 2012-04-10 Jason S. Cornez <jcornez@ravenpack.com> (tiny change)
3184
3185 * keyboard.c: Override inhibit-quit after the third C-g (bug#6585).
3186 (force_quit_count): New var.
3187 (handle_interrupt): Use it.
3188
3189 2012-04-10 Juanma Barranquero <lekktu@gmail.com>
3190
3191 * w32.c (w32_delayed_load): Record the full path of the library
3192 being loaded (bug#10424).
3193
3194 2012-04-09 Glenn Morris <rgm@gnu.org>
3195
3196 * doc.c (Fsnarf_documentation): Check variables, functions are bound,
3197 not just in the obarray, before snarfing them. (Bug#11036)
3198
3199 * Makefile.in ($(leimdir)/leim-list.el):
3200 Pass EMACS rather than BUILT_EMACS.
3201
3202 2012-04-09 Teodor Zlatanov <tzz@lifelogs.com>
3203
3204 * process.c (make_process):
3205 * process.h: Add integer `gnutls_handshakes_tried' member to
3206 process struct.
3207
3208 * gnutls.h: Add `GNUTLS_EMACS_HANDSHAKES_LIMIT' upper limit.
3209 Add convenience `GNUTLS_LOG2i' macro.
3210
3211 * gnutls.c (gnutls_log_function2i): Convenience log function.
3212 (emacs_gnutls_read): Use new log functions,
3213 `gnutls_handshakes_tried' process member, and
3214 `GNUTLS_EMACS_HANDSHAKES_LIMIT' to limit the number of handshake
3215 attempts per process (connection).
3216
3217 2012-04-09 Chong Yidong <cyd@gnu.org>
3218
3219 * eval.c (Fuser_variable_p, user_variable_p_eh)
3220 (lisp_indirect_variable): Functions deleted.
3221 (Fdefvar): Caller changed.
3222
3223 * callint.c (Finteractive, Fcall_interactively):
3224 * minibuf.c (Fread_variable): Callers changed.
3225
3226 2012-04-09 Eli Zaretskii <eliz@gnu.org>
3227
3228 * xdisp.c (set_cursor_from_row): If the display string appears in
3229 the buffer at position that is closer to point than the position
3230 after the display string, display the cursor on the first glyph of
3231 the display string. Fixes cursor display when a 'display' text
3232 property immediately follows invisible text. (Bug#11094)
3233
3234 2012-04-09 Paul Eggert <eggert@cs.ucla.edu>
3235
3236 composite.c: use 'double' consistently
3237 * composite.c (get_composition_id): Use 'double' consistently
3238 instead of converting 'float' to 'double' and vice versa; this is
3239 easier to understand and avoids a GCC warning.
3240
3241 2012-04-09 Glenn Morris <rgm@gnu.org>
3242
3243 * Makefile.in: Generate leim-list with bootstrap-emacs, in
3244 preparation for dumping it with emacs. (Bug#4789)
3245 (leimdir): New variable.
3246 ($(leimdir)/leim-list.el): New rule.
3247 (emacs$(EXEEXT)): Depend on leim-list.el.
3248
3249 * buffer.c (Qucs_set_table_for_input): Remove. (Bug#9821)
3250 (Fget_buffer_create): Don't call Qucs_set_table_for_input.
3251 (init_buffer_once, syms_of_buffer): Remove Qucs_set_table_for_input.
3252
3253 2012-04-08 Andreas Schwab <schwab@linux-m68k.org>
3254
3255 * lisp.h (struct Lisp_Symbol): Add explicit padding to ensure
3256 proper alignment.
3257
3258 2012-04-07 Juanma Barranquero <lekktu@gmail.com>
3259
3260 * xml.c (init_libxml2_functions) [WINDOWSNT]:
3261 Remove unused local variable.
3262
3263 2012-04-07 Paul Eggert <eggert@cs.ucla.edu>
3264
3265 Avoid unnecessary pointer scanning in garbage collection (Bug#10780).
3266 * alloc.c (POINTERS_MIGHT_HIDE_IN_OBJECTS): New macro.
3267 (mark_memory): Mark Lisp_Objects only if pointers might hide in
3268 objects, as mark_maybe_pointer will catch them otherwise.
3269 (GC_LISP_OBJECT_ALIGNMENT): Remove; no longer needed.
3270 * s/gnu-linux.h (GC_LISP_OBJECT_ALIGNMENT) [__mc68000__]: Likewise.
3271
3272 2012-04-07 Paul Eggert <eggert@cs.ucla.edu>
3273
3274 Fix typo that broke non-Windows builds.
3275 * xml.c (libxml2_loaded_p) [!!WINDOWSNT]: 'inine' -> 'inline'.
3276
3277 2012-04-07 Eli Zaretskii <eliz@gnu.org>
3278
3279 Support building on MS-Windows with libxml2.
3280
3281 * makefile.w32-in (OBJ2): Add xml.$(O).
3282 (GLOBAL_SOURCES): Add xml.c.
3283 ($(BLD)/xml.$(O)): New dependency list.
3284
3285 * xml.c (DEF_XML2_FN, LOAD_XML2_FN) [WINDOWSNT]: New macros.
3286 (fn_htmlReadMemory, fn_xmlReadMemory, fn_xmlDocGetRootElement)
3287 (fn_xmlFreeDoc, fn_xmlCleanupParser, fn_xmlCheckVersion)
3288 [!WINDOWSNT]: New macros.
3289 (init_libxml2_functions, libxml2_loaded_p): New functions.
3290 (parse_region): Call fn_xmlCheckVersion instead of using the macro
3291 LIBXML_TEST_VERSION. Call libxml2 functions via the fn_* macros.
3292 (xml_cleanup_parser): New function, export for fn_xmlCleanupParser.
3293 Calls xmlCleanupParser only if libxml2 was loaded (or statically
3294 linked in).
3295 (Flibxml_parse_html_region, Flibxml_parse_xml_region):
3296 Call init_libxml2_functions before calling libxml2 functions.
3297 (syms_of_xml) <Qlibxml2_dll>: DEFSYM it.
3298
3299 * emacs.c: Don't include libxml/parser.h.
3300 (shut_down_emacs): Call xml_cleanup_parser, instead of calling
3301 xmlCleanupParser directly.
3302
3303 * lisp.h [HAVE_LIBXML2]: Add prototype for xml_cleanup_parser.
3304
3305 2012-04-07 Eli Zaretskii <eliz@gnu.org>
3306
3307 * indent.c (Fvertical_motion): If there is a display string at
3308 point, use it.vpos to compute how many lines to backtrack after
3309 move_it_to point. (Bug#11133)
3310
3311 2012-04-06 Eli Zaretskii <eliz@gnu.org>
3312
3313 * buffer.h (FETCH_CHAR, FETCH_MULTIBYTE_CHAR):
3314 * character.h (STRING_CHAR, STRING_CHAR_AND_LENGTH): Add comments
3315 about subtle differences between FETCH_CHAR* and STRING_CHAR*
3316 macros related to unification of CJK characters. For the details,
3317 see the discussion following the message here:
3318 http://debbugs.gnu.org/cgi/bugreport.cgi?bug=11073#14.
3319
3320 2012-04-04 Chong Yidong <cyd@gnu.org>
3321
3322 * keyboard.c (Vdelayed_warnings_list): Doc fix.
3323
3324 2012-04-01 Eli Zaretskii <eliz@gnu.org>
3325
3326 * w32menu.c (simple_dialog_show, add_menu_item): Use SAFE_ALLOCA
3327 instead of alloca. (Bug#11138)
3328
3329 2012-04-01 Andreas Schwab <schwab@linux-m68k.org>
3330
3331 * w32menu.c (is_simple_dialog): Properly check lisp types.
3332 (Bug#11141)
3333
3334 2012-03-31 Eli Zaretskii <eliz@gnu.org>
3335
3336 * xdisp.c (move_it_by_lines): When DVPOS is positive, and the
3337 position we get to after a call to move_it_to fails the
3338 IS_POS_VALID_AFTER_MOVE_P test, move to the next buffer position
3339 only if we wind up in a string from display property. (Bug#11063)
3340
3341 * window.c (Fdelete_other_windows_internal): Invalidate the row
3342 and column information about mouse highlight, so that redisplay
3343 restores it after reallocating the glyph matrices. (Bug#7464)
3344
3345 * xdisp.c (set_cursor_from_row): If `cursor' property on a display
3346 string comes from a `display' text property, use the buffer
3347 position of that property as if we actually saw that position in
3348 the row's glyphs.
3349 (move_it_by_lines): Remove the assertion that
3350 "it->current_x == 0 && it->hpos == 0" which can be legitimately
3351 violated when there's a before-string at the beginning of a line.
3352 (Bug#11063)
3353
3354 2012-03-30 Eli Zaretskii <eliz@gnu.org>
3355
3356 * xdisp.c (append_space_for_newline): If the default face was
3357 remapped, use the remapped face for the appended newline.
3358 (extend_face_to_end_of_line): Use the remapped default face for
3359 extending the face to the end of the line.
3360 (display_line): Call extend_face_to_end_of_line when the default
3361 face was remapped. (Bug#11068)
3362
3363 2012-03-29 Eli Zaretskii <eliz@gnu.org>
3364
3365 * s/ms-w32.h: Discourage from defining HAVE_GETCWD.
3366
3367 2012-03-28 Stefan Monnier <monnier@iro.umontreal.ca>
3368
3369 * keyboard.c (safe_run_hooks_error): Don't unquote strings.
3370
3371 2012-03-27 Glenn Morris <rgm@gnu.org>
3372
3373 * search.c (Fword_search_backward_lax, Fword_search_forward_lax):
3374 Doc fixes.
3375
3376 2012-03-26 Kenichi Handa <handa@m17n.org>
3377
3378 * dispextern.h (struct glyph): Fix previous change. Change the
3379 bit length of glyphless.ch to 25 (Bug#11082).
3380
3381 2012-03-26 Chong Yidong <cyd@gnu.org>
3382
3383 * keyboard.c (Vselection_inhibit_update_commands): New variable.
3384 (command_loop_1): Use it; inhibit selection update for
3385 handle-select-window too (Bug#8996).
3386
3387 2012-03-25 Fabrice Popineau <fabrice.popineau@supelec.fr>
3388
3389 * w32heap.c (_heap_init, _heap_term): Remove dead MSVC-specific code.
3390
3391 2012-03-25 Kenichi Handa <handa@m17n.org>
3392
3393 * dispextern.h (struct glyph): Change the bit length of
3394 glyphless.ch to 22 to make the member glyphless fit in 32 bits.
3395
3396 2012-03-24 Eli Zaretskii <eliz@gnu.org>
3397
3398 * s/ms-w32.h (tzname): Include time.h before redirecting to
3399 _tzname. Fixes the MSVC build. (Bug#9960)
3400
3401 2012-03-24 Andreas Schwab <schwab@linux-m68k.org>
3402
3403 * xdisp.c (produce_glyphless_glyph): Limit length of acronym to 6
3404 characters.
3405
3406 * xterm.c (XTread_socket): Only modify handling_signal if
3407 !SYNC_INPUT. (Bug#11080)
3408
3409 2012-03-23 Eli Zaretskii <eliz@gnu.org>
3410
3411 * bidi.c (bidi_fetch_char): Use STRING_CHAR_AND_LENGTH instead of
3412 FETCH_MULTIBYTE_CHAR followed by CHAR_BYTES. Prevents crashes
3413 when fetching a multibyte character consumes more bytes than
3414 CHAR_BYTES returns, due to unification of CJK characters in
3415 string_char. (Bug#11073)
3416
3417 2012-03-23 Troels Nielsen <bn.troels@gmail.com> (tiny change)
3418
3419 * process.c (wait_reading_process_output): Handle pty disconnect
3420 by refraining from sending oneself a SIGCHLD (bug#10933).
3421
3422 2012-03-22 Chong Yidong <cyd@gnu.org>
3423
3424 * dispextern.h (struct it): New member string_from_prefix_prop_p.
3425
3426 * xdisp.c (push_prefix_prop): Rename from push_display_prop.
3427 Mark string as coming from a prefix property.
3428 (handle_face_prop): Use default face for prefix strings (Bug#4281).
3429 (pop_it, reseat_1): Save and restore string_from_prefix_prop_p.
3430
3431 2012-03-21 Chong Yidong <cyd@gnu.org>
3432
3433 * xfaces.c (Vface_remapping_alist): Doc fix.
3434
3435 2012-03-20 Eli Zaretskii <eliz@gnu.org>
3436
3437 * w32proc.c (Fw32_set_console_codepage)
3438 (Fw32_set_console_output_codepage, Fw32_get_codepage_charset):
3439 Doc fixes.
3440
3441 2012-03-20 Chong Yidong <cyd@gnu.org>
3442
3443 * dispnew.c (Fredisplay, Vredisplay_preemption_period): Update doc
3444 to reflect default non-nil value of redisplay-dont-pause.
3445
3446 2012-03-19 Kenichi Handa <handa@m17n.org>
3447
3448 * ftfont.c (ftfont_drive_otf): Mask bits of character code to make
3449 it fit in a valid range (Bug#11003).
3450
3451 2012-03-18 Eli Zaretskii <eliz@gnu.org>
3452
3453 * xdisp.c (cursor_row_p): Even if the glyph row ends in a string
3454 that is not from display property, accept the row as a "cursor
3455 row" if one of the string's character has a non-nil `cursor'
3456 property. Fixes cursor positioning when there are newlines in
3457 overlay strings, e.g. in icomplete.el. (Bug#11035)
3458
3459 2012-03-12 Paul Eggert <eggert@cs.ucla.edu>
3460
3461 * buffer.c (compare_overlays): Don't assume args differ (Bug#6830).
3462
3463 2012-03-12 Chong Yidong <cyd@gnu.org>
3464
3465 * eval.c (inhibit_lisp_code): Rename from
3466 inhibit_window_configuration_change_hook; move from window.c.
3467
3468 * xfns.c (unwind_create_frame_1, Fx_create_frame):
3469 * window.c (run_window_configuration_change_hook)
3470 (syms_of_window): Callers changed.
3471
3472 2012-03-11 Chong Yidong <cyd@gnu.org>
3473
3474 * keymap.c (Fkey_description): Doc fix (Bug#9700).
3475
3476 * editfns.c (Fconstrain_to_field): Doc fix (Bug#9452).
3477
3478 2012-03-10 Chong Yidong <cyd@gnu.org>
3479
3480 * frame.c (other_visible_frames): Don't assume the selected frame
3481 is visible (Bug#10955).
3482
3483 2012-03-09 Stefan Monnier <monnier@iro.umontreal.ca>
3484
3485 * buffer.c (compare_overlays): Avoid qsort's instability (bug#6830).
3486
3487 2012-03-08 Jan Djärv <jan.h.d@swipnet.se>
3488
3489 * gtkutil.c (x_wm_set_size_hint): Use one row in call to
3490 FRAME_TEXT_LINES_TO_PIXEL_HEIGHT so base_height is greater than
3491 zero (Bug#10954).
3492
3493 2012-03-03 Glenn Morris <rgm@gnu.org>
3494
3495 * alloc.c (Fgarbage_collect, misc-objects-consed): Doc fixes.
3496
3497 2012-03-02 Eli Zaretskii <eliz@gnu.org>
3498
3499 * xdisp.c (try_window_reusing_current_matrix): Don't move cursor
3500 position past the first glyph_row that ends at ZV. (Bug#10902)
3501 (redisplay_window, next_element_from_string): Fix typos in
3502 comments.
3503 (redisplay_window): Pass to move_it_vertically the margin in
3504 pixels, not in screen lines.
3505
3506 2012-03-02 Glenn Morris <rgm@gnu.org>
3507
3508 * buffer.c (buffer-list-update-hook): Doc fix.
3509
3510 2012-02-29 Eli Zaretskii <eliz@gnu.org>
3511
3512 * xdisp.c (get_overlay_strings_1): Under bidi redisplay, call
3513 push_it before setting up the iterator for the first overlay
3514 string, even if we have an empty string loaded.
3515 (next_overlay_string): If there's an empty string on the iterator
3516 stack, pop the stack. (Bug#10903)
3517
3518 2012-02-25 Paul Eggert <eggert@cs.ucla.edu>
3519
3520 Generalize fix for crash due to non-contiguous EMACS_INT (Bug#10780).
3521 Suggested by Stefan Monnier in
3522 <http://lists.gnu.org/archive/html/emacs-devel/2012-02/msg00692.html>.
3523 * alloc.c (widen_to_Lisp_Object): New static function.
3524 (mark_memory): Also mark Lisp_Objects by fetching pointer words
3525 and widening them to Lisp_Objects. This would work even if
3526 USE_LSB_TAG is defined and wide integers are used, which might
3527 happen in a future version of Emacs.
3528
3529 2012-02-25 Chong Yidong <cyd@gnu.org>
3530
3531 * fileio.c (Ffile_selinux_context, Fset_file_selinux_context):
3532 Doc fix.
3533
3534 * xselect.c (Fx_selection_exists_p): Doc fix.
3535 (x_clipboard_manager_save_all): Print an informative message
3536 before saving to clipboard manager.
3537
3538 2012-02-24 Chong Yidong <cyd@gnu.org>
3539
3540 * keyboard.c (process_special_events): Handle all X selection
3541 requests in kbd_buffer, not just the next one (Bug#8869).
3542
3543 2012-02-23 Chong Yidong <cyd@gnu.org>
3544
3545 * xfns.c (Fx_create_frame): Avoid window-configuration-change-hook
3546 call when setting menu-bar-lines and tool-bar-lines parameters.
3547 (unwind_create_frame_1): New helper function.
3548
3549 * window.c (inhibit_window_configuration_change_hook): New var.
3550 (run_window_configuration_change_hook): Obey it.
3551 (syms_of_window): Initialize it.
3552
3553 2012-02-22 Chong Yidong <cyd@gnu.org>
3554
3555 * xterm.c (x_draw_image_relief): Add missing type check for
3556 Vtool_bar_button_margin (Bug#10743).
3557
3558 2012-02-21 Chong Yidong <cyd@gnu.org>
3559
3560 * fileio.c (Vfile_name_handler_alist): Doc fix.
3561
3562 * buffer.c (Fget_file_buffer): Protect against invalid file
3563 handler return value.
3564
3565 2012-02-20 Paul Eggert <eggert@cs.ucla.edu>
3566
3567 * .gdbinit (xreload): Don't assume EMACS_INT fits in 'long'
3568 when computing $valmask.
3569
3570 Fix crash due to non-contiguous EMACS_INT (Bug#10780).
3571 * lisp.h (VALBITS): Move definition up, so that USE_LSB_TAG can use it.
3572 (USE_LSB_TAG): Do not define if UINTPTR_MAX >> VALBITS == 0.
3573 It's useless in that case, and it can cause problems on hosts
3574 that allocate halves of EMACS_INT values separately.
3575 Reported by Dan Horák. Diagnosed by Andreas Schwab in
3576 <http://debbugs.gnu.org/cgi/bugreport.cgi?bug=10780#30>.
3577 * mem-limits.h (EXCEEDS_LISP_PTR): Define to 0 on hosts where
3578 UINTPTR_MAX >> VALBITS == 0. This is required by the above change;
3579 it avoids undefined behavior on hosts where shifting right by more
3580 than the word width has undefined behavior.
3581
3582 2012-02-19 Chong Yidong <cyd@gnu.org>
3583
3584 * fileio.c (Ffile_name_directory, Ffile_name_nondirectory)
3585 (Funhandled_file_name_directory, Ffile_name_as_directory)
3586 (Fdirectory_file_name, Fexpand_file_name)
3587 (Fsubstitute_in_file_name): Protect against invalid file handler
3588 return values (Bug#10845).
3589
3590 2012-02-18 Eli Zaretskii <eliz@gnu.org>
3591
3592 * .gdbinit (pitx): Fix incorrect references to fields of the
3593 iterator stack.
3594
3595 2012-02-17 Chong Yidong <cyd@gnu.org>
3596
3597 * syntax.c (Fscan_lists): Doc fix (Bug#10833).
3598
3599 2012-02-15 Paul Eggert <eggert@cs.ucla.edu>
3600
3601 * image.c (MAX_IMAGE_SIZE): Increase from 6.0 to 10.0; see
3602 <http://lists.gnu.org/archive/html/emacs-devel/2012-02/msg00540.html>.
3603
3604 2012-02-15 Chong Yidong <cyd@gnu.org>
3605
3606 * eval.c (Fdefvar, Fdefconst): Doc fix; note that the variable is
3607 marked as special. Also, starting docstrings with * is obsolete.
3608
3609 2012-02-13 Andreas Schwab <schwab@linux-m68k.org>
3610
3611 * gnutls.c (emacs_gnutls_write): Fix last change.
3612
3613 2012-02-13 Lars Ingebrigtsen <larsi@gnus.org>
3614
3615 * gnutls.c (emacs_gnutls_write): Set errno appropriately for
3616 send_process.
3617
3618 2012-02-13 Stefan Monnier <monnier@iro.umontreal.ca>
3619
3620 * keymap.c (Fsingle_key_description): Handle char ranges.
3621
3622 2012-02-12 Chong Yidong <cyd@gnu.org>
3623
3624 * xdisp.c (handle_stop): Avoid assigning -1 to it->face_id here,
3625 as that creates a dangerous corner case.
3626
3627 * window.c (Fdelete_window_internal): Invalidate the mouse
3628 highlight (Bug#9904).
3629
3630 2012-02-12 Glenn Morris <rgm@gnu.org>
3631
3632 * xselect.c (Fx_own_selection_internal)
3633 (Fx_get_selection_internal, Fx_disown_selection_internal)
3634 (Fx_selection_owner_p, Fx_selection_exists_p): Doc fixes.
3635 * nsselect.m (Fx_own_selection_internal)
3636 (Fx_disown_selection_internal, Fx_selection_exists_p)
3637 (Fx_selection_owner_p, Fx_get_selection_internal):
3638 Sync docs and argument specs with the xselect.c versions.
3639
3640 2012-02-11 Lars Ingebrigtsen <larsi@gnus.org>
3641
3642 * gnutls.c (emacs_gnutls_write): Don't infloop if sendto fails.
3643
3644 2012-02-11 Eli Zaretskii <eliz@gnu.org>
3645
3646 * w32select.c (Fx_selection_exists_p): Sync doc string and
3647 argument list with xselect.c. (Bug#10783)
3648
3649 * w16select.c (Fx_selection_exists_p): Sync doc string and
3650 argument list with xselect.c. (Bug#10783)
3651
3652 2012-02-10 Glenn Morris <rgm@gnu.org>
3653
3654 * fns.c (Fsecure_hash): Doc fix.
3655
3656 2012-02-09 Kenichi Handa <handa@m17n.org>
3657
3658 * coding.c (produce_chars): Fix updating of src_end (Bug#10701).
3659
3660 2012-02-07 Chong Yidong <cyd@gnu.org>
3661
3662 * buffer.c (Fbuffer_local_variables)
3663 (buffer_lisp_local_variables): Handle unbound vars correctly;
3664 don't let Qunbound leak into Lisp.
3665
3666 2012-02-07 Glenn Morris <rgm@gnu.org>
3667
3668 * image.c (Fimagemagick_types): Doc fix.
3669
3670 * image.c (imagemagick-render-type): Change it from a lisp object
3671 to an integer. Move the doc here from the lisp manual.
3672 Treat all values not equal to 0 the same.
3673
3674 2012-02-06 Chong Yidong <cyd@gnu.org>
3675
3676 * doc.c (store_function_docstring): Avoid applying docstring of
3677 alias to base function (Bug#2603).
3678
3679 2012-02-04 Andreas Schwab <schwab@linux-m68k.org>
3680
3681 * .gdbinit (pp1, pv1): Remove redundant defines.
3682 (pr): Use pp.
3683
3684 2012-02-04 Chong Yidong <cyd@gnu.org>
3685
3686 * nsterm.m: Declare a global (Bug#10694).
3687
3688 2012-02-04 Eli Zaretskii <eliz@gnu.org>
3689
3690 * w32.c (get_emacs_configuration_options):
3691 Include --enable-checking, if specified, in the return value.
3692
3693 2012-02-04 Martin Rudalics <rudalics@gmx.at>
3694
3695 * dispnew.c (change_frame_size_1): Calculate new_frame_total_cols
3696 after rounding frame sizes. (Bug#9723)
3697
3698 2012-02-04 Eli Zaretskii <eliz@gnu.org>
3699
3700 * keyboard.c (adjust_point_for_property): Don't position point
3701 before BEGV. (Bug#10696)
3702
3703 2012-02-03 Paul Eggert <eggert@cs.ucla.edu>
3704
3705 Handle overflow when computing char display width (Bug#9496).
3706 * character.c (char_width): Return EMACS_INT, not int.
3707 (char_width, c_string_width): Check for overflow when
3708 computing the width; this is possible now that individual
3709 characters can have unbounded width. Problem introduced
3710 by merge from Emacs 23 on 2012-01-19.
3711
3712 2012-02-02 Michael Albinus <michael.albinus@gmx.de>
3713
3714 * dbusbind.c (Fdbus_register_method): Mention the return value
3715 :ignore in the docstring.
3716
3717 2012-02-02 Glenn Morris <rgm@gnu.org>
3718
3719 * callproc.c (Fcall_process, Fcall_process_region): Doc fix.
3720
3721 * nsterm.m (syms_of_nsterm) <x-toolkit-scroll-bars>:
3722 Unconditionally set to t. (Bug#10673)
3723 * nsterm.m (syms_of_nsterm) <x-toolkit-scroll-bars>:
3724 * w32term.c (syms_of_w32term) <x-toolkit-scroll-bars>:
3725 * xterm.c (syms_of_xterm) <x-toolkit-scroll-bars>: Doc fix.
3726
3727 2012-02-02 Kenichi Handa <handa@m17n.org>
3728
3729 (x_produce_glyphs): Cancel previous change. If cmp->glyph_len is
3730 0, do not call append_composite_glyph.
3731
3732 2012-02-02 Kenichi Handa <handa@m17n.org>
3733
3734 * xdisp.c (BUILD_COMPOSITE_GLYPH_STRING): Initialize first_s to
3735 NULL (Bug#6988).
3736 (x_produce_glyphs): If the component of a composition is a null
3737 string, set it->pixel_width to 1 to avoid zero-width glyph.
3738
3739 2012-02-01 Eli Zaretskii <eliz@gnu.org>
3740
3741 * ralloc.c (resize_bloc, r_alloc_sbrk): Don't call memmove if its
3742 first 2 arguments are identical. This makes inserting large
3743 output from a subprocess an order of magnitude faster on
3744 MS-Windows, where all sbrk'ed memory is always contiguous.
3745
3746 2012-01-31 Glenn Morris <rgm@gnu.org>
3747
3748 * nsterm.m (syms_of_nsterm) <x-toolkit-scroll-bars>:
3749 * w32term.c (syms_of_w32term) <x-toolkit-scroll-bars>:
3750 * xterm.c (syms_of_xterm) <x-toolkit-scroll-bars>: Sync docs.
3751
3752 2012-01-29 Glenn Morris <rgm@gnu.org>
3753
3754 * gnutls.c (syms_of_gnutls): More doc (from etc/NEWS).
3755
3756 2012-01-28 Samuel Thibault <sthibault@debian.org> (tiny change)
3757
3758 * s/gnu.h: Define POSIX_SIGNALS (Bug#10552).
3759
3760 2012-01-28 Chong Yidong <cyd@gnu.org>
3761
3762 * minibuf.c (syms_of_minibuf): Doc fix (Bug#10550).
3763
3764 2012-01-26 Chong Yidong <cyd@gnu.org>
3765
3766 * keyboard.c (Vecho_keystrokes): Document zero value (Bug#10503).
3767
3768 * search.c (Fsearch_forward, Fsearch_backward): Document negative
3769 repeat counts (Bug#10507).
3770
3771 2012-01-26 Glenn Morris <rgm@gnu.org>
3772
3773 * lread.c (syms_of_lread): Doc fix.
3774
3775 2012-01-25 HIROSHI OOTA <nil@mad.dog.cx> (tiny change)
3776
3777 * coding.c (encode_designation_at_bol): Change return value to
3778 EMACS_INT.
3779
3780 2012-01-25 Chong Yidong <cyd@gnu.org>
3781
3782 * eval.c (Fuser_variable_p): Doc fix; mention custom-variable-p.
3783
3784 2012-01-21 Chong Yidong <cyd@gnu.org>
3785
3786 * floatfns.c (Fcopysign): Make the second argument non-optional,
3787 since nil is not allowed anyway.
3788
3789 2012-01-21 Andreas Schwab <schwab@linux-m68k.org>
3790
3791 * process.c (read_process_output): Use p instead of XPROCESS (proc).
3792 (send_process): Likewise.
3793
3794 2012-01-19 Martin Rudalics <rudalics@gmx.at>
3795
3796 * window.c (save_window_save, Fcurrent_window_configuration)
3797 (Vwindow_persistent_parameters): Do not use Qstate.
3798 Rewrite doc-strings.
3799
3800 2012-01-19 Kenichi Handa <handa@m17n.org>
3801
3802 * character.c (char_width): New function.
3803 (Fchar_width, c_string_width, lisp_string_width):
3804 Use char_width (Bug#9496).
3805
3806 2012-01-16 Martin Rudalics <rudalics@gmx.at>
3807
3808 * window.c (Vwindow_persistent_parameters): New variable.
3809 (Fset_window_configuration, save_window_save): Handle persistent
3810 window parameters.
3811
3812 2012-01-14 Eli Zaretskii <eliz@gnu.org>
3813
3814 * w32fns.c (signal_user_input): Don't do a QUIT, to avoid
3815 thrashing the stack of the thread. (Bug#9087)
3816
3817 2012-01-12 Paul Eggert <eggert@cs.ucla.edu>
3818
3819 * xdisp.c (rows_from_pos_range): Add parens as per gcc -Wparentheses.
3820
3821 2012-01-11 Eli Zaretskii <eliz@gnu.org>
3822
3823 * xdisp.c (rows_from_pos_range): Handle the case where the
3824 highlight ends on a newline. (Bug#10464)
3825 (mouse_face_from_buffer_pos): Fix off-by-one error in calculating
3826 he end column for display of highlight that ends on a newline
3827 before a R2L line.
3828
3829 2012-01-11 Glenn Morris <rgm@gnu.org>
3830
3831 * lread.c (init_lread): If no-site-lisp, remove site-lisp dirs
3832 from load-path also when installation-directory is nil. (Bug#10208)
3833
3834 2012-01-10 Glenn Morris <rgm@gnu.org>
3835
3836 * emacs.c (syms_of_emacs) <installation-directory>: Doc fix.
3837
3838 * epaths.in (PATH_LOADSEARCH, PATH_EXEC, PATH_DATA, PATH_DOC):
3839 Update template values to be closer to their typical values these days.
3840
3841 2012-01-09 Eli Zaretskii <eliz@gnu.org>
3842
3843 * xdisp.c (rows_from_pos_range): Accept additional argument
3844 DISP_STRING, and accept any glyph in a row whose object is that
3845 string as eligible for mouse highlight. Fixes mouse highlight of
3846 display strings from overlays. (Bug#10464)
3847
3848 2012-01-07 Paul Eggert <eggert@cs.ucla.edu>
3849
3850 emacs: fix an auto-save permissions race condition (Bug#10400)
3851 * fileio.c (auto_saving_dir_umask): New static var.
3852 (Fmake_directory_internal): Use it.
3853 (do_auto_save_make_dir): Set it, instead of invoking chmod after
3854 creating the directory. The old code temporarily assigns
3855 too-generous permissions to the directory.
3856 (do_auto_save_eh): Clear it.
3857 (Fdo_auto_save): Catch all errors, not just file errors, so
3858 that the var is always cleared.
3859
3860 2012-01-07 Eli Zaretskii <eliz@gnu.org>
3861
3862 * search.c (scan_buffer): Pass character positions to
3863 know_region_cache, not byte positions. (Bug#6540)
3864
3865 2012-01-07 LynX <_LynX@bk.ru> (tiny change)
3866
3867 * w32.c (sys_rename): Report EXDEV when rename of a directory
3868 fails because the target is on another logical disk. (Bug#10284)
3869
3870 2012-01-07 David Benjamin <davidben@mit.edu> (tiny change)
3871
3872 * xterm.c (x_embed_request_focus): New function.
3873
3874 * xterm.h: Add prototype.
3875
3876 * xfns.c (Fx_focus_frame): Use it for embedded frames (Bug#9977).
3877
3878 2012-01-05 Glenn Morris <rgm@gnu.org>
3879
3880 * emacs.c (emacs_copyright): Update short copyright year to 2012.
3881
3882 2012-01-01 Eli Zaretskii <eliz@gnu.org>
3883
3884 * gnutls.c (init_gnutls_functions): Load gnutls_check_version.
3885 Load gnutls_transport_set_lowat only if GnuTLS version is below
3886 2.11.1.
3887 (emacs_gnutls_handshake): Call gnutls_transport_set_lowat only for
3888 GnuTLS versions below 2.11.1.
3889
3890 2011-12-31 Antoine Levitt <antoine.levitt@gmail.com>
3891
3892 * xdisp.c (syms_of_xdisp) <window-scroll-functions>: Add warning
3893 to the doc string advising against its use for altering the way
3894 windows are scrolled.
3895
3896 2011-12-28 Kenichi Handa <handa@m17n.org>
3897
3898 * coding.c (Fdefine_coding_system_internal): Make an utf-8 base
3899 coding-system ASCII compatible only when it does not produce BOM
3900 on encoding (Bug#10383).
3901
3902 2011-12-26 Jan Djärv <jan.h.d@swipnet.se>
3903
3904 * xmenu.c (x_menu_wait_for_event): Use xg_select for Gtk3 so menus
3905 can scroll.
3906 (create_and_show_popup_menu): Always use menu_position_func for
3907 Gtk3 (Bug#10361).
3908
3909 2011-12-24 Andreas Schwab <schwab@linux-m68k.org>
3910
3911 * callint.c (Fcall_interactively): Don't truncate prompt string.
3912
3913 2011-12-23 Eli Zaretskii <eliz@gnu.org>
3914
3915 * xdisp.c (handle_invisible_prop): Handle correctly an invisible
3916 property that ends at ZV, so that the bidi iteration could be
3917 resumed from there (after widening). (Bug#10360)
3918
3919 2011-12-22 Jan Djärv <jan.h.d@swipnet.se>
3920
3921 * nsfont.m (ns_spec_to_descriptor): Do not autorelease fdesc.
3922
3923 2011-12-21 Jan Djärv <jan.h.d@swipnet.se>
3924
3925 * nsterm.m (x_free_frame_resources):
3926 Release f->output_data.ns->miniimage.
3927 (ns_index_color): Fix indentation. Do not retain
3928 color_table->colors[i].
3929
3930 * nsmenu.m (ns_update_menubar): Call free_menubar_widget_value_tree
3931 before returning.
3932
3933 * nsfns.m (x_set_background_color): Assign return value from
3934 ns_index_color to face-background instead of NSColor*.
3935 (ns_implicitly_set_icon_type): Fix indentation.
3936 Change assignment in for loop to comparison.
3937
3938 * emacs.c (ns_pool): New variable.
3939 (main): Assign ns_pool.
3940 (Fkill_emacs): Call ns_release_autorelease_pool.
3941
3942 * nsfont.m (ns_spec_to_descriptor): Fix indentation,
3943 autorelease fdesc, release fdAttrs and tdict.
3944 (ns_get_covering_families): Release charset.
3945 (ns_findfonts): Release NSFontDescriptor created with new.
3946 (ns_uni_to_glyphs): Fix indentation.
3947 (setString): Release attrStr before assigning new value.
3948
3949 2011-12-18 Jan Djärv <jan.h.d@swipnet.se>
3950
3951 * nsmenu.m (NSMenuDidBeginTrackingNotification): Declare if OSX < 10.5
3952 and NS_IMPL_COCOA.
3953 (trackingNotification): Surround with ifdef NS_IMPL_COCOA.
3954 (syms_of_nsmenu): Set trackingMenu to 1 if not NS_IMPL_COCOA.
3955
3956 2011-12-18 David Reitter <reitter@cmu.edu>
3957
3958 * nsterm.m (ns_term_init): Subscribe for notifications
3959 NSMenuDidBeginTrackingNotification and NSMenuDidEndTrackingNotification
3960 to method trackingNotification in EmacsMenu.
3961
3962 * nsmenu.m (trackingMenu): New variable.
3963 (trackingNotification): New method (from Aquamacs).
3964 (menuNeedsUpdate): Expand comment and return if trackingMenu is 0,
3965 from Aquamacs (Bug#7030).
3966
3967 2011-12-18 Jan Djärv <jan.h.d@swipnet.se>
3968
3969 * nsselect.m (CUT_BUFFER_SUPPORT): Remove define.
3970 (symbol_to_nsstring): Fix indentation.
3971 (ns_symbol_to_pb): New function.
3972 (Fns_get_selection_internal): Rename from Fns_get_cut_buffer_internal.
3973 (Fns_rotate_cut_buffers_internal): Remove.
3974 (Fns_store_selection_internal): Rename from
3975 Fns_store_cut_buffer_internal.
3976 (ns_get_foreign_selection, Fx_own_selection_internal)
3977 (Fx_disown_selection_internal, Fx_selection_exists_p)
3978 (Fns_get_selection_internal, Fns_store_selection_internal):
3979 Use ns_symbol_to_pb and check if return value is nil.
3980 (syms_of_nsselect): Remove ifdef CUT_BUFFER_SUPPORT. Remove defsubr
3981 Sns_rotate_cut_buffers_internal. Sns_get_cut_buffer_internal
3982 renamed to Sns_get_selection_internal, Sns_store_cut_buffer_internal
3983 renamed to Sns_store_selection_internal.
3984 (ns_handle_selection_request): Move code to Fx_own_selection_internal
3985 and remove this function.
3986 (ns_handle_selection_clear): Remove, never used.
3987 (Fx_own_selection_internal): Move code from ns_handle_selection_request
3988 here.
3989
3990 2011-12-17 Ken Brown <kbrown@cornell.edu>
3991
3992 * fileio.c (check_writable) [CYGWIN]: Return non-zero if UID or
3993 GID is unknown (Bug#10257).
3994
3995 2011-12-17 Paul Eggert <eggert@cs.ucla.edu>
3996
3997 * s/gnu-linux.h: Fix mark_memory typo (Bug#10286).
3998 (GC_MARK_SECONDARY_STACK): Omit removed 3rd arg to mark_memory,
3999 which caused a build failure on GNU/Linux IA-64. This problem was
4000 introduced by my 2011-10-07 patch.
4001
4002 2011-12-15 Juri Linkov <juri@jurta.org>
4003
4004 * image.c (imagemagick_error): New function. (Bug#10112)
4005 (imagemagick_load_image): Comment out `MagickSetResolution' call.
4006 Use `imagemagick_error' where ImageMagick functions return
4007 `MagickFalse'.
4008 (Fimagemagick_types): Add `Fnreverse' to return the list in the
4009 proper order.
4010
4011 2011-12-15 YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
4012
4013 * xftfont.c (xftfont_draw): Use the font metrics of s->font to
4014 fill background (Bug#8992).
4015
4016 2011-12-13 Martin Rudalics <rudalics@gmx.at>
4017
4018 * window.c (Vwindow_combination_resize)
4019 (Vwindow_combination_limit): Use t instead of non-nil in
4020 doc-strings.
4021 (Vrecenter_redisplay): Add first sentence of doc-string on
4022 separate line.
4023 (Frecenter): Fix doc-string typo.
4024
4025 2011-12-11 Kenichi Handa <handa@m17n.org>
4026
4027 * coding.c (Funencodable_char_position): Pay attention to the
4028 buffer text relocation (Bug#9389).
4029
4030 2011-12-10 Jan Djärv <jan.h.d@swipnet.se>
4031
4032 * xterm.c (x_term_init): Move call to gdk_window_add_filter before
4033 gtk_init (Bug#10100).
4034
4035 2011-12-10 Eli Zaretskii <eliz@gnu.org>
4036
4037 * xdisp.c (RECORD_MAX_MIN_POS): Use IT->cmp_it.charpos only if
4038 IT->string is nil. (Bug#10263)
4039
4040 2011-12-10 Jan Djärv <jan.h.d@swipnet.se>
4041
4042 * nsterm.h (x_free_frame_resources): Declare.
4043
4044 * nsfns.m (ns_get_defaults_value): New function (Bug#10103).
4045 (Fns_get_resource, x_get_string_resource): Call ns_get_defaults_value.
4046
4047 * nsterm.h (ns_get_defaults_value): Declare.
4048
4049 * nsterm.m (ns_default): Call ns_get_defaults_value.
4050
4051 2011-12-09 Eli Zaretskii <eliz@gnu.org>
4052
4053 * xdisp.c (try_scrolling): Don't set scroll_down_p if dy is zero.
4054 (Bug#10170)
4055
4056 2011-12-09 YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
4057
4058 * unexelf.c (unexec) [NS_IMPL_GNUSTEP]: Take account of the case
4059 that where the value of an _OBJC_* symbol points to is in the .bss
4060 section (Bug#10240).
4061
4062 2011-12-08 Kazuhiro Ito <kzhr@d1.dion.ne.jp> (tiny change)
4063
4064 * coding.c (encode_coding_ccl): Check (charbuf < charbuf_end)
4065 after the loop to call ccl_driver at least once (Bug#8619).
4066
4067 2011-12-08 Kenichi Handa <handa@m17n.org>
4068
4069 * ftfont.c (get_adstyle_property): Fix previous change
4070 (Bug#10233).
4071
4072 2011-12-07 Juanma Barranquero <lekktu@gmail.com>
4073
4074 * w32.c (init_environment): If no_site_lisp, remove site-lisp
4075 dirs from the default value of EMACSLOADPATH (bug#10208).
4076
4077 2011-12-07 Glenn Morris <rgm@gnu.org>
4078
4079 * lread.c (init_lread): If no_site_lisp, exclude site-lisp/ in
4080 installation and source directories as well. (Bug#10208)
4081
4082 2011-12-06 Chong Yidong <cyd@gnu.org>
4083
4084 * minibuf.c (Fread_from_minibuffer): Doc fix (Bug#10228).
4085
4086 2011-12-06 Glenn Morris <rgm@gnu.org>
4087
4088 * process.c (start_process_unwind): Treat any pid <= 0, except -2,
4089 as an error, not just -1. (Bug#10217)
4090
4091 2011-12-05 Chong Yidong <cyd@gnu.org>
4092
4093 * keyboard.c (process_special_events): New function.
4094 (swallow_events, Finput_pending_p): Use it (Bug#10195).
4095
4096 2011-12-05 Paul Eggert <eggert@cs.ucla.edu>
4097
4098 * coding.c (encode_designation_at_bol): Don't use uninitialized
4099 local variable (Bug#9318).
4100
4101 2011-12-05 Kenichi Handa <handa@m17n.org>
4102
4103 * ftfont.c (get_adstyle_property): If the font is not BDF nor PCF,
4104 return Qnil (Bug#8046, Bug#10193).
4105
4106 2011-12-05 Kenichi Handa <handa@m17n.org>
4107
4108 * coding.c (encode_designation_at_bol): New args charbuf_end and
4109 dst. Return the number of produced bytes. Callers changed.
4110 (coding_set_source): Return how many bytes coding->source was
4111 relocated.
4112 (coding_set_destination): Return how many bytes
4113 coding->destination was relocated.
4114 (CODING_DECODE_CHAR, CODING_ENCODE_CHAR, CODING_CHAR_CHARSET)
4115 (CODING_CHAR_CHARSET_P): Adjust for the avove changes.
4116
4117 2011-12-05 Kazuhiro Ito <kzhr@d1.dion.ne.jp> (tiny change)
4118
4119 * coding.c (CODING_CHAR_CHARSET_P): New macro.
4120 (encode_coding_emacs_mule, encode_coding_iso_2022): Use the above
4121 macro (Bug#9318).
4122
4123 2011-12-05 Andreas Schwab <schwab@linux-m68k.org>
4124
4125 The following changes are to fix Bug#9318.
4126
4127 * coding.c (CODING_ENCODE_CHAR, CODING_CHAR_CHARSET): New macros.
4128 (encode_coding_emacs_mule, ENCODE_ISO_CHARACTER)
4129 (encode_coding_iso_2022, encode_coding_sjis)
4130 (encode_coding_big5, encode_coding_charset): Use the above macros.
4131
4132 2011-12-05 Juanma Barranquero <lekktu@gmail.com>
4133
4134 * lisp.h (process_quit_flag): Fix external declaration.
4135
4136 2011-12-04 Stefan Monnier <monnier@iro.umontreal.ca>
4137
4138 Don't macro-inline non-performance-critical code.
4139 * eval.c (process_quit_flag): New function.
4140 * lisp.h (QUIT): Use it.
4141
4142 2011-12-04 Jan Djärv <jan.h.d@swipnet.se>
4143
4144 * nsfns.m (get_geometry_from_preferences): New function.
4145 (Fx_create_frame): Call get_geometry_from_preferences (Bug#10103).
4146
4147 2011-12-04 Andreas Schwab <schwab@linux-m68k.org>
4148
4149 * emacs.c (Qkill_emacs): Define.
4150 (syms_of_emacs): Initialize it.
4151 * keyboard.c (interrupt_signal): Don't call Fkill_emacs here, set
4152 Qquit_flag to `kill-emacs' instead.
4153 (quit_throw_to_read_char): Add parameter `from_signal'.
4154 All callers changed. Call Fkill_emacs if requested and safe.
4155 * lisp.h (QUIT): Call Fkill_emacs if requested.
4156
4157 2011-12-03 Jan Djärv <jan.h.d@swipnet.se>
4158
4159 * widget.c (update_wm_hints): Return if wmshell is null.
4160 (widget_update_wm_size_hints): New function.
4161
4162 * widget.h (widget_update_wm_size_hints): Declare.
4163
4164 * xterm.c (x_wm_set_size_hint): If USE_X_TOOLKIT, call
4165 widget_update_wm_size_hints (Bug#10104).
4166
4167 2011-12-03 Eli Zaretskii <eliz@gnu.org>
4168
4169 * xdisp.c (handle_invisible_prop): If the invisible text ends just
4170 before a newline, prepare the bidi iterator for consuming the
4171 newline, and keep the current paragraph direction. (Bug#10183)
4172 (redisplay_window): Don't let `margin' become negative. (Bug#10192)
4173
4174 2011-12-02 Juri Linkov <juri@jurta.org>
4175
4176 * search.c (Fword_search_regexp): New Lisp function created from
4177 `wordify'. Change type of arg `lax' from `int' to `Lisp_Object'.
4178 (Fword_search_backward, Fword_search_forward)
4179 (Fword_search_backward_lax, Fword_search_forward_lax):
4180 Use `Fword_search_regexp' instead of `wordify'. Doc fix.
4181 (syms_of_search): Define `Sword_search_regexp'. (Bug#10145)
4182
4183 2011-12-01 Stefan Monnier <monnier@iro.umontreal.ca>
4184
4185 * fileio.c (Finsert_file_contents): Move after-change-function call
4186 to before the "handled:" label, since all "goto handled" appear in
4187 cases where the *-change-functions have already been properly called
4188 (bug#10117).
4189
4190 2011-12-01 Andreas Schwab <schwab@linux-m68k.org>
4191
4192 * keyboard.c (interrupt_signal): Don't call kill-emacs when
4193 waiting for input. (Bug#10169)
4194
4195 2011-11-30 Eli Zaretskii <eliz@gnu.org>
4196
4197 * dispnew.c (adjust_glyph_matrix): Remove the assertion that
4198 verifies glyph row's hash code--we have just reallocated the
4199 glyphs, so their contents can be complete garbage. (Bug#10164)
4200
4201 2011-11-30 Juanma Barranquero <lekktu@gmail.com>
4202
4203 * dispnew.c (adjust_glyph_matrix) [XASSERTS]: Add missing check.
4204
4205 2011-11-30 Eli Zaretskii <eliz@gnu.org>
4206
4207 * dispnew.c (adjust_glyph_matrix) [XASSERTS]: Ensure ROW's
4208 attributes are tested _before_ calling verify_row_hash, to protect
4209 against GCC re-ordering of the tests. (Bug#10164)
4210
4211 2011-11-29 Jan Djärv <jan.h.d@swipnet.se>
4212
4213 * xterm.h (struct x_output): net_wm_state_hidden_seen is new.
4214
4215 * xterm.c (handle_one_xevent): Only set async_visible and friends
4216 if net_wm_state_hidden_seen is non-zero (Bug#10002)
4217 (get_current_wm_state): Set net_wm_state_hidden_seen to 1 if
4218 _NET_WM_STATE_HIDDEN is in NET_WM_STATE.
4219
4220 2011-11-28 Paul Eggert <eggert@cs.ucla.edu>
4221
4222 Remove GCPRO-related macros that exist only to avoid shadowing locals.
4223 * lisp.h (GCPRO1_VAR, GCPRO2_VAR, GCPRO3_VAR, GCPRO4_VAR, GCPRO5_VAR)
4224 (GCPRO6_VAR, UNGCPRO_VAR): Remove. See
4225 <http://lists.gnu.org/archive/html/emacs-diffs/2011-11/msg00265.html>.
4226 All uses changed to use GCPRO1 etc.
4227 (GCPRO1, GCPRO2, GCPRO3, GCPRO4, GCPRO5, GCPRO6, UNGCPRO):
4228 Revert to old implementation (i.e., before 2011-03-11).
4229
4230 2011-11-28 YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
4231
4232 * dispnew.c (scrolling_window): Truncate overlaps in copy destination
4233 of scroll runs so as to avoid assigning disabled bogus rows and
4234 unnecessary graphics copy operations.
4235
4236 2011-11-27 Eli Zaretskii <eliz@gnu.org>
4237
4238 * s/ms-w32.h (utimbuf) [_MSC_VER]: Don't define.
4239 (snprintf) [_MSC_VER]: Redirect to _snprintf.
4240 (strtoll) [_MSC_VER]: Redirect to _strtoi64.
4241 (malloc, free, realloc, calloc): Redirect to e_* only when
4242 compiling Emacs.
4243
4244 * lisp.h (GCTYPEBITS): Move before first use.
4245 (ALIGN_GCTYPEBITS) [_MSC_VER]: Define.
4246 (DECL_ALIGN) [_MSC_VER]: Use it, as MSVC doesn't like bit ops in
4247 this macro definition.
4248
4249 * s/ms-w32.h (tzname): Redirect to _tzname for all values of
4250 _MSC_VER.
4251
4252 2011-11-27 Jan Djärv <jan.h.d@swipnet.se>
4253
4254 * gtkutil.c (xg_create_frame_widgets):
4255 Call gtk_window_set_has_resize_grip (FALSE) if that function is
4256 present with Gtk+ 2.0.
4257
4258 2011-11-26 Paul Eggert <eggert@cs.ucla.edu>
4259
4260 * fileio.c (Finsert_file_contents): Undo previous change; see
4261 <http://lists.gnu.org/archive/html/emacs-diffs/2011-11/msg00265.html>.
4262
4263 2011-11-26 Paul Eggert <eggert@cs.ucla.edu>
4264
4265 Rename locals to avoid shadowing.
4266 * fileio.c (Finsert_file_contents):
4267 Rename inner 'gcpro1' to 'inner_gcpro1' to avoid shadowing.
4268 * process.c (wait_reading_process_output):
4269 Rename inner 'proc' to 'p' to avoid shadowing.
4270 Indent for consistency with usual Emacs style.
4271
4272 2011-11-25 Eli Zaretskii <eliz@gnu.org>
4273
4274 * xdisp.c (redisplay_window): If cursor row is not fully visible
4275 after recentering, and scroll-conservatively is set to a large
4276 number, scroll window by a few more lines to make the cursor fully
4277 visible and out of scroll-margin. (Bug#10105)
4278 (start_display): Don't move to the next line if the display should
4279 start at a newline that is part of a display vector or an overlay
4280 string. (Bug#10119)
4281
4282 2011-11-24 Juri Linkov <juri@jurta.org>
4283
4284 * image.c (imagemagick_load_image): Move `MagickSetResolution' down
4285 after the `MagickPingImage' call. (Bug#10112)
4286
4287 2011-11-23 Chong Yidong <cyd@gnu.org>
4288
4289 * window.c (Fcoordinates_in_window_p): Accept only live windows.
4290
4291 2011-11-23 Martin Rudalics <rudalics@gmx.at>
4292
4293 * buffer.c (Fkill_buffer): Run replace_buffer_in_windows before
4294 making another buffer current. (Bug#10114)
4295
4296 2011-11-23 Glenn Morris <rgm@gnu.org>
4297
4298 * font.c (font_find_for_lface) [HAVE_NS]: Ignore case. (Bug#2526)
4299
4300 2011-11-23 Chong Yidong <cyd@gnu.org>
4301
4302 * xdisp.c (compute_stop_pos): Check validity of end_charpos before
4303 using it (Bug#5984).
4304
4305 2011-11-22 Eli Zaretskii <eliz@gnu.org>
4306
4307 * dispnew.c (adjust_glyph_matrix): Don't verify hash code of mode-
4308 and header-lines, as they don't have one computed for them.
4309 (Bug#10098)
4310
4311 * .gdbinit (prow): Make displayed values more self-explaining.
4312 Add row's hash code.
4313
4314 2011-11-21 Lars Magne Ingebrigtsen <larsi@gnus.org>
4315
4316 * process.c (wait_reading_process_output): Fix asynchrounous
4317 GnuTLS socket handling on some versions of the GnuTLS library.
4318 (wait_reading_process_output): Add comment and URL.
4319
4320 2011-11-21 Jan Djärv <jan.h.d@swipnet.se>
4321
4322 * xterm.c (x_clear_frame): Reinstate the XClearWindow call.
4323
4324 2011-11-21 Chong Yidong <cyd@gnu.org>
4325
4326 * window.c (Fnext_window, Fprevious_window): Doc fix.
4327
4328 2011-11-20 Stefan Monnier <monnier@iro.umontreal.ca>
4329
4330 * window.c (get_phys_cursor_glyph): Fix Lisp_Object/int mixup.
4331
4332 2011-11-20 Juanma Barranquero <lekktu@gmail.com>
4333
4334 * nsfont.m (syms_of_nsfont) <ns-reg-to-script>: Fix typo.
4335
4336 2011-11-20 Martin Rudalics <rudalics@gmx.at>
4337
4338 * window.c (Fset_window_combination_limit): Rename argument
4339 STATUS to LIMIT.
4340 (Vwindow_combination_limit): Remove "status" from doc-string.
4341
4342 2011-11-20 Andreas Schwab <schwab@linux-m68k.org>
4343
4344 * m/ibms390.h: Remove.
4345 * m/ibms390x.h: Don't include "ibms390.h".
4346
4347 2011-11-20 Stefan Monnier <monnier@iro.umontreal.ca>
4348
4349 * fileio.c (Finsert_file_contents): Add missing gcpro1 variable.
4350 Suggested by Dmitry Antipov <dmantipov@yandex.ru>.
4351
4352 2011-11-20 Juanma Barranquero <lekktu@gmail.com>
4353
4354 * casetab.c (Fset_case_table):
4355 * charset.c (Fcharset_after): Fix typos.
4356
4357 2011-11-20 Paul Eggert <eggert@cs.ucla.edu>
4358
4359 Standardize on VIRT_ADDR_VARIES behavior (Bug#10042).
4360 Otherwise, valgrind does not work on some platforms.
4361 Problem reported by Andreas Schwab in
4362 <http://lists.gnu.org/archive/html/emacs-devel/2011-11/msg00081.html>.
4363 * puresize.h (pure, PURE_P): Always behave as if VIRT_ADDR_VARIES
4364 is set, removing the need for VIRT_ADDRESS_VARIES.
4365 (PURE_P): Use a more-efficient implementation that needs just one
4366 comparison, not two: on x86-64 with GCC 4.6.2, this cut down the
4367 number of instructions from 6 (xorl, cmpq, jge, xorl, cmpq, setge)
4368 to 4 (xorl, subq, cmpq, setbe).
4369 * alloc.c (pure): Always extern now, since that's the
4370 VIRT_ADDR_VARIES behavior.
4371 (PURE_POINTER_P): Use a single comparison, not two, for
4372 consistency with the new puresize.h.
4373 * lisp.h (PNTR_COMPARISON_TYPE): Remove; no longer needed.
4374 * m/ibms390.h, m/intel386.h, m/template.h, s/cygwin.h, s/hpux10-20.h:
4375 Remove VIRT_ADDR_VARIES no longer needed.
4376
4377 2011-11-19 Eli Zaretskii <eliz@gnu.org>
4378
4379 * xdisp.c (x_write_glyphs, draw_phys_cursor_glyph)
4380 (erase_phys_cursor, update_window_cursor, show_mouse_face)
4381 (cursor_in_mouse_face_p): If the cursor position is out of bounds,
4382 behave as if the cursor position were at the window margin.
4383
4384 * window.c (get_phys_cursor_glyph): If the window is hscrolled,
4385 and the cursor position is out of bounds, behave as if the cursor
4386 position were at the window margin. (Bug#10075)
4387
4388 2011-11-18 Chong Yidong <cyd@gnu.org>
4389
4390 * window.c (Fwindow_combination_limit): Make first argument
4391 non-optional, since it is meaningless for live windows like the
4392 selected window.
4393
4394 2011-11-18 Dmitry Antipov <dmantipov@yandex.ru>
4395
4396 * keymap.c (Fwhere_is_internal): Add missing RETURN_UNGCPROs.
4397
4398 2011-11-18 Stefan Monnier <monnier@iro.umontreal.ca>
4399
4400 * intervals.c: Fix grafting over the whole buffer (bug#10071).
4401 (graft_intervals_into_buffer): Simplify.
4402
4403 2011-11-18 Eli Zaretskii <eliz@gnu.org>
4404
4405 * dispnew.c (swap_glyph_pointers): Swap the used[] arrays and the
4406 hash values of the two rows.
4407 (copy_row_except_pointers): Preserve the used[] arrays and the
4408 hash values of the two rows. (Bug#10035)
4409 (add_row_entry): Add xassert to verify that ROW's hash code is valid.
4410
4411 * xdisp.c (row_hash): New function, body extracted from
4412 compute_line_metrics.
4413 (compute_line_metrics): Call row_hash, instead of computing the
4414 hash code inline.
4415
4416 * dispnew.c (verify_row_hash): Call row_hash for computing the
4417 hash code of a row, instead of duplicating code from xdisp.c.
4418
4419 * dispextern.h (row_hash): Add prototype.
4420
4421 2011-11-18 Tassilo Horn <tassilo@member.fsf.org>
4422
4423 * frame.c (delete_frame): Don't delete the terminal when the last
4424 X frame is closed if emacs is built with GTK toolkit.
4425
4426 2011-11-17 Juanma Barranquero <lekktu@gmail.com>
4427
4428 * window.c (syms_of_window) <window-combination-resize>: Fix typo.
4429
4430 2011-11-17 Martin Rudalics <rudalics@gmx.at>
4431
4432 * window.c (Vwindow_splits): Rename to
4433 Vwindow_combination_resize. Suggested by Juri Linkov.
4434 (Fsplit_window_internal): Use Vwindow_combination_resize instead
4435 of Vwindow_splits.
4436
4437 2011-11-16 Juanma Barranquero <lekktu@gmail.com>
4438
4439 * nsfns.m (Fns_font_name):
4440 * window.c (syms_of_window) <window-combination-limit>: Fix typos.
4441
4442 2011-11-16 Martin Rudalics <rudalics@gmx.at>
4443
4444 * window.h (window): Rename slot "nest" to "combination_limit".
4445 * window.c (Fwindow_nest): Rename to Fwindow_combination_limit.
4446 (Fset_window_nest): Rename to Fset_window_combination_limit.
4447 (Vwindow_nest): Rename to Vwindow_combination_limit.
4448 (recombine_windows, make_parent_window, make_window)
4449 (Fsplit_window_internal, saved_window)
4450 (Fset_window_configuration, save_window_save): Rename all
4451 occurrences of window_nest to window_combination_limit.
4452
4453 2011-11-15 Juanma Barranquero <lekktu@gmail.com>
4454
4455 * image.c (imagemagick_load_image): Fix typo.
4456
4457 2011-11-14 Eli Zaretskii <eliz@gnu.org>
4458
4459 * xdisp.c (display_line): Move the call to
4460 highlight_trailing_whitespace before the call to
4461 compute_line_metrics, since the latter needs to see the final
4462 faces of all the glyphs to compute ROW's hash value.
4463 Fixes assertion violations in row_equal_p. (Bug#10035)
4464
4465 2011-11-14 Juanma Barranquero <lekktu@gmail.com>
4466
4467 * w32proc.c (reader_thread): Don't check pending input if cp->fd < 0,
4468 just return (bug#10044).
4469
4470 2011-11-12 Eli Zaretskii <eliz@gnu.org>
4471
4472 * makefile.w32-in (HEAPSIZE): New variable, allows to build temacs
4473 with user-defined heap size. Bump the default size of the temacs
4474 heap to 27MB, to avoid memory warning when running temacs.
4475 ($(TEMACS)): Use HEAPSIZE instead of a hardcoded value.
4476
4477 * dispnew.c (scrolling_window): Fix incorrect indices in accessing
4478 current_matrix and desired_matrix. (Bug#9990)
4479 (verify_row_hash) [XASSERTS]: New function.
4480 (adjust_glyph_matrix, row_equal_p): Use it in xassert to verify
4481 that the hash value of glyph rows is correct.
4482
4483 2011-11-12 Martin Rudalics <rudalics@gmx.at>
4484
4485 * window.h (window): Remove splits slot.
4486 * window.c (Fwindow_splits, Fset_window_splits): Remove.
4487 (Fdelete_other_windows_internal, make_parent_window)
4488 (make_window, Fsplit_window_internal, Fdelete_window_internal)
4489 (Fset_window_configuration, save_window_save): Don't deal with
4490 split status of windows.
4491 (saved_window): Remove splits slot.
4492 (Vwindow_splits): Rewrite doc-string.
4493
4494 2011-11-11 Jan Djärv <jan.h.d@swipnet.se>
4495
4496 * xfns.c (unwind_create_frame):
4497 * nsfns.m (unwind_create_frame):
4498 * w32fns.c (unwind_create_frame): Use Fmemq to check if frame is in
4499 Vframe_list (Bug#9999).
4500
4501 2011-11-11 Dmitry Antipov <dmantipov@yandex.ru>
4502
4503 * xdisp.c (syms_of_xdisp): Remove duplicated definition of Qtext.
4504
4505 2011-11-11 Kenichi Handa <handa@m17n.org>
4506
4507 * callproc.c (Fcall_process): Set the member dst_multibyte of
4508 process_coding.
4509
4510 2011-11-11 Johan Bockgård <bojohan@gnu.org>
4511
4512 * xdisp.c (fill_composite_glyph_string): Always set s->face, to
4513 avoid a crash (bug#9496).
4514
4515 2011-11-09 Chong Yidong <cyd@gnu.org>
4516
4517 * window.c (Fwindow_inside_edges, Fwindow_inside_pixel_edges)
4518 (Fwindow_inside_absolute_pixel_edges): Only allow live windows.
4519
4520 2011-11-08 Paul Eggert <eggert@cs.ucla.edu>
4521
4522 * s/gnu.h (GC_MARK_STACK): Define to GC_MAKE_GCPROS_NOOPS (Bug#9926).
4523
4524 2011-11-08 Paul Eggert <eggert@cs.ucla.edu>
4525
4526 Avoid some portability problems by eschewing 'extern inline' functions.
4527 The trivial performance wins aren't worth the portability hassles; see
4528 <http://lists.gnu.org/archive/html/emacs-devel/2011-11/msg00084.html>
4529 et seq.
4530 * dispextern.h (window_box, window_box_height, window_text_bottom_y)
4531 (window_box_width, window_box_left, window_box_left_offset)
4532 (window_box_right, window_box_right_offset): Undo previous change,
4533 by removing the "extern"s.
4534 * intervals.c (adjust_intervals_for_insertion)
4535 (adjust_intervals_for_deletion): Undo previous change,
4536 making these static again.
4537 (offset_intervals, temp_set_point_both, temp_set_point)
4538 (copy_intervals_to_string): No longer inline.
4539 * xdisp.c (window_text_bottom_y, window_box_width)
4540 (window_box_height, window_box_left_offset)
4541 (window_box_right_offset, window_box_left, window_box_right)
4542 (window_box): No longer inline.
4543
4544 2011-11-08 Chong Yidong <cyd@gnu.org>
4545
4546 * window.c (Fwindow_left_column, Fwindow_top_line): Doc fix.
4547 (Fwindow_body_height, Fwindow_body_width): Move from Lisp.
4548 Signal an error if not a live window.
4549 (Fwindow_total_width, Fwindow_total_height): Move from Lisp.
4550 (Fwindow_total_size, Fwindow_body_size): Move to Lisp.
4551
4552 2011-11-07 Juanma Barranquero <lekktu@gmail.com>
4553
4554 * lisp.h (syms_of_abbrev): Remove declaration.
4555 Reported by CHENG Gao <chenggao@royau.me>.
4556
4557 2011-11-07 Eli Zaretskii <eliz@gnu.org>
4558
4559 * w32.c (check_windows_init_file): Don't look for term/w32-win.el
4560 if Vpurify_flag is non-nil. Fixes a crash when running w32 build
4561 of temacs in GUI mode.
4562
4563 2011-11-07 Martin Rudalics <rudalics@gmx.at>
4564
4565 * window.h: Declare delete_all_child_windows instead of
4566 delete_all_subwindows.
4567 * window.c (Fwindow_nest, Fset_window_nest)
4568 (Fset_window_new_total, Fset_window_new_normal)
4569 (Fwindow_resize_apply): Don't use term subwindow in doc-strings.
4570 (delete_all_subwindows): Rename to delete_all_child_windows.
4571 (Fdelete_other_windows_internal, Fset_window_configuration):
4572 Call delete_all_child_windows instead of delete_all_subwindows.
4573 * frame.c (delete_frame): Call delete_all_child_windows instead
4574 of delete_all_subwindows.
4575
4576 2011-11-07 Paul Eggert <eggert@cs.ucla.edu>
4577
4578 * alloc.c (DEADP): New macro, for porting to GNU/Hurd (Bug#9926).
4579 This is also needed for porting to any host where GC_MARK_STACK is
4580 not GC_MAKE_GCPROS_NOOPS.
4581 (which_symbols): Use it.
4582
4583 2011-11-07 Kenichi Handa <handa@m17n.org>
4584
4585 * coding.c (coding_set_destination): Check coding->src_pos only
4586 when coding->src_object is a buffer (bug#9910).
4587
4588 * process.c (send_process): Set the member src_multibyte of coding
4589 to 0 (bug#9911) when sending a unibyte text.
4590
4591 * callproc.c (Fcall_process): Set the member src_multibyte of
4592 process_coding to 0 (bug#9912).
4593
4594 2011-11-06 YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
4595
4596 * xmenu.c (cleanup_widget_value_tree): New function.
4597 (xmenu_show, xdialog_show): Use it in record_unwind_protect instead of
4598 calling free_menubar_widget_value_tree directly (Bug#9830).
4599
4600 2011-11-06 Paul Eggert <eggert@cs.ucla.edu>
4601
4602 Fix some portability problems with 'inline'.
4603 * dispextern.h (window_box, window_box_height, window_text_bottom_y)
4604 (window_box_width, window_box_left, window_box_left_offset)
4605 (window_box_right, window_box_right_offset): Declare extern.
4606 Otherwise, these inline functions do not conform to C99 and
4607 are miscompiled by Microsoft compilers. Reported by Eli Zaretskii in
4608 <http://lists.gnu.org/archive/html/emacs-devel/2011-11/msg00084.html>.
4609 * intervals.c (adjust_intervals_for_insertion)
4610 (adjust_intervals_for_deletion): Now extern, because otherwise the
4611 extern inline functions 'offset_intervals' couldn't refer to it.
4612 (static_offset_intervals): Remove.
4613 (offset_intervals): Rewrite using the old contents of
4614 static_offset_intervals. The old version didn't conform to C99
4615 because an extern inline function contained a reference to an
4616 identifier with static linkage.
4617
4618 2011-11-06 Andreas Schwab <schwab@linux-m68k.org>
4619
4620 * keyboard.c (interrupt_signal): Don't call kill-emacs while in
4621 GC.
4622
4623 2011-11-06 Eli Zaretskii <eliz@gnu.org>
4624
4625 * xdisp.c (init_iterator, reseat_to_string): Don't set the
4626 iterator's bidi_p flag if Vpurify_flag is non-nil. (Bug#9963)
4627 (Fcurrent_bidi_paragraph_direction): If Vpurify_flag is non-nil,
4628 return Qleft_to_right.
4629
4630 2011-11-06 Chong Yidong <cyd@gnu.org>
4631
4632 * window.c (Fwindow_live_p, Fwindow_frame, Fframe_root_window)
4633 (Fminibuffer_window, Fwindow_buffer, Fwindow_splits)
4634 (Fset_window_splits, Fwindow_nest, Fset_window_nest)
4635 (Fwindow_use_time, Fwindow_total_size, Fwindow_normal_size)
4636 (Fwindow_new_normal, Fwindow_left_column, Fwindow_top_line)
4637 (Fwindow_margins, Fwindow_fringes, Fwindow_scroll_bars)
4638 (Fwindow_vscroll): Doc fix.
4639 (Fwindow_top_child, Fwindow_left_child): Eliminate a nil default
4640 argument, since it makes no sense to pass a live window and for
4641 consistency with window-child.
4642
4643 2011-11-05 Christoph Scholtes <cschol2112@googlemail.com>
4644
4645 * makefile.w32-in ($(TEMACS), (gl-stamp)): Use $(THISDIR) to
4646 support MSVC.
4647
4648 2011-11-05 Jason Rumney <jasonr@gnu.org>
4649
4650 * w32font.c (font_matches_spec): Filter out non-Japanese kana fonts.
4651 (add_font_entity_to_list): Filter out non-Japanese Shift-JIS
4652 fonts (Bug#6029).
4653 (add_font_entity_to_list): Fix logic errors in mixed boolean and
4654 bitwise arithmetic preventing use of unicode-sip and non-truetype
4655 opentype fonts.
4656
4657 2011-11-05 Eli Zaretskii <eliz@gnu.org>
4658
4659 * s/ms-w32.h (fstat, stat, utime): Move redirections to
4660 "emacs"-only part.
4661
4662 * w32fns.c (x_create_tip_frame, Fx_create_frame): Rearrange
4663 initialization code to keep similarity to xfns.c after changes
4664 from 2011-11-05.
4665
4666 2011-11-05 Jan Djärv <jan.h.d@swipnet.se>
4667
4668 * nsfns.m: Declare image_cache_refcount if GLYPH_DEBUG.
4669 (unwind_create_frame): New function (Bug#9943).
4670 (Fx_create_frame): Restructure code to be more similar to the one in
4671 xfns.c. Call record_unwind_protect with unwind_create_frame (Bug#9943).
4672 Initialize image_cache_refcount if GLYPH_DEBUG (Bug#9943).
4673 Move terminal->reference_count++ just before making the frame official
4674 (Bug#9943).
4675
4676 * nsterm.m (x_free_frame_resources): New function.
4677 (x_destroy_window): Move code to x_free_frame_resources.
4678
4679 * xfns.c (unwind_create_frame): Fix comment.
4680 (Fx_create_frame, x_create_tip_frame):
4681 Move terminal->reference_count++ just before making the frame
4682 official. Move initialization of image_cache_refcount and
4683 dpyinfo_refcount before calling init_frame_faces (Bug#9943).
4684
4685 2011-11-05 Eli Zaretskii <eliz@gnu.org>
4686
4687 Support MSVC build with newer versions of Visual Studio.
4688 * makefile.w32-in (TAGS-gmake): Don't use $(patsubst ...), as
4689 Nmake barfs on that. Use $(OBJ*_c) variables instead, defined on
4690 nt/gmake.defs.
4691
4692 * lisp.h (ENUM_BF): New macro, for enumerated types in bitfields,
4693 which are not supported by MSVC.
4694 (Lisp_Symbol, Lisp_Misc_Any, Lisp_Marker, Lisp_Misc_Overlay)
4695 (Lisp_Save_Value, Lisp_Free): Use ENUM_BF for enumerated types in
4696 bitfields.
4697 (Lisp_Object) [USE_LISP_UNION_TYPE]: Use ENUM_BF for enumerated
4698 types in bitfields.
4699 (DEFUN) [_MSC_VER]: Define in a different way for MSVC.
4700
4701 * w32fns.c [_MSC_VER]: DECLARE_HANDLE for any MSVC version.
4702
4703 2011-11-05 Fabrice Popineau <fabrice.popineau@supelec.fr> (tiny change)
4704
4705 Support MSVC build with newer versions of Visual Studio.
4706 * w32.c: Don't include w32api.h for MSVC.
4707 (init_environment) [_MSC_VER]: Call sys_access, not _access.
4708
4709 * s/ms-w32.h <sigset_t, ssize_t> [_MSC_VER]: Typedefs for MSVC.
4710 [_MSC_VER]: Include sys/timeb.h, sys/stat.h, and signal.h.
4711 (fstat, stat, utime) [_MSC_VER]: Redirect to their sys_* cousins.
4712 (malloc, free, realloc, calloc) [_MSC_VER]: Always redirect to the
4713 e_* cousins.
4714 (alloca) [_MSC_VER]: Define to _alloca.
4715
4716 * lisp.h (DECL_ALIGN) [_MSC_VER]: Define for MSVC.
4717
4718 * regex.c <re_char> [_MSC_VER]: A separate definition for MSVC.
4719
4720 2011-11-04 Eli Zaretskii <eliz@gnu.org>
4721
4722 * xdisp.c (note_mouse_highlight): If either of
4723 previous/next-single-property-change returns nil, treat that as
4724 the beginning or the end of the buffer. (Bug#9955)
4725
4726 2011-11-04 Jan Djärv <jan.h.d@swipnet.se>
4727
4728 * gtkutil.c (xg_make_tool_item): Add callbacks if one of wimage or
4729 label is not null (Bug#9951).
4730 (xg_tool_item_stale_p): Handle the fact that wimage and/or wlbl
4731 may be NULL.
4732
4733 2011-11-04 Eli Zaretskii <eliz@gnu.org>
4734
4735 * window.c (Fwindow_body_size): Mention in the doc string that the
4736 return value is in frame's canonical units. (Bug#9949)
4737
4738 2011-11-03 Eli Zaretskii <eliz@gnu.org>
4739
4740 * xdisp.c (note_mouse_highlight): Initialize `area'. (Bug#9947)
4741
4742 * w32fns.c (unwind_create_frame): If needed, free the glyph
4743 matrices of the partially constructed frame. (Bug#9943)
4744 * xfns.c (unwind_create_frame): Likewise.
4745
4746 2011-11-01 Eli Zaretskii <eliz@gnu.org>
4747
4748 * xdisp.c (mouse_face_from_buffer_pos): Fix a typo in a comment.
4749 Don't stop backward scan on the continuation glyph, even though
4750 its CHARPOS is positive.
4751 (mouse_face_from_buffer_pos, note_mouse_highlight):
4752 Rename cover_string to disp_string.
4753
4754 2011-11-01 Martin Rudalics <rudalics@gmx.at>
4755
4756 * window.c (temp_output_buffer_show): Don't use
4757 Vtemp_buffer_show_specifiers.
4758 (Vtemp_buffer_show_specifiers): Remove unused variable.
4759
4760 2011-10-30 Eli Zaretskii <eliz@gnu.org>
4761
4762 * xdisp.c (try_cursor_movement): Make sure ROW isn't decremented
4763 past the beginning of the current glyph matrix.
4764
4765 2011-10-30 Adam Sjøgren <asjo@koldfront.dk> (tiny change)
4766
4767 * xterm.c: Include X11/Xproto.h if HAVE_GTK3.
4768 (x_error_handler): Ignore BadMatch for X_SetInputFocus for
4769 HAVE_GTK3 (Bug#9869).
4770
4771 * gtkutil.c (xg_win_to_widget, xg_event_is_for_menubar): Initialize
4772 type to GDK_NOTHING so valgrind does not complain (Bug#9901).
4773
4774 * xterm.h (x_display_info): Add Xatom_net_wm_state_hidden (Bug#9893).
4775
4776 * xterm.c: Declare x_handle_net_wm_state to return int.
4777 (handle_one_xevent): Check if we are iconified but don't have
4778 _NET_WM_STATE_HIDDEN. If do, treat as deiconify (Bug#9893).
4779 (get_current_wm_state): Return non-zero if not hidden,
4780 check for _NET_WM_STATE_HIDDEN (Bug#9893).
4781 (do_ewmh_fullscreen): Ignore return value from get_current_wm_state.
4782 (x_handle_net_wm_state): Return what get_current_wm_state returns.
4783 (x_term_init): Initialize dpyinfo->Xatom_net_wm_state_hidden.
4784
4785 2011-10-29 Paul Eggert <eggert@cs.ucla.edu>
4786
4787 * alloc.c (which_symbols): Declare EXTERNALLY_VISIBLE,
4788 so that this new function doesn't get optimized away by a
4789 whole-program optimizer. Make the 2nd arg EMACS_INT, not int.
4790
4791 2011-10-29 Andreas Schwab <schwab@linux-m68k.org>
4792
4793 * frame.h (MOUSE_HL_INFO): Remove excess parens.
4794
4795 2011-10-29 Eli Zaretskii <eliz@gnu.org>
4796
4797 Fix the `xbytecode' command.
4798 * .gdbinit (xprintbytestr): New command.
4799 (xwhichsymbols): Rename from `which'; all callers changed.
4800 (xbytecode): Print the byte-code string as well.
4801
4802 2011-10-29 Kim Storm <storm@cua.dk>
4803
4804 * alloc.c (which_symbols): New function.
4805
4806 2011-10-29 Andreas Schwab <schwab@linux-m68k.org>
4807
4808 * minibuf.c (read_minibuf_noninteractive): Allow reading empty
4809 line. (Bug#9903)
4810
4811 2011-10-29 Glenn Morris <rgm@gnu.org>
4812
4813 * process.c (wait_reading_process_output): Revert 2009-08-30 change.
4814 Not clear what it was for, and it causes various bugs. (Bug#9839)
4815
4816 2011-10-28 Eli Zaretskii <eliz@gnu.org>
4817
4818 * xdisp.c (note_mouse_highlight): Initialize `part', to avoid a
4819 possible random value that matches one of those tested as
4820 condition to clear the mouse face.
4821
4822 2011-10-28 Chong Yidong <cyd@gnu.org>
4823
4824 * xdisp.c (note_mouse_highlight): Fix use of uninitialized var.
4825
4826 2011-10-28 Dan Nicolaescu <dann@ics.uci.edu>
4827
4828 * window.c (make_window): Initialize phys_cursor_on_p.
4829
4830 2011-10-28 Stefan Monnier <monnier@iro.umontreal.ca>
4831
4832 * lisp.h (struct Lisp_Symbol): Update comments.
4833
4834 2011-10-28 Juanma Barranquero <lekktu@gmail.com>
4835
4836 * w32font.c (w32_load_unicows_or_gdi32): Add missing return.
4837
4838 2011-10-28 Eli Zaretskii <eliz@gnu.org>
4839
4840 Fix Emacs on Windows 9X (bug#8562). Thanks to oslsachem
4841 <oslsachem@gmail.com> for helping to debug this.
4842
4843 * w32font.c (g_b_init_is_w9x, g_b_init_get_outline_metrics_w)
4844 (g_b_init_get_text_metrics_w, g_b_init_get_glyph_outline_w)
4845 (g_b_init_get_glyph_outline_w): New static variables.
4846 (GetOutlineTextMetricsW_Proc, GetTextMetricsW_Proc)
4847 (GetGlyphOutlineW_Proc): New typedefs.
4848 (w32_load_unicows_or_gdi32, get_outline_metrics_w)
4849 (get_text_metrics_w, get_glyph_outline_w, globals_of_w32font):
4850 New functions.
4851 (w32font_open_internal, compute_metrics):
4852 Call get_outline_metrics_w, get_text_metrics_w, and get_glyph_outline_w
4853 instead of calling the "wide" APIs directly.
4854
4855 * emacs.c (main) [HAVE_NTGUI]: Call globals_of_w32font.
4856
4857 * w32.h (syms_of_w32font): Add prototype.
4858
4859 2011-10-27 Juanma Barranquero <lekktu@gmail.com>
4860
4861 * window.c (Fframe_root_window, Fframe_first_window, Fwindow_end)
4862 (Fframe_selected_window, Ftemp_output_buffer_show, Fnext_window)
4863 (Fdelete_window_internal, Fwindow_parameters): Fix typos in docstrings.
4864 (Fmove_to_window_line): Doc fix.
4865
4866 2011-10-27 Chong Yidong <cyd@gnu.org>
4867
4868 * process.c (make_process): Set gnutls_state to NULL.
4869
4870 * gnutls.c (emacs_gnutls_deinit): Deinit the gnutls_state if it is
4871 non-NULL, regardless of GNUTLS_INITSTAGE.
4872 (Fgnutls_boot): Cleanups. Call emacs_gnutls_deinit if we signal
4873 an error. Set process slots as soon as we allocate them.
4874
4875 * gnutls.h (GNUTLS_LOG, GNUTLS_LOG2): Fix macros.
4876
4877 2011-10-27 Chong Yidong <cyd@gnu.org>
4878
4879 * gnutls.c (emacs_gnutls_deinit): New function.
4880 Deallocate credentials structures as well as calling gnutls_deinit.
4881 (Fgnutls_deinit, Fgnutls_boot): Use it.
4882
4883 * process.c (make_process): Initialize GnuTLS credentials to NULL.
4884 (deactivate_process): Call emacs_gnutls_deinit.
4885
4886 2011-10-27 Juanma Barranquero <lekktu@gmail.com>
4887
4888 * image.c (x_create_x_image_and_pixmap):
4889 * w32.c (sys_rename, w32_delayed_load):
4890 * w32font.c (fill_in_logfont):
4891 * w32reg.c (x_get_string_resource): Silence compiler warnings.
4892
4893 2011-10-26 Juanma Barranquero <lekktu@gmail.com>
4894
4895 * w32fns.c (w32_default_color_map): New function,
4896 extracted from Fw32_default_color_map.
4897 (Fw32_default_color_map, Fx_open_connection): Use it. (Bug#9785)
4898
4899 2011-10-25 Paul Eggert <eggert@cs.ucla.edu>
4900
4901 * dispextern.h (Fcontrolling_tty_p): New decl (Bug#6649 part 2).
4902
4903 2011-10-25 Stefan Monnier <monnier@iro.umontreal.ca>
4904
4905 * keyboard.c (test_undefined): New function (bug#9751).
4906 (read_key_sequence): Use it to detect when a key is bound to `undefined'.
4907
4908 2011-10-25 Enami Tsugutomo <tsugutomo.enami@jp.sony.com>
4909
4910 * sysdep.c (init_sys_modes): Fix the check for the controlling
4911 terminal (Bug#6649).
4912
4913 2011-10-20 Eli Zaretskii <eliz@gnu.org>
4914
4915 * dispextern.h (struct bidi_it): New member next_en_type.
4916
4917 * bidi.c (bidi_line_init): Initialize the next_en_type member.
4918 (bidi_resolve_explicit_1): When next_en_pos is valid for the
4919 current character, check also for next_en_type being WEAK_EN.
4920 (bidi_resolve_weak): Don't enter the expensive loop if the current
4921 position is before next_en_pos. Record the bidi type of the first
4922 non-ET, non-BN character we find, in addition to its position.
4923 (bidi_level_of_next_char): Invalidate next_en_type when
4924 next_en_pos is over-stepped.
4925
4926 2011-10-20 Paul Eggert <eggert@cs.ucla.edu>
4927
4928 Time zone name fixes for non-ASCII locales (Bug#641, Bug#9794)
4929 * editfns.c: Rewrite current-time-zone so that it invokes
4930 the equivalent of (format-time-string "%Z") to get the time zone name.
4931 This fixes a bug when the time zone name contains characters that
4932 need converting from the system time locale to Emacs internal format.
4933 This fixes a shortcoming that I introduced in my 1999-10-19 patch:
4934 that patch fixed format-time-string to do the conversion, but
4935 I forgot to fix current-time-zone.
4936 (format_time_string): New function, containing most of
4937 what Fformat_time_string used to contain.
4938 (Fformat_time_string): Rewrite in terms of format_time_string.
4939 This doesn't change this function's behavior.
4940 (current-time-zone): Rewrite to use format_time_string.
4941 This fixes the bug reported by Michael Schierl in
4942 <http://lists.gnu.org/archive/html/emacs-devel/2007-06/msg00334.html>.
4943 Jason Rumney's 2007-06-07 change worked around this bug, but
4944 didn't fix it.
4945 * systime.h (tzname, timezone): Remove no-longer-used declarations.
4946
4947 2011-10-19 Eli Zaretskii <eliz@gnu.org>
4948
4949 * xdisp.c (start_display): If the character at POS is displayed
4950 via a display vector, reset IT->current.dpvec_index to zero.
4951 (try_window_reusing_current_matrix): If a line ends in a display
4952 vector or the next line starts in a display vector, continue
4953 redrawing the window even though the character position of
4954 start_row was reached.
4955 (Bug#9771, part 2)
4956
4957 2011-10-18 Chong Yidong <cyd@gnu.org>
4958
4959 * xdisp.c (get_next_display_element): Handle U+2010 and U+2011
4960 with nobreak-char-display too.
4961
4962 2011-10-18 Eli Zaretskii <eliz@gnu.org>
4963
4964 Fix part 3 of bug#9771.
4965 * bidi.c (bidi_line_init): Initialize next_en_pos to zero, not -1.
4966 (bidi_resolve_neutral): Don't enter the expensive loop looking for
4967 non-neutral characters if the current character is a paragraph
4968 separator (a.k.a. Newline). This avoids running the same
4969 expensive loop twice, once when we consume the preceding newline
4970 and the other time when the line actually needs to be displayed.
4971 Avoid the loop when we see neutrals on the base embedding level
4972 following a character whose directionality is the same as the
4973 paragraph's. This avoids running the expensive loop when a line
4974 ends in a long sequence of neutrals, like control characters.
4975 Add assertion against STRONG_AL type. Slightly rearrange code
4976 that determines the type of a neutral given the first non-neutral
4977 that follows it.
4978 (bidi_level_of_next_char): Set next_en_pos to zero when
4979 invalidating its info.
4980
4981 2011-10-17 Eli Zaretskii <eliz@gnu.org>
4982
4983 * xdisp.c (push_display_prop): Determine whether to record string
4984 or buffer position by IT->string, not by IT->method. Allow
4985 GET_FROM_DISPLAY_VECTOR as IT->method on entry. (Bug#9771, part 4)
4986 (move_it_vertically_backward): Don't look for character position
4987 immediately after the newline when in a continuation line.
4988 (Bug#9771, part 1)
4989
4990 2011-10-15 Martin Rudalics <rudalics@gmx.at>
4991
4992 * window.c (coordinates_in_window): Rewrite and delabelize
4993 vertical border check. (Bug#5357) (Bug#9618)
4994
4995 2011-10-14 Stefan Monnier <monnier@iro.umontreal.ca>
4996
4997 * xterm.c (frame_highlight, frame_unhighlight): Ignore unexplained
4998 errors in XSetWindowBorder (bug#9310).
4999
5000 2011-10-13 Dmitry Antipov <dmantipov@yandex.ru>
5001
5002 * editfns.c (Fset_time_zone_rule): Replace free with xfree to
5003 avoid crash when xmalloc overrun checking is enabled.
5004
5005 2011-10-13 Eli Zaretskii <eliz@gnu.org>
5006
5007 * xdisp.c (Fcurrent_bidi_paragraph_direction): Initialize
5008 itb.paragraph_dir to NEUTRAL_DIR. Fixes an occasional incorrect
5009 cursor motion with <left> and <right> arrow keys.
5010
5011 * bidi.c (bidi_init_it): Don't initialize paragraph_dir here, as
5012 some callers set that themselves.
5013
5014 2011-10-12 Eli Zaretskii <eliz@gnu.org>
5015
5016 * xdisp.c (find_row_edges): Handle the case where ROW comes from a
5017 display string and the previous row comes from the same string and
5018 is empty. (Bug#9739) (Bug#9738)
5019
5020 2011-10-12 Stefan Monnier <monnier@iro.umontreal.ca>
5021
5022 * doc.c (get_doc_string): Encode file name (bug#9735).
5023
5024 2011-10-12 Eli Zaretskii <eliz@gnu.org>
5025
5026 * bidi.c (bidi_level_of_next_char):
5027 * xdisp.c (get_visually_first_element): Remove old incorrect
5028 comments regarding the Unicode Line Separator character.
5029
5030 * bidi.c (bidi_init_it): Initialize paragraph_dir to NEUTRAL_DIR.
5031
5032 2011-10-12 Dmitry Antipov <dmantipov@yandex.ru>
5033
5034 * alloc.c (Fgc_status): Do not access beyond zombies array
5035 boundary if nzombies > MAX_ZOMBIES.
5036 * alloc.c (dump_zombies): Add missing format specifier.
5037
5038 2011-10-12 Paul Eggert <eggert@cs.ucla.edu>
5039
5040 * xdisp.c (set_cursor_from_row): Simplify conditionals,
5041 to pacify GCC 4.6.1 x86-64 with -O2 -Wstrict-overflow.
5042
5043 * lread.c (read_escape): Allow hex escapes as large as ?\xfffffff.
5044 Some packages use them to denote characters with modifiers.
5045
5046 2011-10-11 Andreas Schwab <schwab@linux-m68k.org>
5047
5048 * lisp.h (GCPRO1_VAR, GCPRO2_VAR, GCPRO3_VAR, GCPRO4_VAR)
5049 (GCPRO5_VAR, GCPRO6_VAR, UNGCPRO_VAR): Add whitespace to avoid
5050 matching a pp-number. Rename parameter var to var1.
5051
5052 2011-10-11 Stefan Monnier <monnier@iro.umontreal.ca>
5053
5054 * minibuf.c (Finternal_complete_buffer): Fix last change (bug#9709).
5055
5056 2011-10-08 Glenn Morris <rgm@gnu.org>
5057
5058 * callint.c (Fcall_interactively): Give a more explicit error for the
5059 'c' case with a non-character input. (Bug#8479)
5060
5061 2011-10-08 Eli Zaretskii <eliz@gnu.org>
5062
5063 * xdisp.c (hscroll_window_tree): Support hscroll in right-to-left
5064 lines.
5065 (set_cursor_from_row): Fix cursor positioning in mixed L2R+R2L
5066 lines that are hscrolled on the left.
5067
5068 * dispnew.c (buffer_posn_from_coords): Account for a possible
5069 presence of header-line. (Bug#4426)
5070
5071 2011-10-07 Stefan Monnier <monnier@iro.umontreal.ca>
5072
5073 * buffer.c (syms_of_buffer) <enable-multibyte-characters>:
5074 Don't advertise functionality which we discourage or doesn't work.
5075
5076 2011-10-07 Paul Eggert <eggert@cs.ucla.edu>
5077
5078 * alloc.c (GC_LISP_OBJECT_ALIGNMENT): Use offsetof, not __alignof__
5079 or sizeof. __alignof__ gives the wrong answer on Fedora x86-64
5080 with GCC 4.6.1 when configured with CC='gcc -m32' --with-wide-int;
5081 this makes Emacs dump core during garbage collection on rare
5082 occasions. sizeof is obviously inferior to offsetof here, so
5083 stick with offsetof.
5084 (GC_POINTER_ALIGNMENT): New macro.
5085 (mark_memory): Omit 3rd (offset) arg; caller changed.
5086 Don't assume EMACS_INT alignment is the same as pointer alignment.
5087
5088 2011-10-03 Stefan Monnier <monnier@iro.umontreal.ca>
5089
5090 * keyboard.c (read_key_sequence_remapped): New var.
5091 (read_key_sequence): Compute remapping in the right buffer.
5092 (command_loop_1): Use read_key_sequence's remapping directly.
5093
5094 2011-10-02 Stefan Monnier <monnier@iro.umontreal.ca>
5095
5096 * dired.c (file_name_completion): Don't expand file name.
5097 (Ffile_name_completion, Ffile_name_all_completions): Expand file name
5098 before checking file name handler.
5099
5100 * minibuf.c (Finternal_complete_buffer): Only show internal buffers if
5101 they've been requested explicitly (bug#9591).
5102
5103 2011-10-01 Andreas Schwab <schwab@linux-m68k.org>
5104
5105 * keymap.c (Fsingle_key_description): Use make_specified_string
5106 instead of build_string to build string from push_key_description.
5107 (Bug#5193)
5108
5109 2011-09-30 Paul Eggert <eggert@cs.ucla.edu>
5110
5111 * buffer.h (struct buffer): Use time_t, not int, for a time stamp.
5112 This fixes a Y2038 bug on 64-bit hosts.
5113 * buffer.c (reset_buffer):
5114 * fileio.c (Fdo_auto_save, Fset_buffer_auto_saved)
5115 (Fclear_buffer_auto_save_failure):
5116 Use 0, not -1, to represent an unset failure time, since time_t
5117 might not be signed.
5118
5119 Remove dependency on glibc malloc internals.
5120 * alloc.c (XMALLOC_OVERRUN_CHECK_OVERHEAD, XMALLOC_OVERRUN_CHECK_SIZE):
5121 Move back here from lisp.h, but with their new implementations.
5122 (XMALLOC_BASE_ALIGNMENT, COMMON_MULTIPLE, XMALLOC_HEADER_ALIGNMENT)
5123 (XMALLOC_OVERRUN_SIZE_SIZE): Move these new lisp.h macros here.
5124 * charset.c (charset_table_init): New static var.
5125 (syms_of_charset): Use it instead of xmalloc. This removes a
5126 dependency on glibc malloc internals. See Eli Zaretskii's comment in
5127 <http://lists.gnu.org/archive/html/emacs-devel/2011-09/msg00815.html>.
5128 * lisp.h (XMALLOC_OVERRUN_CHECK_OVERHEAD, XMALLOC_OVERRUN_CHECK_SIZE):
5129 Move back to alloc.c.
5130 (XMALLOC_BASE_ALIGNMENT, COMMON_MULTIPLE, XMALLOC_HEADER_ALIGNMENT)
5131 (XMALLOC_OVERRUN_SIZE_SIZE): Move to alloc.c.
5132
5133 2011-09-30 Jan Djärv <jan.h.d@swipnet.se>
5134
5135 * nsterm.m (windowDidResize): Call x_set_window_size only when
5136 ns_in_resize is true. Otherwise set pixelwidth/height and
5137 call change_frame_size (Bug#9628).
5138
5139 2011-09-30 Paul Eggert <eggert@cs.ucla.edu>
5140
5141 Port --enable-checking=all to Fedora 14 x86-64.
5142 * charset.c (syms_of_charset): Also account for glibc malloc's
5143 internal overhead when calculating the initial malloc maximum.
5144
5145 Port --enable-checking=all to Fedora 14 x86.
5146 * alloc.c (XMALLOC_OVERRUN_CHECK_OVERHEAD, XMALLOC_OVERRUN_CHECK_SIZE):
5147 Move to lisp.h.
5148 (xmalloc_put_size, xmalloc_get_size, overrun_check_malloc)
5149 (overrun_check_realloc, overrun_check_free):
5150 Use XMALLOC_OVERRUN_SIZE_SIZE, not sizeof (size_t).
5151 That way, xmalloc returns a properly-aligned pointer even if
5152 XMALLOC_OVERRUN_CHECK is defined. The old debugging code happened
5153 to align OK on typical 64-bit hosts, but not on Fedora 14 x86.
5154 * charset.c (syms_of_charset): Take XMALLOC_OVERRUN_CHECK_OVERHEAD
5155 into account when calculating the initial malloc maximum.
5156 * lisp.h (XMALLOC_OVERRUN_CHECK_OVERHEAD, XMALLOC_OVERRUN_CHECK_SIZE):
5157 Move here from alloc.c, so that charset.c can use it too.
5158 Properly align; the old code wasn't right for common 32-bit hosts
5159 when configured with --enable-checking=all.
5160 (XMALLOC_BASE_ALIGNMENT, COMMON_MULTIPLE, XMALLOC_HEADER_ALIGNMENT)
5161 (XMALLOC_OVERRUN_SIZE_SIZE): New macros.
5162
5163 2011-09-29 Eli Zaretskii <eliz@gnu.org>
5164
5165 * sysdep.c (snprintf) [!EOVERFLOW]: If EOVERFLOW is not defined,
5166 use EDOM.
5167
5168 2011-09-28 Eli Zaretskii <eliz@gnu.org>
5169
5170 * xdisp.c (compute_display_string_end): If there's no display
5171 string at CHARPOS, return -1.
5172
5173 * bidi.c (bidi_fetch_char): When compute_display_string_end
5174 returns a negative value, treat the character as a normal
5175 character not covered by a display string. (Bug#9624)
5176
5177 2011-09-28 Juanma Barranquero <lekktu@gmail.com>
5178
5179 * lread.c (Fread_from_string): Fix typo in docstring.
5180
5181 2011-09-27 Eli Zaretskii <eliz@gnu.org>
5182
5183 * xdisp.c (handle_invisible_prop): If invisible text ends on a
5184 newline, reseat the iterator instead of bidi-iterating there one
5185 character at a time. (Bug#9610)
5186 (BUFFER_POS_REACHED_P, move_it_in_display_line_to): Bail when past
5187 TO_CHARPOS if the bidi iterator is at base embedding level.
5188
5189 2011-09-27 Andreas Schwab <schwab@linux-m68k.org>
5190
5191 * lread.c (readevalloop): Use correct code for NBSP.
5192 (read1): Likewise. (Bug#9608)
5193
5194 2011-09-25 Michael Albinus <michael.albinus@gmx.de>
5195
5196 * dbusbind.c (Fdbus_register_signal): When service is not
5197 registered, use nil in Vdbus_registered_objects_table. (Bug#9581)
5198
5199 2011-09-25 Glenn Morris <rgm@gnu.org>
5200
5201 * buffer.c (truncate-lines): Doc fix.
5202
5203 2011-09-24 Chong Yidong <cyd@stupidchicken.com>
5204
5205 * window.c (Fwindow_prev_buffers, Fset_window_prev_buffers)
5206 (Fset_window_next_buffers): Doc fix.
5207
5208 2011-09-24 Glenn Morris <rgm@gnu.org>
5209
5210 * minibuf.c (read_minibuf): Disable line truncation. (Bug#5715)
5211
5212 2011-09-24 Paul Eggert <eggert@cs.ucla.edu>
5213
5214 Fix minor problems found by static checking.
5215 * xdisp.c (string_from_display_spec): Don't assume vecsize fits in int.
5216 * indent.c (Fvertical_motion): Fix == vs = typo.
5217
5218 2011-09-24 Eli Zaretskii <eliz@gnu.org>
5219
5220 * dispnew.c (syms_of_display) <redisplay-dont-pause>:
5221 Default value is now t. Doc fix.
5222
5223 * indent.c (Fvertical_motion): Compute and apply the overshoot
5224 logic when moving up, not only when moving down. Fix the
5225 confusing name and values of the it_overshoot_expected variable;
5226 logic changes accordingly. (Bug#9254) (Bug#9549)
5227
5228 * xdisp.c (pos_visible_p): Produce correct pixel coordinates when
5229 CHARPOS is covered by a display string which includes newlines.
5230 (move_it_vertically_backward): Avoid inflooping when START_CHARPOS
5231 is covered by a display string with embedded newlines.
5232
5233 2011-09-24 Michael Albinus <michael.albinus@gmx.de>
5234
5235 * dbusbind.c (Fdbus_register_signal): Add match rule to
5236 Vdbus_registered_objects_table. (Bug#9581)
5237 (Fdbus_register_method, Vdbus_registered_objects_table):
5238 Fix docstring.
5239
5240 2011-09-24 Jim Meyering <meyering@redhat.com>
5241
5242 do not ignore write error for any output size
5243 The previous change was incomplete.
5244 While it makes emacs --batch detect the vast majority of stdout
5245 write failures, errors were still ignored whenever the output size is
5246 k * (BUFSIZ+1) - 4. E.g., on a system with BUFSIZ of 4096,
5247 $ emacs --batch --eval '(print (format "%4093d" 0))' > /dev/full \
5248 && echo FAIL: ignored write error
5249 FAIL: ignored write error
5250 $ emacs --batch --eval '(print (format "%20481d" 0))' > /dev/full \
5251 && echo FAIL: ignored write error
5252 FAIL: ignored write error
5253 * emacs.c (Fkill_emacs): Also test ferror. (Bug#9574)
5254
5255 2011-09-23 Andreas Schwab <schwab@linux-m68k.org>
5256
5257 * emacs.c (Fkill_emacs): In noninteractive mode exit
5258 non-successfully if a write error occurred on stdout. (Bug#9574)
5259
5260 2011-09-21 Eli Zaretskii <eliz@gnu.org>
5261
5262 * xdisp.c (pop_it): Allow it->object that is a cons cell to pass
5263 the xassert test.
5264
5265 * dispextern.h (struct it): Update the comment documenting what
5266 can it->OBJECT be.
5267
5268 2011-09-20 Eli Zaretskii <eliz@gnu.org>
5269
5270 * xdisp.c (set_cursor_from_row): If the row ends in a newline from
5271 a display string, extend search for cursor position to end of row.
5272 (find_row_edges): If the row ends in a newline from a display
5273 string, increment its MATRIX_ROW_END_CHARPOS by one. (Bug#9549)
5274 Handle the case of a display string with multiple newlines.
5275 (Fcurrent_bidi_paragraph_direction): Fix search for previous
5276 non-empty line. Fixes confusing cursor motion with arrow keys at
5277 the beginning of a line that starts with whitespace.
5278
5279 2011-09-19 Lars Magne Ingebrigtsen <larsi@gnus.org>
5280
5281 * lread.c (Fread_from_string): Document what FINAL-STRING-INDEX is
5282 (bug#9493).
5283
5284 2011-09-18 Chong Yidong <cyd@stupidchicken.com>
5285
5286 * xfns.c (Fx_create_frame): Handle the bitmapIcon resource as
5287 boolean (Bug#9154).
5288
5289 2011-09-18 Eli Zaretskii <eliz@gnu.org>
5290
5291 * xdisp.c (display_line): Record maximum and minimum buffer
5292 positions even if no glyphs were produced (e.g., by a zero-width
5293 stretch). Fixes bug#9530 on a TTY. Under word-wrap, don't record
5294 buffer positions that will be removed from the glyph row because
5295 they don't fit.
5296 (produce_stretch_glyph): Fix a bug in :align-to on a TTY when the
5297 column is beyond frame width: don't subtract 1 "pixel" when
5298 computing width of the stretch.
5299 (reseat_at_next_visible_line_start): Undo the change made on
5300 2011-09-17 that saved paragraph information and restored it after
5301 the call to `reseat'. (Bug#9545)
5302
5303 2011-09-18 YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
5304
5305 * xdisp.c (expose_window): Save original value of phys_cursor_on_p
5306 and turn window cursor on if cleared (Bug#9415).
5307
5308 2011-09-18 Andreas Schwab <schwab@linux-m68k.org>
5309
5310 * search.c (boyer_moore): Take unibyte characters from pattern
5311 literally. (Bug#9458)
5312
5313 2011-09-18 Eli Zaretskii <eliz@gnu.org>
5314
5315 * xdisp.c (reseat_at_next_visible_line_start): Fix last change.
5316
5317 2011-09-18 Paul Eggert <eggert@cs.ucla.edu>
5318
5319 Fix minor problem found by static checking.
5320 * xdisp.c (reseat_at_next_visible_line_start): Mark locals as
5321 initialized, to pacify gcc -Wuninitialized.
5322
5323 * fileio.c: Report proper errno when syscall falls.
5324 (Finsert_file_contents): Save and restore errno,
5325 so that report_file_error outputs the correct diagnostic.
5326 (Fwrite_region) [CLASH_DETECTION]: Likewise.
5327
5328 2011-09-18 Eli Zaretskii <eliz@gnu.org>
5329
5330 * .gdbinit (pgx): Fix references to fields of `struct glyph'.
5331
5332 2011-09-17 Eli Zaretskii <eliz@gnu.org>
5333
5334 * xdisp.c (produce_stretch_glyph): Another fix for changes made on
5335 2011-08-30T17:32:44Z!eliz@gnu.org. (Bug#9530)
5336
5337 2011-09-17 Eli Zaretskii <eliz@gnu.org>
5338
5339 * xdisp.c (reseat_at_next_visible_line_start): Keep information
5340 about the current paragraph and restore it after the call to reseat.
5341
5342 * bidi.c (MAX_PARAGRAPH_SEARCH): New macro.
5343 (bidi_find_paragraph_start): Search back for paragraph beginning
5344 at most MAX_PARAGRAPH_SEARCH lines; if not found, return BEGV_BYTE.
5345 (bidi_move_to_visually_next): Only trigger paragraph-related
5346 computations when the last character is a newline or at EOB, not
5347 just any NEUTRAL_B. (Bug#9470)
5348
5349 * xdisp.c (set_cursor_from_row): Don't invoke special treatment of
5350 truncated lines if point is covered by a display string. (Bug#9524)
5351
5352 2011-09-16 Paul Eggert <eggert@cs.ucla.edu>
5353
5354 * xselect.c: Relax test for outgoing X longs (Bug#9498).
5355 (cons_to_x_long): New function.
5356 (lisp_data_to_selection_data): Use it. Correct the test for
5357 short-versus-long data; it was negated. Break out of vector
5358 loop, for efficiency, when a long datum is discovered.
5359
5360 2011-09-16 Stefan Monnier <monnier@iro.umontreal.ca>
5361
5362 * eval.c (Fquote): Document its non-consing behavior (bug#9482).
5363
5364 2011-09-16 Eli Zaretskii <eliz@gnu.org>
5365
5366 * image.c (tiff_handler): Work around a bug in MinGW GCC 3.x (see
5367 GCC PR/17406) by declaring this function with external scope.
5368
5369 2011-09-15 Paul Eggert <eggert@cs.ucla.edu>
5370
5371 * editfns.c (Fformat): Fix bug in text-property fix (Bug#9514).
5372 Don't mishandle (length (format "%%")) and (format "%4000s%%" "").
5373
5374 2011-09-15 Andreas Schwab <schwab@linux-m68k.org>
5375
5376 * editfns.c (Fformat): Correctly handle text properties on "%%".
5377
5378 2011-09-15 Eli Zaretskii <eliz@gnu.org>
5379
5380 * xterm.c (x_draw_composite_glyph_string_foreground):
5381 * w32term.c (x_draw_composite_glyph_string_foreground):
5382 * term.c (encode_terminal_code):
5383 * composite.c (composition_update_it, get_composition_id):
5384 * xdisp.c (get_next_display_element)
5385 (fill_composite_glyph_string): Add comments about special meaning
5386 of TAB characters in a composition.
5387
5388 2011-09-15 Paul Eggert <eggert@cs.ucla.edu>
5389
5390 * editfns.c (Fformat): Fix off-by-1 bug for "%%b" (Bug#9514).
5391 This occurs when processing a multibyte format.
5392 Problem reported by Wolfgang Jenker.
5393
5394 2011-09-15 Johan Bockgård <bojohan@gnu.org>
5395
5396 * xdisp.c (try_cursor_movement): Only check for exact match if
5397 cursor hpos found by set_cursor_from_row is valid. (Bug#9495)
5398
5399 2011-09-14 Paul Eggert <eggert@cs.ucla.edu>
5400
5401 Remove unused external symbols.
5402 * dispextern.h (calc_pixel_width_or_height): Remove decl.
5403 * xdisp.c (calc_pixel_width_or_height): Now static.
5404 * doprnt.c (exprintf) [! (HAVE_X_WINDOWS && USE_X_TOOLKIT)]: Remove.
5405 * indent.c (check_display_width):
5406 * w32term.c: Fix comment to match code.
5407 * xterm.c, xterm.h (x_catching_errors): Remove.
5408
5409 2011-09-14 Paul Eggert <eggert@cs.ucla.edu>
5410
5411 * xselect.c: Use signed conversions more consistently (Bug#9498).
5412 (selection_data_to_lisp_data): Assume incoming selection data are
5413 signed integers, not unsigned. This is to be consistent with
5414 outgoing selection data, which was modified to use signed integers
5415 in as part of the fix to Bug#9196 in response to Jan D.'s comment
5416 in <http://debbugs.gnu.org/cgi/bugreport.cgi?bug=9196#32> that X11
5417 expects long, not unsigned long.
5418
5419 2011-09-14 Eli Zaretskii <eliz@gnu.org>
5420
5421 * xdisp.c (try_window_reusing_current_matrix): Fix incorrect
5422 computation of loop end. Reported by Johan Bockgård
5423 <bojohan@gnu.org>.
5424
5425 2011-09-13 Chong Yidong <cyd@stupidchicken.com>
5426
5427 * frame.c (Fother_visible_frames_p): Function deleted.
5428
5429 2011-09-12 Eli Zaretskii <eliz@gnu.org>
5430
5431 * indent.c (compute_motion): Process display vector front to back
5432 rather than the other way around. (Bug#2496)
5433
5434 2011-09-12 Stefan Monnier <monnier@iro.umontreal.ca>
5435
5436 * fileio.c (Finsert_file_contents): Don't assume beg_offset is 0.
5437
5438 2011-09-11 Chong Yidong <cyd@stupidchicken.com>
5439
5440 * minibuf.c (Fread_from_minibuffer): Doc fix.
5441
5442 2011-09-11 Eli Zaretskii <eliz@gnu.org>
5443
5444 * xdisp.c (produce_stretch_glyph): Fix a typo made in changes from
5445 2011-08-30T17:32:44Z!eliz@gnu.org. (Bug#9475)
5446
5447 2011-09-11 Lars Magne Ingebrigtsen <larsi@gnus.org>
5448
5449 * fileio.c (Fvisited_file_modtime): Document `(-1 65535)' as a
5450 value for non-existent files.
5451
5452 2011-09-11 Eli Zaretskii <eliz@gnu.org>
5453
5454 * fileio.c (Finsert_file_contents): If the file cannot be opened,
5455 set its "size" to -1. This will set the modtime_size field of
5456 the corresponding buffer to -1, which is what
5457 verify-visited-file-modtime expects for files that do not exist.
5458 (Bug#9139)
5459
5460 2011-09-11 Paul Eggert <eggert@cs.ucla.edu>
5461
5462 * keymap.h (KEY_DESCRIPTION_SIZE, push_key_description): Move decls
5463 here ...
5464 * lisp.h: ... from here. push_key_description is no longer
5465 defined in keyboard.c, so its declaration should not be in
5466 lisp.h's "Defined in keyboard.c" section, and KEY_DESCRIPTION_SIZE
5467 logically belongs with push_key_description.
5468
5469 2011-09-10 Paul Eggert <eggert@cs.ucla.edu>
5470
5471 * buffer.h: Include <sys/types.h> instead of <time.h>.
5472 Otherwise, off_t wasn't defined on FreeBSD 9.0-BETA2 i386.
5473 Problem reported by Herbert J. Skuhra.
5474
5475 2011-09-10 Lars Magne Ingebrigtsen <larsi@gnus.org>
5476
5477 * xml.c (parse_region): Make the parsing work for
5478 non-comment-starting XML files again (bug#9144).
5479
5480 2011-09-10 Andreas Schwab <schwab@linux-m68k.org>
5481
5482 * image.c (gif_load): Fix calculation of bottom and right corner.
5483 (Bug#9468)
5484
5485 2011-09-10 Eli Zaretskii <eliz@gnu.org>
5486
5487 * xdisp.c (MAX_DISP_SCAN): Decrease to 250. Prevents sluggish
5488 redisplay in small windows.
5489
5490 2011-09-09 Eli Zaretskii <eliz@gnu.org>
5491
5492 * frame.c (x_report_frame_params): Cast to avoid compiler warnings.
5493
5494 2011-09-08 Martin Rudalics <rudalics@gmx.at>
5495
5496 * window.c (Fset_window_prev_buffers, Fset_window_next_buffers):
5497 Operate on live windows only.
5498
5499 2011-09-08 Juanma Barranquero <lekktu@gmail.com>
5500
5501 * emacs.c (my_heap_start): #ifdef to avoid warnings when unused.
5502
5503 2011-09-07 Eli Zaretskii <eliz@gnu.org>
5504
5505 * xdisp.c (move_it_in_display_line_to): Call RESTORE_IT on ppos_it
5506 only under bidi iteration.
5507
5508 2011-09-07 Jan Djärv <jan.h.d@swipnet.se>
5509
5510 * gtkutil.c (xg_make_tool_item): Insert comment about eventbox.
5511
5512 2011-09-06 Paul Eggert <eggert@cs.ucla.edu>
5513
5514 isnan: Fix porting problem to Solaris 10 with bundled gcc.
5515 Without this fix, the command to link temacs failed due to an
5516 undefined symbol __builtin_isnan. This is because
5517 /usr/include/iso/math_c99.h #defines isnan(x) to
5518 __builtin_isnan(x), but the bundled gcc, which identifies itself
5519 as gcc 3.4.3 (csl-sol210-3_4-branch+sol_rpath), does not have
5520 a __builtin_isnan.
5521 * floatfns.c (isnan): #undef, and then #define to a clone of
5522 what's in data.c.
5523 (Fisnan): Always define, since it's always available now.
5524 (syms_of_floatfns): Always define isnan at the Lisp level.
5525
5526 2011-09-06 Paul Eggert <eggert@cs.ucla.edu>
5527
5528 * Makefile.in (gl-stamp): move-if-change now in build-aux (Bug#9169).
5529
5530 2011-09-06 Paul Eggert <eggert@cs.ucla.edu>
5531
5532 * fileio.c: Fix bugs with large file offsets (Bug#9428).
5533 The previous code assumed that file offsets (off_t values) fit in
5534 EMACS_INT variables, which is not true on typical 32-bit hosts.
5535 The code messed up by falsely reporting buffer overflow in cases
5536 such as (insert-file-contents "big" nil 1 2) into an empty buffer
5537 when "big" contains more than 2**29 bytes, even though this
5538 inserts just one byte and does not overflow the buffer.
5539 (Finsert_file_contents): Store file offsets as off_t
5540 values, not as EMACS_INT values. Check for overflow when
5541 converting between EMACS_INT and off_t. When checking for
5542 buffer overflow or for overlap, take the offsets into account.
5543 Don't use EMACS_INT for small values where int suffices.
5544 When checking for overlap, fix a typo: ZV was used where
5545 ZV_BYTE was intended.
5546 (Fwrite_region): Don't assume off_t fits into 'long'.
5547 * buffer.h (struct buffer.modtime_size): Now off_t, not EMACS_INT.
5548
5549 2011-09-05 Michael Albinus <michael.albinus@gmx.de>
5550
5551 * dbusbind.c (xd_signature_cat): Rename from signature_cat.
5552
5553 2011-09-04 Paul Eggert <eggert@cs.ucla.edu>
5554
5555 sprintf-related integer and memory overflow issues (Bug#9412).
5556
5557 * doprnt.c (doprnt): Support printing ptrdiff_t and intmax_t values.
5558 (esprintf, exprintf, evxprintf): New functions.
5559 * keyboard.c (command_loop_level): Now EMACS_INT, not int.
5560 (cmd_error): Kbd macro iterations count is now EMACS_INT, not int.
5561 (modify_event_symbol): Do not assume that the length of
5562 name_alist_or_stem is safe to alloca and fits in int.
5563 (Fexecute_extended_command): Likewise for function name and binding.
5564 (Frecursion_depth): Wrap around reliably on integer overflow.
5565 * keymap.c (push_key_description): First arg is now EMACS_INT, not int,
5566 since some callers pass EMACS_INT values.
5567 (Fsingle_key_description): Don't crash if symbol name contains more
5568 than MAX_ALLOCA bytes.
5569 * minibuf.c (minibuf_level): Now EMACS_INT, not int.
5570 (get_minibuffer): Arg is now EMACS_INT, not int.
5571 * lisp.h (get_minibuffer, push_key_description): Reflect API changes.
5572 (esprintf, exprintf, evxprintf): New decls.
5573 * window.h (command_loop_level, minibuf_level): Reflect API changes.
5574
5575 * dbusbind.c (signature_cat): New function.
5576 (xd_signature, Fdbus_register_signal):
5577 Do not overrun buffer; instead, report string overflow.
5578
5579 * dispnew.c (add_window_display_history): Don't overrun buffer.
5580 Truncate instead; this is OK since it's just a log.
5581
5582 * editfns.c (Fcurrent_time_zone): Don't overrun buffer
5583 even if the time zone offset is outlandishly large.
5584 Don't mishandle offset == INT_MIN.
5585
5586 * emacs.c (main) [NS_IMPL_COCOA]: Don't overrun buffer
5587 when creating daemon; the previous buffer-overflow check was incorrect.
5588
5589 * eval.c (verror): Simplify by rewriting in terms of evxprintf,
5590 which has the guts of the old verror function.
5591
5592 * filelock.c (lock_file_1, lock_file): Don't blindly alloca long name;
5593 use SAFE_ALLOCA instead. Use esprintf to avoid int-overflow issues.
5594
5595 * font.c: Include <float.h>, for DBL_MAX_10_EXP.
5596 (font_unparse_xlfd): Don't blindly alloca long strings.
5597 Don't assume XINT result fits in int, or that XFLOAT_DATA * 10
5598 fits in int, when using sprintf. Use single snprintf to count
5599 length of string rather than counting it via multiple sprintfs;
5600 that's simpler and more reliable.
5601 (font_unparse_fcname): Use it to avoid sprintf buffer overrun.
5602 (generate_otf_features) [0 && HAVE_LIBOTF]: Use esprintf, not
5603 sprintf, in case result does not fit in int.
5604
5605 * fontset.c (num_auto_fontsets): Now printmax_t, not int.
5606 (fontset_from_font): Print it.
5607
5608 * frame.c (tty_frame_count): Now printmax_t, not int.
5609 (make_terminal_frame, set_term_frame_name): Print it.
5610 (x_report_frame_params): In X, window IDs are unsigned long,
5611 not signed long, so print them as unsigned.
5612 (validate_x_resource_name): Check for implausibly long names,
5613 and don't assume name length fits in 'int'.
5614 (x_get_resource_string): Don't blindly alloca invocation name;
5615 use SAFE_ALLOCA. Use esprintf, not sprintf, in case result does
5616 not fit in int.
5617
5618 * gtkutil.c: Include <float.h>, for DBL_MAX_10_EXP.
5619 (xg_check_special_colors, xg_set_geometry):
5620 Make sprintf buffers a bit bigger, to avoid potential buffer overrun.
5621
5622 * lread.c (dir_warning): Don't blindly alloca buffer; use SAFE_ALLOCA.
5623 Use esprintf, not sprintf, in case result does not fit in int.
5624
5625 * macros.c (executing_kbd_macro_iterations): Now EMACS_INT, not int.
5626 (Fend_kbd_macro): Don't mishandle MOST_NEGATIVE_FIXNUM by treating
5627 it as a large positive number.
5628 (Fexecute_kbd_macro): Don't assume repeat count fits in int.
5629 * macros.h (executing_kbd_macro_iterations): Now EMACS_INT, not int.
5630
5631 * nsterm.m ((NSSize)windowWillResize): Use esprintf, not sprintf,
5632 in case result does not fit in int.
5633
5634 * print.c (float_to_string): Detect width overflow more reliably.
5635 (print_object): Make sprintf buffer a bit bigger, to avoid potential
5636 buffer overrun. Don't assume list length fits in 'int'. Treat
5637 print length of 0 as 0, not as infinity; to be consistent with other
5638 uses of print length in this function. Don't overflow print length
5639 index. Don't assume hash table size fits in 'long', or that
5640 vectorlike size fits in 'unsigned long'.
5641
5642 * process.c (make_process): Use printmax_t, not int, to format
5643 process-name gensyms.
5644
5645 * sysdep.c (snprintf) [! HAVE_SNPRINTF]: New function.
5646
5647 * term.c (produce_glyphless_glyph): Make sprintf buffer a bit bigger
5648 to avoid potential buffer overrun.
5649
5650 * xfaces.c (x_update_menu_appearance): Don't overrun buffer
5651 if X resource line is longer than 512 bytes.
5652
5653 * xfns.c (x_window): Make sprintf buffer a bit bigger
5654 to avoid potential buffer overrun.
5655
5656 * xterm.c (x_io_error_quitter): Don't overrun sprintf buffer.
5657
5658 * xterm.h (x_check_errors): Add ATTRIBUTE_FORMAT_PRINTF.
5659
5660 2011-09-04 Paul Eggert <eggert@cs.ucla.edu>
5661
5662 Integer overflow fixes for scrolling, etc.
5663 Without these, Emacs silently mishandles large integers sometimes.
5664 For example, "C-u 4294967297 M-x recenter" was treated as if
5665 it were "C-u 1 M-x recenter" on a typical 64-bit host.
5666
5667 * xdisp.c (try_window_id): Check Emacs fixnum range before
5668 converting to 'int'.
5669
5670 * window.c (window_scroll_line_based, Frecenter):
5671 Check that an Emacs fixnum is in range before assigning it to 'int'.
5672 (Frecenter, Fmove_to_window_line): Use EMACS_INT, not int, for
5673 values converted from Emacs fixnums.
5674 (Frecenter): Don't wrap around a line count if it is out of 'int'
5675 range; instead, treat it as an extreme value.
5676 (Fset_window_configuration, compare_window_configurations):
5677 Use ptrdiff_t, not int, for index that might exceed 2 GiB.
5678
5679 * search.c (Freplace_match): Use ptrdiff_t, not int, for indexes
5680 that can exceed INT_MAX. Check that EMACS_INT value is in range
5681 before assigning it to the (possibly-narrower) index.
5682 (match_limit): Don't assume that a fixnum can fit in 'int'.
5683
5684 * print.c (print_object): Use ptrdiff_t, not int, for index that can
5685 exceed INT_MAX.
5686
5687 * indent.c (position_indentation): Now takes ptrdiff_t, not int.
5688 (Fvertical_motion): Don't wrap around LINES values that don't fit
5689 in 'int'. Instead, treat them as extreme values. This is good
5690 enough for windows, which can't have more than INT_MAX lines anyway.
5691
5692 2011-09-03 Lars Magne Ingebrigtsen <larsi@gnus.org>
5693
5694 * Require libxml/parser.h to avoid compilation warning.
5695
5696 * emacs.c (shut_down_emacs): Call xmlCleanupParser on shutdown.
5697
5698 * xml.c (parse_region): Don't call xmlCleanupParser after parsing,
5699 since this reportedly can destroy thread storage.
5700
5701 2011-08-30 Chong Yidong <cyd@stupidchicken.com>
5702
5703 * syntax.c (find_defun_start): Update all cache variables if
5704 exiting early (Bug#9401).
5705
5706 2011-08-30 Eli Zaretskii <eliz@gnu.org>
5707
5708 * image.c (x_bitmap_pixmap): Cast to int to avoid compiler warnings.
5709
5710 * xdisp.c (produce_stretch_glyph): No longer static, compiled also
5711 when HAVE_WINDOW_SYSTEM is not defined. Support both GUI and TTY
5712 frames. Call tty_append_glyph in the TTY case. (Bug#9402)
5713
5714 * term.c (tty_append_glyph): New function.
5715 (produce_stretch_glyph): Static function and its prototype deleted.
5716
5717 * dispextern.h (produce_stretch_glyph, tty_append_glyph):
5718 Add prototypes.
5719
5720 2011-08-29 Paul Eggert <eggert@cs.ucla.edu>
5721
5722 * image.c (parse_image_spec): Check for nonnegative, not for positive,
5723 when checking :margin (Bug#9390).
5724 (IMAGE_NON_NEGATIVE_INTEGER_VALUE_OR_PAIR):
5725 Rename from IMAGE_POSITIVE_INTEGER_VALUE_OR_PAIR,
5726 so that the name doesn't mislead. All uses changed.
5727
5728 2011-08-28 Johan Bockgård <bojohan@gnu.org>
5729
5730 * term.c (init_tty) [HAVE_GPM]: Move mouse settings after
5731 set_tty_hooks.
5732
5733 2011-08-27 Eli Zaretskii <eliz@gnu.org>
5734
5735 * xdisp.c (move_it_to): Don't bail out early when reaching
5736 position beyond to_charpos, if we are scanning backwards.
5737 (move_it_vertically_backward): When DY == 0, make sure we get to
5738 the first character in the line after the newline.
5739
5740 2011-08-27 Paul Eggert <eggert@cs.ucla.edu>
5741
5742 * ccl.c: Improve and simplify overflow checking (Bug#9196).
5743 (ccl_driver): Do not generate an out-of-range pointer.
5744 (Fccl_execute_on_string): Remove unnecessary check for
5745 integer overflow, noted by Stefan Monnier in
5746 <http://lists.gnu.org/archive/html/emacs-devel/2011-08/msg00979.html>.
5747 Remove a FIXME that didn't need fixing.
5748 Simplify the newly-introduced buffer reallocation code.
5749
5750 2011-08-27 Juanma Barranquero <lekktu@gmail.com>
5751
5752 * makefile.w32-in ($(BLD)/alloc.$(O)): Depend on lib/verify.h.
5753
5754 2011-08-26 Paul Eggert <eggert@cs.ucla.edu>
5755
5756 Integer and memory overflow issues (Bug#9196).
5757
5758 * doc.c (get_doc_string): Rework so that
5759 get_doc_string_buffer_size is the actual buffer size, rather than
5760 being 1 less than the actual buffer size; this makes xpalloc more
5761 convenient.
5762
5763 * image.c (x_allocate_bitmap_record, cache_image):
5764 * xselect.c (Fx_register_dnd_atom):
5765 Simplify previous changes by using xpalloc.
5766
5767 * buffer.c (overlay_str_len): Now ptrdiff_t, not EMACS_INT,
5768 since either will do and ptrdiff_t is convenient with xpalloc.
5769
5770 * charset.c (charset_table_size)
5771 (struct charset_sort_data.priority): Now ptrdiff_t.
5772 (charset_compare): Don't overflow if priorities differ greatly.
5773 (Fsort_charsets): Don't assume list length fits in int.
5774 Check for size-calculation overflow when allocating sort data.
5775 (syms_of_charset): Allocate an initial charset table that is
5776 just under 64 KiB, to avoid problems with glibc malloc and mmap.
5777
5778 * cmds.c (internal_self_insert): Check for size-calculation overflow.
5779
5780 * composite.h (struct composition.glyph_len): Now int, not unsigned.
5781 The actual value is always <= INT_MAX, and leaving it unsigned made
5782 overflow checking harder.
5783
5784 * dispextern.h (struct glyph_matrix.rows_allocated)
5785 (struct face_cache.size): Now ptrdiff_t, for convenience in use
5786 with xpalloc. The values are still always <= INT_MAX.
5787
5788 * indent.c (compute_motion): Adjust to region_cache_forward sig change.
5789
5790 * lisp.h (xnmalloc, xnrealloc, xpalloc): New decls.
5791 (SAFE_NALLOCA): New macro.
5792
5793 * region-cache.c (struct boundary.pos, find_cache_boundary)
5794 (move_cache_gap, insert_cache_boundary, delete_cache_boundaries)
5795 (set_cache_region, invalidate_region_cache)
5796 (revalidate_region_cache, know_region_cache, region_cache_forward)
5797 (region_cache_backward, pp_cache):
5798 Use ptrdiff_t, not EMACS_INT, since either will do. This is needed
5799 so that ptrdiff_t * can be passed to xpalloc.
5800 (struct region_cache): Similarly, for gap_start, gap_len, cache_len,
5801 beg_unchanged, end_unchanged, buffer_beg, buffer_end members.
5802 (pp_cache): Don't assume cache_len fits in int.
5803 * region-cache.h: Adjust extern decls to match.
5804
5805 * search.c (scan_buffer, Freplace_match): Use ptrdiff_t, not
5806 EMACS_INT, since either will do, for xpalloc.
5807
5808 * alloc.c: Include verify.h, and check that int fits in ptrdiff_t.
5809 (xnmalloc, xnrealloc, xpalloc): New functions.
5810
5811 * bidi.c (bidi_shelve_header_size): New constant.
5812 (bidi_cache_ensure_space, bidi_shelve_cache): Use it.
5813 (bidi_cache_ensure_space): Avoid integer overflow when allocating.
5814
5815 * bidi.c (bidi_cache_shrink):
5816 * buffer.c (overlays_at, overlays_in, record_overlay_string)
5817 (overlay_strings):
5818 Don't update size of array until after memory allocation succeeds,
5819 because xmalloc/xrealloc may not return.
5820 (struct sortstrlist.bytes): Now ptrdiff_t, as EMACS_INT doesn't help
5821 now that we have proper integer overflow checking.
5822 (record_overlay_string, overlay_strings): Catch overflows when
5823 calculating size of overlay_str_buf.
5824
5825 * callproc.c (Fcall_process): Check for size overflow when
5826 calculating size of args2.
5827 (child_setup): Avoid overflow by using size_t rather than ptrdiff_t.
5828 Normally we prefer signed values, but sticking with ptrdiff_t would
5829 require adding more-complicated checks.
5830
5831 * ccl.c (Fccl_execute_on_string): Check for memory overflow.
5832 Use ptrdiff_t rather than EMACS_INT where ptrdiff_t will do.
5833 Redo buffer-overflow calculations to avoid integer overflow.
5834 Add a FIXME comment where memory seems to be over-allocated.
5835
5836 * character.c (Fstring): Check for size-calculation overflow.
5837
5838 * coding.c (produce_chars): Redo buffer-overflow calculations to avoid
5839 unnecessary integer overflow. Check for size overflow.
5840 (encode_coding_object): Don't update size until xmalloc succeeds.
5841
5842 * composite.c (get_composition_id): Check for overflow in glyph
5843 length calculations.
5844
5845 Integer and memory overflow fixes for display code.
5846 * dispextern.h (struct glyph_pool.nglyphs): Now ptrdiff_t, not int.
5847 * dispnew.c (adjust_glyph_matrix, realloc_glyph_pool)
5848 (scrolling_window): Check for overflow in size calculations.
5849 (line_draw_cost, realloc_glyph_pool, add_row_entry):
5850 Don't assume glyph table len fits in int.
5851 (struct row_entry.bucket, row_entry_pool_size, row_entry_idx)
5852 (row_table_size): Now ptrdiff_t, not int.
5853 (scrolling_window): Avoid overflow in size calculations.
5854 Don't update size until allocation succeeds.
5855 * fns.c (concat): Check for overflow in size calculations.
5856 (next_almost_prime): Verify NEXT_ALMOST_PRIME_LIMIT.
5857 * lisp.h (RANGED_INTEGERP, TYPE_RANGED_INTEGERP): New macros.
5858 (NEXT_ALMOST_PRIME_LIMIT): New constant.
5859
5860 * doc.c (get_doc_string_buffer_size): Now ptrdiff_t, not int.
5861 (get_doc_string): Check for size calculation overflow.
5862 Don't update size until allocation succeeds.
5863 (get_doc_string, Fsubstitute_command_keys): Use ptrdiff_t, not
5864 EMACS_INT, where ptrdiff_t will do.
5865 (Fsubstitute_command_keys): Check for string overflow.
5866
5867 * editfns.c (set_time_zone_rule): Don't assume environment length
5868 fits in int.
5869 (message_length): Now ptrdiff_t, not int.
5870 (Fmessage_box): Don't update size until allocation succeeds.
5871 Don't assume message length fits in int.
5872 (Fformat): Use ptrdiff_t, not EMACS_INT, where ptrdiff_t will do.
5873
5874 * emacs.c (main): Do not reallocate argv, since there is a null at
5875 the end that can be overwritten, and this way there's no need to
5876 worry about size-calculation overflow.
5877 (sort_args): Check for size-calculation overflow.
5878
5879 * eval.c (init_eval_once, grow_specpdl): Don't update size until
5880 alloc succeeds.
5881 (call_debugger, grow_specpdl): Redo calculations to avoid overflow.
5882
5883 * frame.c (set_menu_bar_lines, x_set_frame_parameters)
5884 (x_set_scroll_bar_width, x_figure_window_size):
5885 Check for integer overflow.
5886 (x_set_alpha): Do not assume XINT fits in int.
5887
5888 * frame.h (struct frame): Use int, not EMACS_INT, where int works.
5889 This is for the members text_lines, text_cols, total_lines, total_cols,
5890 where the system imposes an 'int' limit.
5891
5892 * fringe.c (Fdefine_fringe_bitmap):
5893 Don't update size until alloc works.
5894
5895 * ftfont.c (ftfont_get_open_type_spec, setup_otf_gstring)
5896 (ftfont_shape_by_flt): Check for integer overflow in size calculations.
5897
5898 * gtkutil.c (get_utf8_string, xg_store_widget_in_map):
5899 Check for size-calculation overflow.
5900 (get_utf8_string): Use ptrdiff_t, not size_t, where either will
5901 do, as we prefer signed integers.
5902 (id_to_widget.max_size, id_to_widget.used)
5903 (xg_store_widget_in_map, xg_remove_widget_from_map)
5904 (xg_get_widget_from_map, xg_get_scroll_id_for_window)
5905 (xg_remove_scroll_bar, xg_update_scrollbar_pos):
5906 Use and return ptrdiff_t, not int.
5907 (xg_gtk_scroll_destroy): Don't assume ptrdiff_t fits in int.
5908 * gtkutil.h: Change prototypes to match the above.
5909
5910 * image.c (RANGED_INTEGERP, TYPE_RANGED_INTEGERP): Remove; these
5911 are duplicate now that they've been promoted to lisp.h.
5912 (x_allocate_bitmap_record, x_alloc_image_color)
5913 (make_image_cache, cache_image, xpm_load):
5914 Don't update size until alloc is done.
5915 (xpm_load, lookup_rgb_color, lookup_pixel_color, x_to_xcolors)
5916 (x_detect_edges):
5917 Check for size calculation overflow.
5918 (ct_colors_allocated_max): New constant.
5919 (x_to_xcolors, x_detect_edges): Reorder multiplicands to avoid
5920 overflow.
5921
5922 * keyboard.c (read_char, menu_bar_items, tool_bar_items)
5923 (read_char_x_menu_prompt, read_char_minibuf_menu_width)
5924 (read_char_minibuf_menu_prompt, follow_key, read_key_sequence):
5925 Use ptrdiff_t, not int, to count maps.
5926 (read_char_minibuf_menu_prompt): Check for overflow in size
5927 calculations. Don't update size until allocation succeeds.
5928 Redo calculations to avoid overflow.
5929 * keyboard.h: Change prototypes to match the above.
5930
5931 * keymap.c (cmm_size, current_minor_maps): Use ptrdiff_t, not int,
5932 to count maps.
5933 (current_minor_maps): Check for size calculation overflow.
5934 * keymap.h: Change prototypes to match the above.
5935
5936 * lread.c (read1, init_obarray): Don't update size until alloc done.
5937
5938 * macros.c (Fstart_kbd_macro): Don't update size until alloc done.
5939 (store_kbd_macro_char): Reorder multiplicands to avoid overflow.
5940
5941 * nsterm.h (struct ns_color_table.size, struct ns_color_table.avail):
5942 Now ptrdiff_t, not int.
5943 * nsterm.m (ns_index_color): Use ptrdiff_t, not int, for table indexes.
5944 (ns_draw_fringe_bitmap): Rewrite to avoid overflow.
5945
5946 * process.c (Fnetwork_interface_list): Check for overflow
5947 in size calculation.
5948
5949 * region-cache.c (move_cache_gap): Check for size calculation overflow.
5950
5951 * scroll.c (do_line_insertion_deletion_costs): Check for size calc
5952 overflow. Don't bother calling xmalloc when xrealloc will do.
5953
5954 * search.c (Freplace_match): Check for size calculation overflow.
5955 (Fset_match_data): Don't assume list lengths fit in 'int'.
5956
5957 * sysdep.c (system_process_attributes): Use ptrdiff_t, not int,
5958 for command line length. Do not attempt to address one before the
5959 beginning of an array, as that's not portable.
5960
5961 * term.c (max_frame_lines): Remove; unused.
5962 (encode_terminal_src_size, encode_terminal_dst_size): Now ptrdiff_t,
5963 not int.
5964 (encode_terminal_code, calculate_costs): Check for size
5965 calculation overflow.
5966 (encode_terminal_code): Use ptrdiff_t, not int, to record glyph
5967 table lengths and related sizes. Don't update size until alloc
5968 done. Redo calculations to avoid overflow.
5969 (calculate_costs): Don't bother calling xmalloc when xrealloc will do.
5970
5971 * termcap.c (tgetent): Use ptrdiff_t, not int, to record results of
5972 subtracting pointers.
5973 (gobble_line): Check for overflow more carefully. Don't update size
5974 until alloc done.
5975
5976 * tparam.c (tparam1): Use ptrdiff_t, not int, for sizes.
5977 Don't update size until alloc done.
5978 Redo size calculations to avoid overflow.
5979 Check for size calculation overflow.
5980 (main) [DEBUG]: Fix typo in invoking tparam1.
5981
5982 * xdisp.c (store_mode_line_noprop_char, x_consider_frame_title):
5983 Use ptrdiff_t, not int, for sizes.
5984 (store_mode_line_noprop_char): Don't update size until alloc done.
5985
5986 * xfaces.c (lface_id_to_name_size, Finternal_make_lisp_face):
5987 Use ptrdiff_t, not int, for sizes.
5988 (Finternal_make_lisp_face, cache_face):
5989 Check for size calculation overflow.
5990 (cache_face): Treat size calculation overflows as if they were
5991 memory exhaustion (the usual treatment), rather than aborting.
5992
5993 * xfns.c (x_encode_text, x_set_name_internal)
5994 (Fx_change_window_property): Use ptrdiff_t, not int, to count
5995 sizes, since they can exceed INT_MAX in size. Check for size
5996 calculation overflow.
5997
5998 * xgselect.c (gfds_size): Now ptrdiff_t, for convenience with xpalloc.
5999 (xg_select): Check for size calculation overflow.
6000 Don't update size until alloc done.
6001
6002 * xrdb.c (get_environ_db): Don't assume path length fits in int,
6003 as sprintf is limited to int lengths.
6004
6005 * xselect.c (X_LONG_SIZE, X_SHRT_MAX, X_SHRT_MIN, X_LONG_MAX)
6006 (X_LONG_MIN): New macros.
6007 Use them to make the following changes clearer.
6008 (MAX_SELECTION_QUANTUM): Make the other bounds on this value clearer.
6009 This change doesn't affect the value now, but it may help remind
6010 future maintainers not to raise the value too much later.
6011 (SELECTION_QUANTUM): Remove, replacing with ...
6012 (selection_quantum): ... new function, which avoids overflow.
6013 All uses changed.
6014 (struct selection_data.size): Now ptrdiff_t, not int, to avoid
6015 assumption that selection length fits in 'int'.
6016 (x_reply_selection_request, x_handle_selection_request)
6017 (x_get_window_property, receive_incremental_selection)
6018 (x_get_window_property_as_lisp_data, selection_data_to_lisp_data)
6019 (lisp_data_to_selection_data, clean_local_selection_data):
6020 Use ptrdiff_t, not int, to record length of selection.
6021 (x_reply_selection_request, x_get_window_property)
6022 (receive_incremental_selection, x_property_data_to_lisp):
6023 Redo calculations to avoid overflow.
6024 (x_reply_selection_request): When sending hint, ceiling it at
6025 X_LONG_MAX rather than relying on wraparound overflow to send
6026 something.
6027 (x_get_window_property, receive_incremental_selection)
6028 (lisp_data_to_selection_data, x_property_data_to_lisp):
6029 Check for size-calculation overflow.
6030 (x_get_window_property, receive_incremental_selection)
6031 (lisp_data_to_selection_data, Fx_register_dnd_atom):
6032 Don't store size until memory allocation succeeds.
6033 (x_get_window_property): Plug memory leak on memory exhaustion.
6034 Don't double-block input; malloc is safe here. Don't assume 2**34
6035 - 4 fits in unsigned long. Add an xassert to check
6036 XGetWindowProperty overflow. Be more careful about overflow
6037 calculations, and distinguish size from memory overflow better.
6038 (receive_incremental_selection): When tracing, don't assume
6039 unsigned int is less than INT_MAX.
6040 (x_selection_data_to_lisp_data): Remove unnecessary (and in theory
6041 harmful) conversions of unsigned short to int.
6042 (lisp_data_to_selection_data): Don't assume that integers
6043 in the range -65535 through -1 fit in an X unsigned short.
6044 Don't assume that ULONG_MAX == X_ULONG_MAX. Don't store into
6045 result parameters unless successful. Rely on cons_to_unsigned
6046 to report problems with elements; the old code wasn't right anyway.
6047 (x_check_property_data): Check for int overflow; we cannot use
6048 a wider type due to X limits.
6049 (x_handle_dnd_message): Use unsigned int, to avoid int overflow.
6050
6051 * xsmfns.c (smc_save_yourself_CB): Check for size calc overflow.
6052
6053 * xterm.c (x_color_cells, x_send_scrollbar_event, handle_one_xevent)
6054 (x_term_init): Check for size calculation overflow.
6055 (x_color_cells): Don't store size until memory allocation succeeds.
6056 (handle_one_xevent): Use ptrdiff_t, not int, for byte counts.
6057 Don't assume alloca size is less than MAX_ALLOCA.
6058 (x_term_init): Don't assume length fits in int (sprintf is limited
6059 to int size).
6060
6061 Use ptrdiff_t for composition IDs.
6062 * character.c (lisp_string_width):
6063 * composite.c (composition_table_size, n_compositions)
6064 (get_composition_id, composition_gstring_from_id):
6065 * dispextern.h (struct glyph_string.cmp_id, struct composition_it.id):
6066 * xdisp.c (BUILD_COMPOSITE_GLYPH_STRING):
6067 * window.c (Frecenter):
6068 Use ptrdiff_t, not int, for composition IDs.
6069 * composite.c (get_composition_id): Check for integer overflow.
6070 * composite.h: Adjust prototypes to match the above changes.
6071
6072 Use ptrdiff_t for hash table indexes.
6073 * category.c (hash_get_category_set):
6074 * ccl.c (ccl_driver):
6075 * charset.h (struct charset.hash_index, CHECK_CHARSET_GET_ID):
6076 * coding.c (coding_system_charset_list, detect_coding_system):
6077 * coding.h (struct coding_system.id):
6078 * composite.c (get_composition_id, gstring_lookup_cache):
6079 * fns.c (hash_lookup, hash_put, Fgethash, Fputhash):
6080 * image.c (xpm_get_color_table_h):
6081 * lisp.h (hash_lookup, hash_put):
6082 * minibuf.c (Ftest_completion):
6083 Use ptrdiff_t for hash table indexes, not int (which is too
6084 narrow, on 64-bit hosts) or EMACS_INT (which is too wide, on
6085 32-bit --with-wide-int hosts).
6086
6087 * charset.c (Fdefine_charset_internal): Check for integer overflow.
6088 Add a FIXME comment about memory leaks.
6089 (syms_of_charset): Don't assume xmalloc returns.
6090
6091 Don't assume that stated character widths fit in int.
6092 * character.c (Fchar_width, c_string_width, lisp_string_width):
6093 * character.h (CHAR_WIDTH):
6094 * indent.c (MULTIBYTE_BYTES_WIDTH):
6095 Use sanitize_char_width to avoid undefined and/or bad behavior
6096 with outlandish widths.
6097 * character.h (sanitize_tab_width): Rename from sanitize_width,
6098 now that we have two such functions. All uses changed.
6099 (sanitize_char_width): New inline function.
6100
6101 Don't assume that tab-width fits in int.
6102 * character.h (sanitize_width): New inline function.
6103 (SANE_TAB_WIDTH): New macro.
6104 (ASCII_CHAR_WIDTH): Use it.
6105 * indent.c (sane_tab_width): Remove. All uses replaced by
6106 SANE_TAB_WIDTH (current_buffer).
6107 * xdisp.c (init_iterator): Use SANE_TAB_WIDTH.
6108
6109 * fileio.c: Integer overflow issues with file modes.
6110 (Fset_file_modes, auto_save_1): Don't assume EMACS_INT fits in int.
6111
6112 * charset.c (read_hex): New arg OVERFLOW. All uses changed.
6113 Remove unreachable code.
6114 (read_hex, load_charset_map_from_file): Check for integer overflow.
6115
6116 * xterm.c: Don't go over XClientMessageEvent limit.
6117 (scroll_bar_windows_size): Now ptrdiff_t, as we prefer signed.
6118 (x_send_scroll_bar_event): Likewise. Check that the size does not
6119 exceed limits imposed by XClientMessageEvent, as well as the usual
6120 ptrdiff_t and size_t limits.
6121
6122 * keyboard.c: Overflow, signedness and related fixes.
6123 (make_lispy_movement): Use same integer type in forward decl
6124 that is used in the definition.
6125 (read_key_sequence, keyremap_step):
6126 Change bufsize argument back to int, undoing my 2011-03-30 change.
6127 We prefer signed types, and int is wide enough here.
6128 (parse_tool_bar_item): Don't assume tool_bar_max_label_size is less
6129 than TYPE_MAXIMUM (EMACS_INT) / 2. Don't let the label size grow
6130 larger than STRING_BYTES_BOUND. Use ptrdiff_t for Emacs string
6131 length, not size_t. Use ptrdiff_t for index, not int.
6132 (keyremap_step, read_key_sequence): Redo bufsize check to avoid
6133 possibility of integer overflow.
6134
6135 Overflow, signedness and related fixes for images.
6136
6137 * dispextern.h (struct it.stack[0].u.image.image_id)
6138 (struct_it.image_id, struct image.id, struct image_cache.size)
6139 (struct image_cache.used, struct image_cache.ref_count):
6140 * gtkutil.c (update_frame_tool_bar):
6141 * image.c (x_reference_bitmap, Fimage_size, Fimage_mask_p)
6142 (Fimage_metadata, free_image_cache, clear_image_cache, lookup_image)
6143 (cache_image, mark_image_cache, x_kill_gs_process, Flookup_image):
6144 * nsmenu.m (update_frame_tool_bar):
6145 * xdisp.c (calc_pixel_width_or_height):
6146 * xfns.c (image_cache_refcount):
6147 Image IDs are now ptrdiff_t, not int, to avoid arbitrary limits
6148 on typical 64-bit hosts.
6149
6150 * image.c (RANGED_INTEGERP, TYPE_RANGED_INTEGERP): New macros.
6151 (x_bitmap_pixmap, x_create_x_image_and_pixmap):
6152 Omit unnecessary casts to int.
6153 (parse_image_spec): Check that integers fall into 'int' range
6154 when the callers expect that.
6155 (image_ascent): Redo ascent calculation to avoid int overflow.
6156 (clear_image_cache): Avoid overflow when sqrt (INT_MAX) < nimages.
6157 (lookup_image): Remove unnecessary tests.
6158 (xbm_image_p): Locals are now of int, not EMACS_INT,
6159 since parse_image_check makes sure they fit into int.
6160 (png_load, gif_load, svg_load_image):
6161 Prefer int to unsigned where either will do.
6162 (tiff_handler): New function, combining the cores of the
6163 old tiff_error_handler and tiff_warning_handler.
6164 This function is rewritten to use vsnprintf and thereby avoid
6165 stack buffer overflows. It uses only the features of vsnprintf
6166 that are common to both POSIX and native Microsoft.
6167 (tiff_error_handler, tiff_warning_handler): Use it.
6168 (tiff_load, gif_load, imagemagick_load_image):
6169 Don't assume :index value fits in 'int'.
6170 (gif_load): Omit unnecessary cast to double, and avoid double-rounding.
6171 (imagemagick_load_image): Check that crop parameters fit into
6172 the integer types that MagickCropImage accepts. Don't assume
6173 Vimagemagick_render_type has a nonnegative value. Don't assume
6174 size_t fits in 'long'.
6175 (gs_load): Use printmax_t to print the widest integers possible.
6176 Check for integer overflow when computing image height and width.
6177
6178 2011-08-26 Eli Zaretskii <eliz@gnu.org>
6179
6180 * xdisp.c (redisplay_window): Don't force window start if point
6181 will be invisible in the resulting window. (Bug#9324)
6182
6183 2011-08-25 Eli Zaretskii <eliz@gnu.org>
6184
6185 * xdisp.c (compute_display_string_pos): Return 2 in DISP_PROP when
6186 the display spec is of the form `(space ...)'.
6187 (handle_display_spec): Return the value returned by
6188 handle_single_display_spec, not just 1 or zero.
6189 (handle_single_display_spec): If the display spec is of the form
6190 `(space ...)', and specifies display in the text area, return 2
6191 rather than 1.
6192 (try_cursor_movement): Check for the need to scroll more
6193 accurately, and prefer exact match for point under bidi.
6194 Don't advance `row' beyond the last row of the window.
6195
6196 * dispextern.h (struct bidi_it): Rename the disp_prop_p member
6197 into disp_prop; all users changed.
6198
6199 * bidi.c (bidi_fetch_char): If compute_display_string_pos returns
6200 DISP_PROP = 2, substitute the u+2029 PARAGRAPH SEPARATOR character
6201 for the text covered by the display property.
6202
6203 2011-08-25 Chong Yidong <cyd@stupidchicken.com>
6204
6205 * buffer.c (Fbury_buffer_internal): Rename from Funrecord_buffer.
6206 Change return value to nil.
6207 (Frecord_buffer): Delete unused function.
6208
6209 2011-08-24 Eli Zaretskii <eliz@gnu.org>
6210
6211 * xdisp.c (Fcurrent_bidi_paragraph_direction): For unibyte
6212 buffers, return left-to-right.
6213 (set_cursor_from_row): Consider candidate row a win if its glyph
6214 represents a newline and point is on that newline. Fixes cursor
6215 positioning on the newline at EOL of R2L text within L2R
6216 paragraph, and vice versa.
6217 (try_cursor_movement): Check continued rows, in addition to
6218 continuation rows. Fixes unwarranted scroll when point enters a
6219 continued line of R2L text within an L2R paragraph, or vice versa.
6220 (cursor_row_p): Consider the case of point being equal to
6221 MATRIX_ROW_END_CHARPOS. Prevents cursor being stuck when moving
6222 from the end of a short line to the beginning of a continued line
6223 of R2L text within L2R paragraph.
6224 (RECORD_MAX_MIN_POS): For max_pos, use IT_CHARPOS even for
6225 composed characters.
6226
6227 * bidi.c (bidi_check_type): Use xassert.
6228 (bidi_cache_iterator_state): Update the disp_pos and disp_prop_p
6229 members.
6230
6231 2011-08-23 Eli Zaretskii <eliz@gnu.org>
6232
6233 * bidi.c (bidi_get_type): Abort if we get zero as the bidi type of
6234 a character.
6235
6236 2011-08-23 Chong Yidong <cyd@stupidchicken.com>
6237
6238 * nsfont.m (ns_otf_to_script): Fix typo.
6239
6240 2011-08-22 Kenichi Handa <handa@m17n.org>
6241
6242 * chartab.c (Fset_char_table_extra_slot): Do not inhibit setting a
6243 extra slot even if the purpose is char-code-property-table.
6244
6245 2011-08-23 Eli Zaretskii <eliz@gnu.org>
6246
6247 * xdisp.c (redisplay_window): When computing centering_position,
6248 account for the height of the header line. (Bug#8874)
6249
6250 * dispnew.c (buffer_posn_from_coords): Use buf_charpos_to_bytepos
6251 instead of CHAR_TO_BYTE. Fixes a crash when a completion
6252 candidate is selected by the mouse, and that candidate has a
6253 composed character under the mouse.
6254
6255 * xdisp.c (x_produce_glyphs): Set it->nglyphs to 1. Fixes pixel
6256 coordinates reported by pos-visible-in-window-p for a composed
6257 character in column zero.
6258
6259 2011-08-23 Stefan Monnier <monnier@iro.umontreal.ca>
6260
6261 * cmds.c (Fself_insert_command): Mention post-self-insert-hook.
6262
6263 2011-08-22 Eli Zaretskii <eliz@gnu.org>
6264
6265 * xdisp.c (BUFFER_POS_REACHED_P): If this is a composition,
6266 consider it a hit if to_charpos is anywhere in the range of the
6267 composed buffer positions.
6268
6269 2011-08-22 Chong Yidong <cyd@stupidchicken.com>
6270
6271 * image.c (gif_load): Don't assume that each subimage has the same
6272 dimensions as the base image. Handle disposal method that is
6273 "undefined" by the gif spec (Bug#9335).
6274
6275 2011-08-20 Chong Yidong <cyd@stupidchicken.com>
6276
6277 * eval.c (Fsignal): Handle `debug' symbol in error handler (Bug#9329).
6278 (Fcondition_case): Document `debug' symbol in error handler.
6279
6280 2011-08-19 Eli Zaretskii <eliz@gnu.org>
6281
6282 * xfaces.c (face_at_buffer_position): Avoid repeated evaluation of
6283 face ID by FACE_FROM_ID, and avoid a crash when mouse is moved
6284 from an Org mode buffer to a Speedbar frame.
6285
6286 * xdisp.c (RECORD_MAX_MIN_POS): If the display element comes from
6287 a composition, take its buffer position from IT->cmp_it.charpos.
6288 Fixes cursor positioning at the beginning of a line that begins
6289 with a composed character.
6290
6291 2011-08-18 Eli Zaretskii <eliz@gnu.org>
6292
6293 * bidi.c (bidi_get_type): If bidi_type_table reports zero as the
6294 character bidirectional type, use STRONG_L instead. Fixes crashes
6295 in a buffer produced by `describe-categories'.
6296
6297 * dispextern.h (struct bidi_it): Move disp_pos and disp_prop_p
6298 members before the level stack, so they would be saved and
6299 restored when copying iterator state. Fixes incorrect reordering
6300 around TABs covered by display properties.
6301
6302 2011-08-18 Andreas Schwab <schwab@linux-m68k.org>
6303
6304 * process.c (Fnetwork_interface_list): Correctly determine buffer size.
6305
6306 2011-08-17 Chong Yidong <cyd@stupidchicken.com>
6307
6308 * eval.c (internal_condition_case, internal_condition_case_1)
6309 (internal_condition_case_2, internal_condition_case_n):
6310 Remove unnecessary aborts (Bug#9081).
6311
6312 2011-08-17 Eli Zaretskii <eliz@gnu.org>
6313
6314 * lread.c (Fload) [DOS_NT]: If `openp' returns -2, but the file
6315 has no `load' handler, try opening the file locally. (Bug#9311)
6316
6317 2011-08-16 Ken Brown <kbrown@cornell.edu>
6318
6319 * gmalloc.c: Expand comment.
6320
6321 2011-08-16 Eli Zaretskii <eliz@gnu.org>
6322
6323 * xdisp.c (set_cursor_from_row): Don't accept a previous candidate
6324 if it fails the cursor_row_p test. Fixes cursor positioning at ZV.
6325
6326 2011-08-16 Ken Brown <kbrown@cornell.edu>
6327
6328 Fix memory allocation problems in Cygwin build (Bug#9273).
6329
6330 * unexcw.c ( __malloc_initialized): Declare external variable.
6331 (fixup_executable): Force the dumped emacs to reinitialize malloc.
6332
6333 * gmalloc.c [CYGWIN] (bss_sbrk_heapbase, bss_sbrk_heapinfo):
6334 New variables.
6335 (malloc_initialize_1) [CYGWIN]: Prepare for reinitializing the
6336 dumped emacs.
6337 (_free_internal_nolock) [CYGWIN]: Ignore requests to free storage
6338 in the static heap.
6339 [CYGWIN] (special_realloc): New function.
6340 (_realloc_internal_nolock) [CYGWIN]: Use the new function on
6341 requests to realloc storage in the static heap.
6342
6343 2011-08-15 Paul Eggert <eggert@cs.ucla.edu>
6344
6345 * bidi.c (bidi_initialize): Remove unused local.
6346
6347 2011-08-15 Eli Zaretskii <eliz@gnu.org>
6348
6349 * bidimirror.h:
6350 * biditype.h: Remove file.
6351 * makefile.w32-in ($(BLD)/bidi.$(O)):
6352 * deps.mk (bidi.o): Remove biditype.h and bidimirror.h.
6353
6354 * dispextern.h: Fix a typo in the comment to bidi_type_t.
6355
6356 * chartab.c: Improve commentary for the uniprop_table API.
6357
6358 * bidi.c (bidi_paragraph_init): Support zero value of
6359 bidi_ignore_explicit_marks_for_paragraph_level.
6360 (bidi_initialize): Use uniprop_table instead of including
6361 biditype.h and bidimirror.h.
6362
6363 * xdisp.c (move_it_in_display_line_to): Don't reset pixel
6364 coordinates of the iterator when restoring from ppos_it.
6365 (Bug#9296)
6366
6367 2011-08-14 Kenichi Handa <handa@m17n.org>
6368
6369 * process.c (create_process): Call setup_process_coding_systems
6370 after the pid of the process is set to -1 (Bug#8162).
6371
6372 2011-08-14 Eli Zaretskii <eliz@gnu.org>
6373
6374 * xdisp.c (move_it_in_display_line_to): Don't invoke
6375 IT_RESET_X_ASCENT_DESCENT when iterator position was restored from
6376 ppos_it. Fixes vertical cursor motion when line beginning is
6377 covered by an image. (Bug#9296)
6378
6379 2011-08-14 Jan Djärv <jan.h.d@swipnet.se>
6380
6381 * nsterm.h (ns_run_ascript): Declare.
6382 (NSAPP_DATA2_RUNASSCRIPT): Define.
6383
6384 * nsfns.m (as_script, as_result, as_status): New static variables.
6385 (ns_run_ascript): New function.
6386 (Fns_do_applescript): Set variables as_*. Make an NSApplicationDefined
6387 event with data2 set to NSAPP_DATA2_RUNASSCRIPT, post it and then start
6388 the event loop. Get status from as_status (Bug#7276).
6389
6390 * nsterm.m (sendEvent): If event is NSApplicationDefined and
6391 data2 is NSAPP_DATA2_RUNASSCRIPT, call ns_run_ascript and then exit
6392 the event loop (Bug#7276).
6393
6394 2011-08-14 Andreas Schwab <schwab@linux-m68k.org>
6395
6396 * gnutls.c (QCgnutls_bootprop_priority)
6397 (QCgnutls_bootprop_trustfiles, QCgnutls_bootprop_keylist)
6398 (QCgnutls_bootprop_crlfiles, QCgnutls_bootprop_callbacks)
6399 (QCgnutls_bootprop_loglevel, QCgnutls_bootprop_hostname)
6400 (QCgnutls_bootprop_min_prime_bits, QCgnutls_bootprop_verify_flags)
6401 (QCgnutls_bootprop_verify_hostname_error)
6402 (QCgnutls_bootprop_callbacks_verify): Rename from
6403 Qgnutls_bootprop_..., all uses changed.
6404
6405 * xfaces.c (QCignore_defface): Rename from Qignore_defface, all
6406 uses changed.
6407
6408 2011-08-14 Paul Eggert <eggert@cs.ucla.edu>
6409
6410 * xfaces.c (Qframe_set_background_mode): Now static.
6411 * dispextern.h (Qframe_set_background_mode): Remove decl.
6412
6413 * process.c (Fnetwork_interface_info): Declare local only if needed.
6414
6415 2011-08-13 Jan Djärv <jan.h.d@swipnet.se>
6416
6417 * process.c: Include ifaddrs.h and net/if_dl.h if available (Bug#8477).
6418 (Fnetwork_interface_list): Allocate in increments of bytes instead
6419 of sizeof (struct ifreq). Iterate over ifconf.ifc_req by counting
6420 bytes (Bug#8477). Count bytes correctly when ifr_addr is a struct
6421 sockaddr.
6422 (struct ifflag_def): notrailers is smart on OSX.
6423 (Fnetwork_interface_info): Handle case when ifr_flags is negative.
6424 Get hardware address with getifaddrs if available.
6425
6426 2011-08-12 Eli Zaretskii <eliz@gnu.org>
6427
6428 * xdisp.c (iterate_out_of_display_property): xassert that
6429 IT->position is set to within IT->object's boundaries. Break from
6430 the loop as soon as EOB is reached; avoids infloops in redisplay
6431 when IT->position is set up wrongly due to some bug.
6432 Set IT->current to match the bidi iterator unconditionally.
6433 (push_display_prop): Allow GET_FROM_STRING as IT->method on
6434 entry. Force push_it to save on the stack the current
6435 buffer/string position, to be restored by pop_it. Fix flags in
6436 the iterator structure wrt the object coming from a display
6437 property, as `line-prefix' and `wrap-prefix' are not ``replacing''
6438 properties. (Bug#9284)
6439
6440 2011-08-09 Andreas Schwab <schwab@linux-m68k.org>
6441
6442 * fontset.c (fontset_get_font_group): Add proper type checks.
6443 (Bug#9172)
6444
6445 2011-08-09 YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
6446
6447 * unexmacosx.c (print_load_command_name): Add cases LC_FUNCTION_STARTS
6448 and LC_VERSION_MIN_MACOSX.
6449 (copy_linkedit_data) [LC_FUNCTION_STARTS]: New function.
6450 (dump_it) [LC_FUNCTION_STARTS]: Use it.
6451
6452 2011-08-08 Eli Zaretskii <eliz@gnu.org>
6453
6454 * xdisp.c (forward_to_next_line_start): Allow to use the
6455 no-display-properties-and-no-overlays under bidi display.
6456 Set disp_pos in the bidi iterator to avoid searches for display
6457 properties and overlays.
6458
6459 2011-08-08 Chong Yidong <cyd@stupidchicken.com>
6460
6461 * editfns.c (Fset_time_zone_rule): Document relationship with the
6462 setenv function.
6463
6464 * ftfont.c (ftfont_pattern_entity): Copy the extras argument to
6465 the font entity extracted from the cache (Bug#8109).
6466
6467 2011-08-07 Chong Yidong <cyd@stupidchicken.com>
6468
6469 * composite.c (autocmp_chars): Don't reset point. That is done by
6470 restore_point_unwind (Bug#5984).
6471
6472 2011-08-07 Juri Linkov <juri@jurta.org>
6473
6474 * editfns.c (Fformat_time_string): Doc fix, add tag `usage:'
6475 to show the arg `TIME' instead of `TIMEVAL'.
6476
6477 2011-08-06 Eli Zaretskii <eliz@gnu.org>
6478
6479 * xdisp.c (set_cursor_from_row): Fix cursor positioning when a
6480 display property strides EOL and includes a newline, as in
6481 longlines-mode. (Bug#9254)
6482 (move_it_in_display_line_to): Fix vertical-motion in a buffer with
6483 word-wrap under bidirectional display. (Bug#9224)
6484
6485 * bidi.c (bidi_unshelve_cache): Don't reset the cache if JUST_FREE
6486 is non-zero, even if the data buffer is NULL. Fixes a crash in
6487 vertical-motion with longlines-mode. (Bug#9254)
6488
6489 2011-08-05 Eli Zaretskii <eliz@gnu.org>
6490
6491 * bidi.c <bidi_cache_total_alloc>: Now static.
6492 (bidi_initialize): Initialize bidi_cache_total_alloc.
6493
6494 * xdisp.c (display_line): Release buffer allocated for shelved bidi
6495 cache. (Bug#9221)
6496
6497 * bidi.c (bidi_shelve_cache, bidi_unshelve_cache): Track total
6498 amount allocated this far in `bidi_cache_total_alloc'.
6499 (bidi_unshelve_cache): Accept an additional argument JUST_FREE; if
6500 non-zero, only free the data buffer without restoring the cache
6501 contents. All callers changed.
6502
6503 * dispextern.h (bidi_unshelve_cache): Update prototype.
6504
6505 * xdisp.c (SAVE_IT, pos_visible_p, move_it_in_display_line_to)
6506 (move_it_in_display_line, move_it_to)
6507 (move_it_vertically_backward, move_it_by_lines): Replace the call
6508 to xfree to an equivalent call to bidi_unshelve_cache.
6509 (move_it_in_display_line_to): Fix logic of returning
6510 MOVE_POS_MATCH_OR_ZV in the bidi case. (Bug#9224)
6511
6512 2011-08-05 Eli Zaretskii <eliz@gnu.org>
6513
6514 * xdisp.c (set_cursor_from_row): Prefer the candidate glyph that
6515 came from a string character with a `cursor' property. (Bug#9229)
6516
6517 2011-08-04 Jan Djärv <jan.h.d@swipnet.se>
6518
6519 * Makefile.in (LIB_PTHREAD): New variable.
6520 (LIBES): Add LIB_PTHREAD (Bug#9216).
6521
6522 * alloc.c, emacs.c, gmalloc.c, gtkutil.c, keyboard.c, syssignal.h:
6523 Rename HAVE_GTK_AND_PTHREAD to HAVE_PTHREAD (Bug#9216).
6524
6525 2011-08-04 Andreas Schwab <schwab@linux-m68k.org>
6526
6527 * regex.c (re_iswctype): Remove some redundant boolean conversions.
6528
6529 2011-08-04 Jan Djärv <jan.h.d@swipnet.se>
6530
6531 * xterm.c (x_find_topmost_parent): New function.
6532 (x_set_frame_alpha): Find topmost parent window with
6533 x_find_topmost_parent and set the property there also (bug#9181).
6534 (handle_one_xevent): Call x_set_frame_alpha on ReparentNotify.
6535
6536 2011-08-04 Paul Eggert <eggert@cs.ucla.edu>
6537
6538 * callproc.c (Fcall_process): Avoid vfork clobbering
6539 the local vars buffer, coding_systems, current_dir.
6540
6541 2011-08-03 Stefan Monnier <monnier@iro.umontreal.ca>
6542
6543 * keymap.c (Fmake_composed_keymap): Move to subr.el.
6544
6545 2011-08-03 Paul Eggert <eggert@cs.ucla.edu>
6546
6547 * fontset.c (dump_fontset) [FONTSET_DEBUG]: Declare EXTERNALLY_VISIBLE
6548 so that it is not optimized away.
6549
6550 * xdisp.c (compute_display_string_pos): Remove unused local.
6551
6552 2011-08-02 Eli Zaretskii <eliz@gnu.org>
6553
6554 Fix slow cursor motion and scrolling in large buffers with
6555 selective display, like Org Mode buffers. (Bug#9218)
6556
6557 * dispextern.h (struct bidi_it): New member disp_prop_p.
6558
6559 * xdisp.c: Remove one-slot cache of display string positions.
6560 (compute_display_string_pos): Accept an additional argument
6561 DISP_PROP_P; callers changed. Scan at most 5K characters forward
6562 for a display string or property. If found, set DISP_PROP_P
6563 non-zero.
6564
6565 * bidi.c (bidi_fetch_char): Accept an additional argument
6566 DISP_PROP_P, and pass it to compute_display_string_pos.
6567 Only handle text covered by a display string if DISP_PROP_P is returned
6568 non-zero. All callers of bidi_fetch_char changed.
6569
6570 2011-08-02 Stefan Monnier <monnier@iro.umontreal.ca>
6571
6572 * keymap.c (Fdefine_key): Fix Lisp_Object/int mixup; apply some CSE.
6573
6574 2010-12-03 Don March <don@ohspite.net>
6575
6576 * keymap.c (Fdefine_key): Fix non-prefix key error message when
6577 last character M-[char] is translated to ESC [char] (bug#7541).
6578
6579 2011-08-02 Kenichi Handa <handa@m17n.org>
6580
6581 * lisp.h (uniprop_table): Extern it.
6582
6583 * chartab.c (uniprop_table): Make it non-static.
6584
6585 2011-08-01 Eli Zaretskii <eliz@gnu.org>
6586
6587 * xdisp.c (forward_to_next_line_start): Accept additional argument
6588 BIDI_IT_PREV, and store into it the state of the bidi iterator had
6589 on the newline.
6590 (reseat_at_next_visible_line_start): Use the bidi iterator state
6591 returned by forward_to_next_line_start to restore the state of
6592 it->bidi_it after backing up to previous newline. (Bug#9212)
6593
6594 2011-07-30 Andreas Schwab <schwab@linux-m68k.org>
6595
6596 * regex.c (re_comp): Protoize.
6597 (re_exec): Fix return type.
6598 (regexec): Fix type of `ret'. (Bug#9203)
6599
6600 2011-07-28 Paul Eggert <eggert@cs.ucla.edu>
6601
6602 * image.c (check_image_size): Use 1024x1024 if unknown frame (Bug#9189).
6603 This is needed if max-image-size is a floating-point number.
6604
6605 2011-07-28 Andreas Schwab <schwab@linux-m68k.org>
6606
6607 * print.c (print_object): Print empty symbol as ##.
6608
6609 * lread.c (read1): Read ## as empty symbol.
6610
6611 2011-07-28 Alp Aker <alp.tekin.aker@gmail.com>
6612
6613 * nsfns.m (x_set_foreground_color): Set f->foreground_pixel when
6614 setting frame foreground color (Bug#9175).
6615 (x_set_background_color): Likewise.
6616
6617 * nsmenu.m (-setText): Size tooltip dimensions precisely to
6618 contents (Bug#9176).
6619 (EmacsTooltip -init): Remove bezels and add shadows to
6620 tooltip windows.
6621
6622 * nsterm.m (ns_dumpglyphs_stretch): Avoid overwriting left fringe
6623 or scroll bar (Bug#8470).
6624
6625 * nsfont.m (nsfont_open): Remove assignment to voffset and
6626 unnecessary vars hshink, expand, hd, full_height, min_height.
6627 (nsfont_draw): Use s->ybase as baseline for glyph drawing (Bug#8913).
6628
6629 * nsterm.h (nsfont_info): Remove voffset field.
6630
6631 2011-07-28 Alp Aker <alp.tekin.aker@gmail.com>
6632
6633 Implement strike-through and overline on NextStep (Bug#8863).
6634
6635 * nsfont.m (nsfont_open): Use underline position provided by font,
6636 instead of hard-coded value of 2.
6637 (nsfont_draw): Call ns_draw_text_decoration instead.
6638
6639 * nsterm.h: Add declaration for ns_draw_text_decoration.
6640
6641 * nsterm.m (ns_draw_text_decoration): New function for drawing
6642 underline, overline, and strike-through.
6643 (ns_dumpglyphs_image, ns_dumpglyphs_stretch): Add call to
6644 ns_draw_text_decoration. Change treatment of cursor drawing to
6645 accommodate underlining, etc.
6646
6647 2011-07-28 Eli Zaretskii <eliz@gnu.org>
6648
6649 * buffer.c (init_buffer_once): Set bidi-display-reordering to t by
6650 default.
6651
6652 2011-07-28 Paul Eggert <eggert@cs.ucla.edu>
6653
6654 * alloc.c (memory_full) [!SYNC_INPUT]: Fix signal-related race.
6655 Without this fix, if a signal arrives just after memory fills up,
6656 'malloc' might be invoked reentrantly.
6657
6658 * image.c (x_check_image_size) [!HAVE_X_WINDOWS]: Return 1.
6659 In other words, assume that every image size is allowed, on non-X
6660 hosts. This assumption is probably wrong, but it lets Emacs compile.
6661
6662 2011-07-28 Andreas Schwab <schwab@linux-m68k.org>
6663
6664 * regex.c (re_iswctype): Convert return values to boolean.
6665
6666 2011-07-28 Eli Zaretskii <eliz@fencepost.gnu.org>
6667
6668 * xdisp.c (compute_display_string_pos): Don't use cached display
6669 string position if the buffer had its restriction changed.
6670 (Bug#9184)
6671
6672 2011-07-28 Paul Eggert <eggert@cs.ucla.edu>
6673
6674 * callproc.c (Fcall_process): Use 'volatile' to avoid vfork clobbering.
6675
6676 2011-07-28 Paul Eggert <eggert@cs.ucla.edu>
6677
6678 Integer signedness and overflow and related fixes. (Bug#9079)
6679
6680 * bidi.c: Integer size and overflow fixes.
6681 (bidi_cache_size, bidi_cache_idx, bidi_cache_last_idx)
6682 (bidi_cache_start, bidi_cache_fetch_state, bidi_cache_search)
6683 (bidi_cache_find_level_change, bidi_cache_ensure_space)
6684 (bidi_cache_iterator_state, bidi_cache_find, bidi_cache_start_stack)
6685 (bidi_find_other_level_edge):
6686 Use ptrdiff_t instead of EMACS_INT where either will do.
6687 This works better on 32-bit hosts configured --with-wide-int.
6688 (bidi_cache_ensure_space): Check for size-calculation overflow.
6689 Use % rather than repeated addition, for better worst-case speed.
6690 Don't set bidi_cache_size until after xrealloc returns, because it
6691 might not return.
6692 (bidi_dump_cached_states): Use ptrdiff_t, not int, to avoid overflow.
6693 (bidi_cache_ensure_space): Also check that the bidi cache size
6694 does not exceed that of the largest Lisp string or buffer. See Eli
6695 Zaretskii in <http://debbugs.gnu.org/cgi/bugreport.cgi?bug=9079#29>.
6696
6697 * alloc.c (__malloc_size_t): Remove.
6698 All uses replaced by size_t. See Andreas Schwab's note
6699 <http://debbugs.gnu.org/cgi/bugreport.cgi?bug=9079#8>.
6700
6701 * image.c: Improve checking for integer overflow.
6702 (check_image_size): Assume that f is nonnull, since
6703 it is always nonnull in practice. This is one less thing to
6704 worry about when checking for integer overflow later.
6705 (x_check_image_size): New function, which checks for integer
6706 overflow issues inside X.
6707 (x_create_x_image_and_pixmap, xbm_read_bitmap_data): Use it.
6708 This removes the need for a memory_full check.
6709 (xbm_image_p): Rewrite to avoid integer multiplication overflow.
6710 (Create_Pixmap_From_Bitmap_Data, xbm_load): Use x_check_image_size.
6711 (xbm_read_bitmap_data): Change locals back to 'int', since
6712 their values must fit in 'int'.
6713 (xpm_load_image, png_load, tiff_load):
6714 Invoke x_create_x_image_and_pixmap earlier,
6715 to avoid much needless work if the image is too large.
6716 (tiff_load): Treat overly large images as if
6717 x_create_x_image_and_pixmap failed, not as malloc failures.
6718 (gs_load): Use x_check_image_size.
6719
6720 * gtkutil.c: Omit integer casts.
6721 (xg_get_pixbuf_from_pixmap): Remove unnecessary cast.
6722 (xg_set_toolkit_scroll_bar_thumb): Rewrite to avoid need for cast.
6723
6724 * image.c (png_load): Don't assume height * row_bytes fits in 'int'.
6725
6726 * xfaces.c (Fbitmap_spec_p): Fix integer overflow bug.
6727 Without this fix, (bitmap-spec-p '(34359738368 1 "x"))
6728 would wrongly return t on a 64-bit host.
6729
6730 * dispnew.c (init_display): Use *_RANGE_OVERFLOW macros.
6731 The plain *_OVERFLOW macros run afoul of GCC bug 49705
6732 <http://gcc.gnu.org/bugzilla/show_bug.cgi?id=49705>
6733 and therefore cause GCC to emit a bogus diagnostic in some cases.
6734
6735 * image.c: Integer signedness and overflow and related fixes.
6736 This is not an exhaustive set of fixes, but it's time to
6737 record what I've got.
6738 (lookup_pixel_color, check_image_size): Remove redundant decls.
6739 (check_image_size): Don't assume that arbitrary EMACS_INT values
6740 fit in 'int', or that arbitrary 'double' values fit in 'int'.
6741 (x_alloc_image_color, x_create_x_image_and_pixmap, png_load)
6742 (tiff_load, imagemagick_load_image):
6743 Check for overflow in size calculations.
6744 (x_create_x_image_and_pixmap): Remove unnecessary test for
6745 xmalloc returning NULL; that can't happen.
6746 (xbm_read_bitmap_data): Don't assume sizes fit into 'int'.
6747 (xpm_color_bucket): Use better integer hashing function.
6748 (xpm_cache_color): Don't possibly over-allocate memory.
6749 (struct png_memory_storage, tiff_memory_source, tiff_seek_in_memory)
6750 (gif_memory_source):
6751 Use ptrdiff_t, not int or size_t, to record sizes.
6752 (png_load): Don't assume values greater than 2**31 fit in 'int'.
6753 (our_stdio_fill_input_buffer): Prefer ptrdiff_t to size_t when
6754 either works, as we prefer signed integers.
6755 (tiff_read_from_memory, tiff_write_from_memory):
6756 Return tsize_t, not size_t, since that's what the TIFF API wants.
6757 (tiff_read_from_memory): Don't fail simply because the read would
6758 go past EOF; instead, return a short read.
6759 (tiff_load): Omit no-longer-needed casts.
6760 (Fimagemagick_types): Don't assume size fits into 'int'.
6761
6762 Improve hashing quality when configured --with-wide-int.
6763 * fns.c (hash_string): New function, taken from sxhash_string.
6764 Do not discard information about ASCII character case; this
6765 discarding is no longer needed.
6766 (sxhash-string): Use it. Change sig to match it. Caller changed.
6767 * lisp.h: Declare it.
6768 * lread.c (hash_string): Remove, since we now use fns.c's version.
6769 The fns.c version returns a wider integer if --with-wide-int is
6770 specified, so this should help the quality of the hashing a bit.
6771
6772 * emacs.c: Integer overflow minor fix.
6773 (heap_bss_diff): Now uprintmax_t, not unsigned long. All used changed.
6774 Define only if GNU_LINUX.
6775 (main, Fdump_emacs): Set and use heap_bss_diff only if GNU_LINUX.
6776
6777 * dispnew.c: Integer signedness and overflow fixes.
6778 Remove unnecessary forward decls, that were a maintenance hassle.
6779 (history_tick): Now uprintmax_t, so it's more likely to avoid overflow.
6780 All uses changed.
6781 (adjust_glyph_matrix, realloc_glyph_pool, adjust_frame_message_buffer)
6782 (scrolling_window): Use ptrdiff_t, not int, for byte count.
6783 (prepare_desired_row, line_draw_cost):
6784 Use int, not unsigned, where either works.
6785 (save_current_matrix, restore_current_matrix):
6786 Use ptrdiff_t, not size_t, where either works.
6787 (init_display): Check for overflow more accurately, and without
6788 relying on undefined behavior.
6789
6790 * editfns.c (pWIDE, pWIDElen, signed_wide, unsigned_wide):
6791 Remove, replacing with the new symbols in lisp.h. All uses changed.
6792 * fileio.c (make_temp_name):
6793 * filelock.c (lock_file_1, lock_file):
6794 * xdisp.c (message_dolog):
6795 Don't assume PRIdMAX etc. works; this isn't portable to pre-C99 hosts.
6796 Use pMd etc. instead.
6797 * lisp.h (printmax_t, uprintmax_t, pMd, pMu): New types and macros,
6798 replacing the pWIDE etc. symbols removed from editfns.c.
6799
6800 * keyboard.h (num_input_events): Now uintmax_t.
6801 This is (very slightly) less likely to mess up due to wraparound.
6802 All uses changed.
6803
6804 * buffer.c: Integer signedness fixes.
6805 (alloc_buffer_text, enlarge_buffer_text):
6806 Use ptrdiff_t rather than size_t when either will do, as we prefer
6807 signed integers.
6808
6809 * alloc.c: Integer signedness and overflow fixes.
6810 Do not impose an arbitrary 32-bit limit on malloc sizes when debugging.
6811 (__malloc_size_t): Default to size_t, not to int.
6812 (pure_size, pure_bytes_used_before_overflow, stack_copy_size)
6813 (Fgarbage_collect, mark_object_loop_halt, mark_object):
6814 Prefer ptrdiff_t to size_t when either would do, as we prefer
6815 signed integers.
6816 (XMALLOC_OVERRUN_CHECK_OVERHEAD): New macro.
6817 (xmalloc_overrun_check_header, xmalloc_overrun_check_trailer):
6818 Now const. Initialize with values that are in range even if char
6819 is signed.
6820 (XMALLOC_PUT_SIZE, XMALLOC_GET_SIZE): Remove, replacing with ...
6821 (xmalloc_put_size, xmalloc_get_size): New functions. All uses changed.
6822 These functions do the right thing with sizes > 2**32.
6823 (check_depth): Now ptrdiff_t, not int.
6824 (overrun_check_malloc, overrun_check_realloc, overrun_check_free):
6825 Adjust to new way of storing sizes. Check for size overflow bugs
6826 in rest of code.
6827 (STRING_BYTES_MAX): Adjust to new overheads. The old code was
6828 slightly wrong anyway, as it missed one instance of
6829 XMALLOC_OVERRUN_CHECK_OVERHEAD.
6830 (refill_memory_reserve): Omit needless cast to size_t.
6831 (mark_object_loop_halt): Mark as externally visible.
6832
6833 * xselect.c: Integer signedness and overflow fixes.
6834 (Fx_register_dnd_atom, x_handle_dnd_message):
6835 Use ptrdiff_t, not size_t, since we prefer signed.
6836 (Fx_register_dnd_atom): Check for ptrdiff_t (and size_t) overflow.
6837 * xterm.h (struct x_display_info): Use ptrdiff_t, not size_t, for
6838 x_dnd_atoms_size and x_dnd_atoms_length.
6839
6840 * doprnt.c: Prefer signed to unsigned when either works.
6841 * eval.c (verror):
6842 * doprnt.c (doprnt):
6843 * lisp.h (doprnt):
6844 * xdisp.c (vmessage):
6845 Use ptrdiff_t, not size_t, when using or implementing doprnt,
6846 since the sizes cannot exceed ptrdiff_t bounds anyway, and we
6847 prefer signed arithmetic to avoid comparison confusion.
6848 * doprnt.c (doprnt): Avoid a "+ 1" that can't overflow,
6849 but is a bit tricky.
6850
6851 Assume freestanding C89 headers, string.h, stdlib.h.
6852 * data.c, doprnt.c, floatfns.c, print.c:
6853 Include float.h unconditionally.
6854 * gmalloc.c: Assume C89-at-least behavior for preprocessor,
6855 limits.h, stddef.h, string.h. Use memset instead of 'flood'.
6856 * regex.c: Likewise for stddef.h, string.h.
6857 (ISASCII): Remove; can assume it returns 1 now. All uses removed.
6858 * s/aix4-2.h (HAVE_STRING_H): Remove obsolete undef.
6859 * s/ms-w32.h (HAVE_LIMITS_H, HAVE_STRING_H, HAVE_STDLIB_H)
6860 (STDC_HEADERS): Remove obsolete defines.
6861 * sysdep.c: Include limits.h unconditionally.
6862
6863 Assume support for memcmp, memcpy, memmove, memset.
6864 * lisp.h, sysdep.c (memcmp, memcpy, memmove, memset):
6865 * regex.c (memcmp, memcpy):
6866 Remove; we assume C89 now.
6867
6868 * gmalloc.c (memcpy, memset, memmove): Remove; we assume C89 now.
6869 (__malloc_safe_bcopy): Remove; no longer needed.
6870
6871 * lisp.h (struct vectorlike_header, struct Lisp_Subr): Signed sizes.
6872 Use EMACS_INT, not EMACS_UINT, for sizes. The code works equally
6873 well either way, and we prefer signed to unsigned.
6874
6875 2011-07-27 Lars Magne Ingebrigtsen <larsi@gnus.org>
6876
6877 * gnutls.c (emacs_gnutls_read): Don't message anything if the peer
6878 closes the connection while we're reading (bug#9182).
6879
6880 2011-07-25 Jan Djärv <jan.h.d@swipnet.se>
6881
6882 * nsmenu.m (ns_popup_dialog): Add an "ok" button if no buttons
6883 are specified (Bug#9168).
6884
6885 2011-07-25 Paul Eggert <eggert@cs.ucla.edu>
6886
6887 * bidi.c (bidi_dump_cached_states): Fix printf format mismatch.
6888 Found by GCC static checking and --with-wide-int on a 32-bit host.
6889
6890 2011-07-25 Eli Zaretskii <eliz@gnu.org>
6891
6892 * xdisp.c (compute_display_string_pos): Fix logic of caching
6893 previous display string position. Initialize cached_prev_pos to
6894 -1. Fixes slow-down at the beginning of a buffer.
6895
6896 2011-07-24 Eli Zaretskii <eliz@gnu.org>
6897
6898 * xfaces.c (check_lface_attrs) [HAVE_WINDOW_SYSTEM]: Allow `nil'
6899 for attrs[LFACE_FONTSET_INDEX].
6900
6901 2011-07-23 Paul Eggert <eggert@cs.ucla.edu>
6902
6903 * xml.c (parse_region): Remove unused local
6904 that was recently introduced.
6905
6906 2011-07-23 Eli Zaretskii <eliz@gnu.org>
6907
6908 * xfns.c (unwind_create_frame) [GLYPH_DEBUG]: Adapt to changes in
6909 2008-02-22T17:42:09Z!monnier@iro.umontreal.ca.
6910
6911 * xdisp.c (move_it_in_display_line_to): Record the best matching
6912 position for TO_CHARPOS while scanning the line, and restore it on
6913 exit if none of the characters scanned was an exact match.
6914 Fixes vertical-motion and pos-visible-in-window-p under bidi redisplay
6915 when exact match is impossible due to invisible text, and the
6916 lines are truncated.
6917
6918 2011-07-23 Jan Djärv <jan.h.d@swipnet.se>
6919
6920 * nsterm.m (initFrameFromEmacs): Set NSTitledWindowMask in styleMask
6921 for OSX >= 10.7.
6922
6923 2011-07-22 Eli Zaretskii <eliz@gnu.org>
6924
6925 Fix a significant slow-down of cursor motion with C-n, C-p,
6926 C-f/C-b, and C-v/M-v that couldn't keep up with keyboard
6927 auto-repeat under bidi redisplay in fontified buffers.
6928 * xdisp.c (compute_stop_pos_backwards): New function.
6929 (next_element_from_buffer): Call compute_stop_pos_backwards to
6930 find a suitable prev_stop when we find ourselves before
6931 base_level_stop.
6932 (reseat): Don't look for prev_stop, as that could mean a very long
6933 run.
6934 <cached_disp_pos, cached_disp_buffer, cached_disp_modiff>
6935 <cached_disp_overlay_modiff>: Cache for last found display string
6936 position.
6937 (compute_display_string_pos): Return the cached position if asked
6938 about the same buffer in the same area of character positions, and
6939 the buffer wasn't changed since the time the display string
6940 position was cached.
6941
6942 2011-07-22 Eli Zaretskii <eliz@gnu.org>
6943
6944 * xdisp.c (rows_from_pos_range): Don't ignore glyphs whose object
6945 is an integer, which is important for empty lines. (Bug#9149)
6946
6947 2011-07-22 Chong Yidong <cyd@stupidchicken.com>
6948
6949 * frame.c (Fmodify_frame_parameters): In tty case, update the
6950 default face if necessary (Bug#4238).
6951
6952 2011-07-21 Chong Yidong <cyd@stupidchicken.com>
6953
6954 * editfns.c (Fstring_to_char): No need to explain what a character
6955 is in the docstring (Bug#6576).
6956
6957 2011-07-20 Lars Magne Ingebrigtsen <larsi@gnus.org>
6958
6959 * xml.c (parse_region): Make sure we always return a tree.
6960
6961 2011-07-20 HAMANO Kiyoto <khiker.mail@gmail.com>
6962
6963 * xml.c (parse_region): If a document contains only comments,
6964 return that, too.
6965
6966 2011-07-20 Lars Magne Ingebrigtsen <larsi@gnus.org>
6967
6968 * xml.c (make_dom): Return comments, too.
6969
6970 2011-07-19 Paul Eggert <eggert@cs.ucla.edu>
6971
6972 Port to OpenBSD.
6973 See http://lists.gnu.org/archive/html/emacs-devel/2011-07/msg00688.html
6974 and the surrounding thread.
6975 * minibuf.c (read_minibuf_noninteractive): Rewrite to use getchar
6976 rather than fgets, and retry after EINTR. Otherwise, 'emacs
6977 --batch -f byte-compile-file' fails on OpenBSD if an inactivity
6978 timer goes off.
6979 * s/openbsd.h (BROKEN_SIGIO): Define.
6980 * unexelf.c (unexec) [__OpenBSD__]:
6981 Don't update the .mdebug section of the Alpha COFF symbol table.
6982
6983 2011-07-19 Lars Magne Ingebrigtsen <larsi@gnus.org>
6984
6985 * lread.c (syms_of_lread): Clarify when `lexical-binding' is used
6986 (bug#8460).
6987
6988 2011-07-18 Paul Eggert <eggert@cs.ucla.edu>
6989
6990 * fileio.c (Fcopy_file) [!MSDOS]: Tighten created file's mask.
6991 This fixes some race conditions on the permissions of any newly
6992 created file.
6993
6994 * alloc.c (valid_pointer_p): Use pipe, not open.
6995 This fixes some permissions issues when debugging.
6996
6997 * fileio.c (Fcopy_file): Adjust mode if fchown fails. (Bug#9002)
6998 If fchown fails to set both uid and gid, try to set just gid,
6999 as that is sometimes allowed. Adjust the file's mode to eliminate
7000 setuid or setgid bits that are inappropriate if fchown fails.
7001
7002 2011-07-18 Stefan Monnier <monnier@iro.umontreal.ca>
7003
7004 * xdisp.c (next_element_from_string, next_element_from_buffer): Use EQ
7005 to compare Lisp_Objects.
7006 * gnutls.c (syms_of_gnutls): Rename Vgnutls_log_level to
7007 global_gnutls_log_level, don't mistake it for a Lisp_Object.
7008 (init_gnutls_functions, emacs_gnutls_handle_error): Fix up uses.
7009
7010 2011-07-17 Andreas Schwab <schwab@linux-m68k.org>
7011
7012 * lread.c (read_integer): Unread even EOF character.
7013 (read1): Likewise. Properly record start position of symbol.
7014
7015 * lread.c (read1): Read `#:' as empty uninterned symbol if no
7016 symbol character follows.
7017
7018 2011-07-17 Paul Eggert <eggert@cs.ucla.edu>
7019
7020 * fileio.c (Fcopy_file): Pacify gcc re fchown. (Bug#9002)
7021 This works around a problem with the previous change to Fcopy_file.
7022 Recent glibc declares fchown with __attribute__((warn_unused_result)),
7023 and without this change, GCC might complain about discarding
7024 fchown's return value.
7025
7026 2011-07-16 Juanma Barranquero <lekktu@gmail.com>
7027
7028 * makefile.w32-in (GLOBAL_SOURCES): Add gnutls.c (followup to bug#9059).
7029
7030 2011-07-16 Paul Eggert <eggert@cs.ucla.edu>
7031
7032 * fileio.c (Fcopy_file): Don't diagnose fchown failures. (Bug#9002)
7033
7034 2011-07-16 Lars Magne Ingebrigtsen <larsi@gnus.org>
7035
7036 * gnutls.c (syms_of_gnutls): Define `gnutls-log-level' here, since
7037 it's used from the C level.
7038
7039 * process.c: Use the same condition for POLL_FOR_INPUT in both
7040 keyboard.c and process.c (bug#1858).
7041
7042 2011-07-09 Lawrence Mitchell <wence@gmx.li>
7043
7044 * gnutls.c (Qgnutls_bootprop_min_prime_bits): New variable.
7045 (Fgnutls_boot): Use it.
7046
7047 2011-07-15 Andreas Schwab <schwab@linux-m68k.org>
7048
7049 * doc.c (Fsubstitute_command_keys): Revert last change.
7050
7051 2011-07-15 Lars Magne Ingebrigtsen <larsi@gnus.org>
7052
7053 * doc.c (Fsubstitute_command_keys): Clarify that \= really only
7054 quotes the next character, and doesn't affect other longer
7055 sequences (bug#8935).
7056
7057 * lread.c (syms_of_lread): Clarify that is isn't only
7058 `eval-buffer' and `eval-defun' that's affected by
7059 `lexical-binding' (bug#8460).
7060
7061 2011-07-15 Eli Zaretskii <eliz@gnu.org>
7062
7063 * xdisp.c (move_it_in_display_line_to): Fix vertical motion with
7064 bidi redisplay when a line includes both an image and is truncated.
7065
7066 2011-07-14 Paul Eggert <eggert@cs.ucla.edu>
7067
7068 Fix minor problems found by static checking.
7069 * bidi.c (bidi_cache_size): Now EMACS_INT, not size_t.
7070 (elsz): Now a signed constant, not a size_t var. We prefer signed
7071 types to unsigned, to avoid integer comparison confusion. Without
7072 this change, GCC 4.6.1 with -Wunsafe-loop-optimizations complains
7073 "cannot optimize loop, the loop counter may overflow", a symptom
7074 of the confusion.
7075 * indent.c (Fvertical_motion): Mark locals as initialized.
7076 * xdisp.c (reseat_to_string): Fix pointer signedness issue.
7077
7078 2011-07-14 Lars Magne Ingebrigtsen <larsi@gnus.org>
7079
7080 * search.c (Fre_search_backward): Mention `case-fold-search' in
7081 all the re_search_* functions (bug#8138).
7082
7083 * keyboard.c (Fopen_dribble_file): Document when the file is
7084 closed (bug#8056).
7085
7086 2011-07-14 Eli Zaretskii <eliz@gnu.org>
7087
7088 * bidi.c (bidi_dump_cached_states): Fix format of displaying
7089 bidi_cache_idx.
7090
7091 Support bidi reordering of display and overlay strings.
7092 * xdisp.c (compute_display_string_pos)
7093 (compute_display_string_end): Accept additional argument STRING.
7094 (init_iterator, reseat_1): Initialize bidi_it->string.s to NULL.
7095 (reseat_to_string): Initialize bidi_it->string.s and
7096 bidi_it->string.schars.
7097 (Fcurrent_bidi_paragraph_direction): Initialize itb.string.s to
7098 NULL (avoids a crash in bidi_paragraph_init).
7099 Initialize itb.string.lstring.
7100 (init_iterator): Call bidi_init_it only of a valid
7101 buffer position was specified. Initialize paragraph_embedding to
7102 L2R.
7103 (reseat_to_string): Initialize the bidi iterator.
7104 (display_string): If we need to ignore text properties of
7105 LISP_STRING, set IT->stop_charpos to IT->end_charpos. (The
7106 original value of -1 will not work with bidi.)
7107 (compute_display_string_pos): First arg is now struct
7108 `text_pos *'; all callers changed. Support display properties on
7109 Lisp strings.
7110 (compute_display_string_end): Support display properties on Lisp
7111 strings.
7112 (init_iterator, reseat_1, reseat_to_string): Initialize the
7113 string.bufpos member to 0 (zero, for compatibility with IT_CHARPOS
7114 when iterating on a string not from display properties).
7115 (compute_display_string_pos, compute_display_string_end):
7116 Fix calculation of the object to scan. Fixes an error when using
7117 arrow keys.
7118 (next_element_from_buffer): Don't abort when IT_CHARPOS is before
7119 base_level_stop; instead, set base_level_stop to BEGV.
7120 Fixes crashes in vertical-motion.
7121 (next_element_from_buffer): Improve commentary for when
7122 the iterator is before prev_stop.
7123 (init_iterator): Initialize bidi_p from the default value of
7124 bidi-display-reordering, not from buffer-local value. Use the
7125 buffer-local value only if initializing for buffer iteration.
7126 (handle_invisible_prop): Support invisible properties on strings
7127 that are being bidi-reordered.
7128 (set_iterator_to_next): Support bidi reordering of C strings and
7129 Lisp strings.
7130 (next_element_from_string): Support bidi reordering of Lisp
7131 strings.
7132 (handle_stop_backwards): Support Lisp strings as well.
7133 (display_string): Support display of R2L glyph rows.
7134 Use IT_STRING_CHARPOS when displaying from a Lisp string.
7135 (init_iterator): Don't initialize it->bidi_p for strings
7136 here.
7137 (reseat_to_string): Initialize it->bidi_p for strings here.
7138 (next_element_from_string, next_element_from_c_string)
7139 (next_element_from_buffer): Add xassert's for correspondence
7140 between IT's object being iterated and it->bidi_it.string
7141 structure.
7142 (face_before_or_after_it_pos): Support bidi iteration.
7143 (next_element_from_c_string): Handle the case of the first string
7144 character that is not the first one in the visual order.
7145 (get_visually_first_element): New function, refactored from common
7146 parts of next_element_from_buffer, next_element_from_string, and
7147 next_element_from_c_string.
7148 (tool_bar_lines_needed, redisplay_tool_bar)
7149 (display_menu_bar): Force left-to-right direction. Add a FIXME
7150 comment for making that be controlled by a user option.
7151 (push_it, pop_it): Save and restore the state of the
7152 bidi iterator. Save and restore the bidi_p flag.
7153 (pop_it): Iterate out of display property for string iteration as
7154 well.
7155 (iterate_out_of_display_property): Support iteration over strings.
7156 (handle_single_display_spec): Set up it->bidi_it for iteration
7157 over a display string, and call bidi_init_it.
7158 (handle_single_display_spec, next_overlay_string)
7159 (get_overlay_strings_1, push_display_prop): Set up the bidi
7160 iterator for displaying display or overlay strings.
7161 (forward_to_next_line_start): Don't use the shortcut if
7162 bidi-iterating.
7163 (back_to_previous_visible_line_start): If handle_display_prop
7164 pushed the iterator stack, restore the internal state of the bidi
7165 iterator by calling bidi_pop_it same number of times.
7166 (reseat_at_next_visible_line_start): If ON_NEWLINE_P is non-zero,
7167 and we are bidi-iterating, don't decrement the iterator position;
7168 instead, set the first_elt flag in the bidi iterator, to produce
7169 the same effect.
7170 (reseat_1): Remove redundant setting of string_from_display_prop_p.
7171 (push_display_prop): xassert that we are iterating a buffer.
7172 (push_it, pop_it): Save and restore paragraph_embedding member.
7173 (handle_single_display_spec, next_overlay_string)
7174 (get_overlay_strings_1, reseat_1, reseat_to_string)
7175 (push_display_prop): Set up the `unibyte' member of bidi_it.string
7176 correctly. Don't assume unibyte strings are not bidi-reordered.
7177 (compute_display_string_pos)
7178 (compute_display_string_end): Fix handling the case of C string.
7179 (push_it, pop_it): Save and restore from_disp_prop_p.
7180 (handle_single_display_spec, push_display_prop): Set the
7181 from_disp_prop_p flag.
7182 (get_overlay_strings_1): Reset the from_disp_prop_p flag.
7183 (pop_it): Call iterate_out_of_display_property only if we are
7184 popping after iteration over a string that came from a display
7185 property. Fix a typo in popping stretch info. Add an assertion
7186 for verifying that the iterator position is in sync with the bidi
7187 iterator.
7188 (handle_single_display_spec, get_overlay_strings_1)
7189 (push_display_prop): Fix initialization of paragraph direction for
7190 string when that of the parent object is not yet determined.
7191 (reseat_1): Call bidi_init_it to resync the bidi
7192 iterator with IT's position. (Bug#7616)
7193 (find_row_edges): If ROW->start.pos gives position
7194 smaller than min_pos, use it as ROW->minpos. (Bug#7616)
7195 (handle_stop, back_to_previous_visible_line_start, reseat_1):
7196 Reset the from_disp_prop_p flag.
7197 (SAVE_IT, RESTORE_IT): New macros.
7198 (pos_visible_p, face_before_or_after_it_pos)
7199 (back_to_previous_visible_line_start)
7200 (move_it_in_display_line_to, move_it_in_display_line)
7201 (move_it_to, move_it_vertically_backward, move_it_by_lines)
7202 (try_scrolling, redisplay_window, display_line): Use them when
7203 saving a temporary copy of the iterator and restoring it back.
7204 (back_to_previous_visible_line_start, reseat_1)
7205 (init_iterator): Empty the bidi cache "stack".
7206 (move_it_in_display_line_to): If iterator ended up at
7207 EOL, but we never saw any buffer positions smaller than
7208 to_charpos, return MOVE_POS_MATCH_OR_ZV. Fixes vertical cursor
7209 motion in bidi-reordered lines.
7210 (move_it_in_display_line_to): Record prev_method and prev_pos
7211 immediately before the call to set_iterator_to_next. Fixes cursor
7212 motion in bidi-reordered lines with stretch glyphs and strings
7213 displayed in margins. (Bug#8133) (Bug#8867)
7214 Return MOVE_POS_MATCH_OR_ZV only if iterator position is past
7215 TO_CHARPOS.
7216 (pos_visible_p): Support positions in bidi-reordered lines.
7217 Save and restore bidi cache.
7218
7219 * bidi.c (bidi_level_of_next_char): clen should be EMACS_NT, not int.
7220 (bidi_paragraph_info): Delete unused struct.
7221 (bidi_cache_idx, bidi_cache_last_idx): Declare EMACS_INT.
7222 (bidi_cache_start): New variable.
7223 (bidi_cache_reset): Reset bidi_cache_idx to bidi_cache_start, not
7224 to zero.
7225 (bidi_cache_fetch_state, bidi_cache_search)
7226 (bidi_cache_find_level_change, bidi_cache_iterator_state)
7227 (bidi_cache_find, bidi_peek_at_next_level)
7228 (bidi_level_of_next_char, bidi_find_other_level_edge)
7229 (bidi_move_to_visually_next): Compare cache index with
7230 bidi_cache_start rather than with zero.
7231 (bidi_fetch_char): Accept new argument STRING; all callers
7232 changed. Support iteration over a string. Support strings with
7233 display properties. Support unibyte strings. Fix the type of
7234 `len' according to what STRING_CHAR_AND_LENGTH expects.
7235 (bidi_paragraph_init, bidi_resolve_explicit_1)
7236 (bidi_resolve_explicit, bidi_resolve_weak)
7237 (bidi_level_of_next_char, bidi_move_to_visually_next):
7238 Support iteration over a string.
7239 (bidi_set_sor_type, bidi_resolve_explicit_1)
7240 (bidi_resolve_explicit, bidi_type_of_next_char): ignore_bn_limit
7241 can now be zero (for strings); special values 0 and -1 were
7242 changed to -1 and -2, respectively.
7243 (bidi_char_at_pos): New function.
7244 (bidi_paragraph_init, bidi_resolve_explicit, bidi_resolve_weak):
7245 Call it instead of FETCH_MULTIBYTE_CHAR.
7246 (bidi_move_to_visually_next): Abort if charpos or bytepos were not
7247 initialized to valid values.
7248 (bidi_init_it): Don't initialize charpos and bytepos with invalid
7249 values.
7250 (bidi_level_of_next_char): Allow the sentinel "position" to pass
7251 the test for valid cached positions. Fix the logic for looking up
7252 the sentinel state in the cache. GCPRO the Lisp string we are
7253 iterating.
7254 (bidi_push_it, bidi_pop_it): New functions.
7255 (bidi_initialize): Initialize the bidi cache start stack pointer.
7256 (bidi_cache_ensure_space): New function, refactored from part of
7257 bidi_cache_iterator_state. Don't assume the required size is just
7258 one BIDI_CACHE_CHUNK away.
7259 (bidi_cache_start_stack, bidi_push_it): Use IT_STACK_SIZE.
7260 (bidi_count_bytes, bidi_char_at_pos): New functions.
7261 (bidi_cache_search): Don't assume bidi_cache_last_idx is
7262 always valid if bidi_cache_idx is valid.
7263 (bidi_cache_find_level_change): xassert that bidi_cache_last_idx
7264 is valid if it's going to be used.
7265 (bidi_shelve_cache, bidi_unshelve_cache): New functions.
7266 (bidi_cache_fetch_state, bidi_cache_search)
7267 (bidi_cache_find_level_change, bidi_cache_ensure_space)
7268 (bidi_cache_iterator_state, bidi_cache_find)
7269 (bidi_find_other_level_edge, bidi_cache_start_stack):
7270 All variables related to cache indices are now EMACS_INT.
7271
7272 * dispextern.h (struct bidi_string_data): New structure.
7273 (struct bidi_it): New member `string'. Make flag members be 1-bit
7274 fields, and put them last in the struct.
7275 (compute_display_string_pos, compute_display_string_end):
7276 Update prototypes.
7277 (bidi_push_it, bidi_pop_it): Add prototypes.
7278 (struct iterator_stack_entry): New members bidi_p,
7279 paragraph_embedding, and from_disp_prop_p.
7280 (struct it): Member bidi_p is now a bit field 1 bit wide.
7281 (bidi_shelve_cache, bidi_unshelve_cache):
7282 Declare prototypes.
7283
7284 * .gdbinit (xvectype, xvector, xcompiled, xchartable, xboolvector)
7285 (xpr, xfont, xbacktrace): Use "header.size" when accessing vectors
7286 and vector-like objects.
7287
7288 * dispnew.c (buffer_posn_from_coords): Save and restore the bidi
7289 cache around display iteration.
7290
7291 * window.c (Fwindow_end, window_scroll_pixel_based)
7292 (displayed_window_lines, Frecenter): Save and restore the bidi
7293 cache around display iteration.
7294
7295 2011-07-14 Lars Magne Ingebrigtsen <larsi@gnus.org>
7296
7297 * editfns.c (Fdelete_region): Clarify the use of the named
7298 parameters (bug#6788).
7299
7300 2011-07-14 Martin Rudalics <rudalics@gmx.at>
7301
7302 * indent.c (Fvertical_motion): Set and restore w->pointm when
7303 saving and restoring the window's buffer (Bug#9006).
7304
7305 2011-07-13 Lars Magne Ingebrigtsen <larsi@gnus.org>
7306
7307 * editfns.c (Fstring_to_char): Clarify just what is returned
7308 (bug#6576). Text by Eli Zaretskii.
7309
7310 2011-07-13 Juanma Barranquero <lekktu@gmail.com>
7311
7312 * gnutls.c (init_gnutls_functions): Honor gnutls_log_level (bug#9059).
7313
7314 2011-07-13 Eli Zaretskii <eliz@gnu.org>
7315
7316 * buffer.c (mmap_find): Fix a typo.
7317
7318 2011-07-13 Johan Bockgård <bojohan@gnu.org>
7319
7320 Fix execution of x selection hooks.
7321 * xselect.c (Qx_lost_selection_functions)
7322 (Qx_sent_selection_functions): New vars.
7323 (syms_of_xselect): DEFSYM them.
7324 (x_handle_selection_request): Pass Qx_sent_selection_functions
7325 rather than Vx_sent_selection_functions to Frun_hook_with_args.
7326 (x_handle_selection_clear,x_clear_frame_selections):
7327 Pass Qx_lost_selection_functions rather than
7328 Vx_lost_selection_functions to Frun_hook_with_args.
7329
7330 2011-07-13 Paul Eggert <eggert@cs.ucla.edu>
7331
7332 * buffer.c (Fget_buffer_create): Initialize inhibit_shrinking.
7333 The old code sometimes used this field without initializing it.
7334
7335 * alloc.c (gc_sweep): Don't read past end of array.
7336 In theory, the old code could also have corrupted Emacs internals,
7337 though it'd be very unlikely.
7338
7339 2011-07-12 Andreas Schwab <schwab@linux-m68k.org>
7340
7341 * character.c (Fcharacterp): Don't advertise optional ignored
7342 argument. (Bug#4026)
7343
7344 2011-07-12 Lars Magne Ingebrigtsen <larsi@gnus.org>
7345
7346 * keymap.c (syms_of_keymap): Clarify that "modifier" is "modifier
7347 key" (bug#4257).
7348
7349 * window.c (Fset_window_start): Doc fix (bug#4199).
7350 (Fset_window_hscroll): Ditto.
7351
7352 2011-07-12 Paul Eggert <eggert@cs.ucla.edu>
7353
7354 Fix minor new problems caught by GCC 4.6.1.
7355 * term.c (init_tty): Remove unused local.
7356 * xsettings.c (store_monospaced_changed): Define this function only
7357 if (defined HAVE_GSETTINGS || defined HAVE_GCONF), as it's
7358 not used otherwise.
7359
7360 2011-07-12 Chong Yidong <cyd@stupidchicken.com>
7361
7362 * xdisp.c (Vresize_mini_windows): Minor doc fix (Bug#3300).
7363
7364 2011-07-11 Lars Magne Ingebrigtsen <larsi@gnus.org>
7365
7366 * xdisp.c (syms_of_xdisp): Make it explicit that the mini-windows
7367 are the mini-buffer and the echo area (bug#3320).
7368
7369 * term.c (init_tty): Remove support for supdup, c10 and perq
7370 terminals, which are no longer supported (bug#1482).
7371
7372 2011-07-10 Johan Bockgård <bojohan@gnu.org>
7373
7374 * xdisp.c (Ftool_bar_lines_needed): Fix WINDOWP check.
7375
7376 2011-07-10 Jan Djärv <jan.h.d@swipnet.se>
7377
7378 * xmenu.c (menu_highlight_callback): Only pass frame to show_help_event
7379 for non-popups (Bug#3642).
7380
7381 2011-07-10 Andreas Schwab <schwab@linux-m68k.org>
7382
7383 * alloc.c (reset_malloc_hooks): Protoize.
7384 * buffer.c (mmap_init, mmap_find, mmap_free_1, mmap_enlarge)
7385 (mmap_set_vars, mmap_alloc, mmap_free, mmap_realloc): Likewise.
7386 * cm.c (losecursor): Likewise.
7387 * data.c (fmod): Likewise.
7388 * dispnew.c (swap_glyphs_in_rows): Likewise.
7389 * emacs.c (memory_warning_signal): Likewise.
7390 * floatfns.c (float_error): Likewise.
7391 * font.c (check_gstring, check_otf_features, otf_tag_symbol)
7392 (otf_open, font_otf_capability, generate_otf_features)
7393 (font_otf_DeviceTable, font_otf_ValueRecord, font_otf_Anchor):
7394 Likewise.
7395 * image.c (pbm_read_file): Likewise.
7396 * indent.c (string_display_width): Likewise.
7397 * intervals.c (check_for_interval, search_for_interval)
7398 (inc_interval_count, count_intervals, root_interval)
7399 (adjust_intervals_for_insertion, make_new_interval): Likewise.
7400 * lread.c (defalias): Likewise.
7401 * ralloc.c (r_alloc_check): Likewise.
7402 * regex.c (set_image_of_range_1, set_image_of_range)
7403 (regex_grow_registers): Likewise.
7404 * sysdep.c (strerror): Likewise.
7405 * termcap.c (valid_filename_p, tprint, main): Likewise.
7406 * tparam.c (main): Likewise.
7407 * unexhp9k800.c (run_time_remap, save_data_space)
7408 (update_file_ptrs, read_header, write_header, calculate_checksum)
7409 (copy_file, copy_rest, display_header): Likewise.
7410 * widget.c (mark_shell_size_user_specified, create_frame_gcs):
7411 Likewise.
7412 * xdisp.c (check_it): Likewise.
7413 * xfaces.c (register_color, unregister_color, unregister_colors):
7414 Likewise.
7415 * xfns.c (print_fontset_result): Likewise.
7416 * xrdb.c (member, fatal, main): Likewise.
7417
7418 2011-07-10 Paul Eggert <eggert@cs.ucla.edu>
7419
7420 Fix minor problems found by static checking (Bug#9031).
7421 * chartab.c (char_table_set_range, map_sub_char_table):
7422 Remove unused locals.
7423 (uniprop_table): Now static.
7424 * composite.c (_work_char): Remove unused static var.
7425
7426 2011-07-09 Juanma Barranquero <lekktu@gmail.com>
7427
7428 * chartab.c (uniprop_table_uncompress): Remove unused local variable.
7429
7430 2011-07-09 Jan Djärv <jan.h.d@swipnet.se>
7431
7432 * gtkutil.c (qttip_cb): Remove code without function.
7433
7434 2011-07-09 Eli Zaretskii <eliz@gnu.org>
7435
7436 * w32.c (pthread_sigmask): New stub.
7437
7438 2011-07-08 Paul Eggert <eggert@cs.ucla.edu>
7439
7440 Use pthread_sigmask, not sigprocmask (Bug#9010).
7441 sigprocmask is portable only for single-threaded applications, and
7442 Emacs can be multi-threaded when it uses GTK.
7443 * Makefile.in (LIB_PTHREAD_SIGMASK): New macro.
7444 (LIBES): Use it.
7445 * callproc.c (Fcall_process):
7446 * process.c (create_process):
7447 * sysdep.c (sys_sigblock, sys_sigunblock, sys_sigsetmask):
7448 Use pthread_sigmask, not sigprocmask.
7449
7450 2011-07-08 Jan Djärv <jan.h.d@swipnet.se>
7451
7452 * gtkutil.c (qttip_cb): Set line wrap to FALSE for tooltip widget.
7453 (xg_prepare_tooltip): Revert text in x->ttip_lbl, margins was
7454 wrong (Bug#8591).
7455
7456 2011-07-08 Jan Djärv <jan.h.d@swipnet.se>
7457
7458 * gtkutil.c (xg_prepare_tooltip): Fix indentation and comment.
7459 Put text in x->ttip_lbl instead of gtk_tooltip_set_text (Bug#8591).
7460 (xg_hide_tooltip): Fix comment.
7461
7462 * nsterm.m (initFrameFromEmacs): Don't use ns_return_types
7463 in registerServicesMenuSendTypes.
7464 (validRequestorForSendType): Don't check ns_return_types.
7465
7466 * nsfns.m (Fx_open_connection): Put NSStringPboardType into
7467 ns_return_type.
7468
7469 2011-07-08 Jason Rumney <jasonr@gnu.org>
7470
7471 * w32term.c (x_make_frame_visible): Use SH_SHOWNORMAL rather than
7472 SH_SHOW for hidden windows (Bug#5482).
7473
7474 * w32fns.c (w32_wnd_proc) [WM_TIMER, WM_SET_CURSOR]: Avoid using
7475 frame struct members of non-existent frames (Bug#6284).
7476
7477 2011-07-08 Jan Djärv <jan.h.d@swipnet.se>
7478
7479 * nsterm.m (keyDown): Call to wantsToDelayTextChangeNotifications and
7480 variable firstTime not needed on OSX >= 10.6.
7481 (setPosition): setFloatValue:knobProportion: is deprecated on OSX
7482 >= 10.5. Use setKnobProportion, setDoubleValue.
7483
7484 * nsterm.h (MAC_OS_X_VERSION_10_3, MAC_OS_X_VERSION_10_4)
7485 (MAC_OS_X_VERSION_10_5): Define if not defined.
7486 (EmacsView, EmacsTooltip): Implements NSWindowDelegate on OSX >= 10.6.
7487 (EmacsMenu): Implements NSMenuDelegate on OSX >= 10.6.
7488 (EmacsToolbar): Implements NSToolbarDelegate on OSX >= 10.6.
7489
7490 * nsselect.m (ns_string_from_pasteboard): Don't use deprecated methods
7491 cString and lossyCString on OSX >= 10.4
7492
7493 * nsmenu.m (fillWithWidgetValue): Don't use deprecated method
7494 sizeToFit on OSX >= 10.2.
7495
7496 * nsimage.m (allocInitFromFile): Don't use deprecated method
7497 bestRepresentationForDevice on OSX >= 10.6.
7498
7499 * nsfns.m (check_ns_display_info): Cast to long and use %ld in error
7500 to avoid warning.
7501
7502 * emacs.c: Declare unexec_init_emacs_zone.
7503
7504 * nsgui.h: Fix compiler warning about gnulib redefining verify.
7505
7506 * nsselect.m (ns_get_local_selection): Change to extern (Bug#8842).
7507
7508 * nsmenu.m (ns_update_menubar): Remove useless setDelegate call
7509 on svcsMenu (Bug#8842).
7510
7511 * nsfns.m (Fx_open_connection): Remove NSStringPboardType from
7512 ns_return_types.
7513 (Fns_list_services): Just return Qnil on 10.6, code not working there.
7514
7515 * nsterm.m (QUTF8_STRING): Declare.
7516 (initFrameFromEmacs): Call registerServicesMenuSendTypes.
7517 (validRequestorForSendType): Return type is (id).
7518 Change indexOfObjectIdenticalTo to indexOfObject.
7519 Check if we have local selection before returning self (Bug#8842).
7520 (writeSelectionToPasteboard): Put local selection into paste board
7521 if we have a local selection (Bug#8842).
7522 (syms_of_nsterm): DEFSYM QUTF8_STRING.
7523
7524 * nsterm.h (MAC_OS_X_VERSION_10_6): Define here instead of nsterm.m.
7525 (ns_get_local_selection): Declare.
7526
7527 2011-07-07 Lars Magne Ingebrigtsen <larsi@gnus.org>
7528
7529 * keymap.c (describe_map_tree): Don't insert a double newline at
7530 the end of the buffer (bug#1169) and return whether we inserted
7531 something.
7532
7533 * callint.c (Fcall_interactively): Change "reading args" to
7534 "providing args" to try to clarify what it does (bug#1010).
7535
7536 2011-07-07 Kenichi Handa <handa@m17n.org>
7537
7538 * composite.c (composition_compute_stop_pos): Ignore a static
7539 composition starting before CHARPOS (Bug#8915).
7540
7541 * xdisp.c (handle_composition_prop): Likewise.
7542
7543 2011-07-07 Eli Zaretskii <eliz@gnu.org>
7544
7545 * term.c (produce_glyphs) <xassert>: Allow IT_GLYPHLESS in it->what.
7546 (Bug#9015)
7547
7548 2011-07-07 Kenichi Handa <handa@m17n.org>
7549
7550 * character.h (unicode_category_t): New enum type.
7551
7552 * chartab.c (uniprop_decoder_t, uniprop_encoder_t): New types.
7553 (Qchar_code_property_table): New variable.
7554 (UNIPROP_TABLE_P, UNIPROP_GET_DECODER)
7555 (UNIPROP_COMPRESSED_FORM_P): New macros.
7556 (char_table_ascii): Uncompress the compressed values.
7557 (sub_char_table_ref): New arg is_uniprop. Callers changed.
7558 Uncompress the compressed values.
7559 (sub_char_table_ref_and_range): Likewise.
7560 (char_table_ref_and_range): Uncompress the compressed values.
7561 (sub_char_table_set): New arg is_uniprop. Callers changed.
7562 Uncompress the compressed values.
7563 (sub_char_table_set_range): Args changed. Callers changed.
7564 (char_table_set_range): Adjuted for the above change.
7565 (map_sub_char_table): Delete args default_val and parent. Add arg
7566 top. Give decoded values to a Lisp function.
7567 (map_char_table): Adjust for the above change. Give decoded
7568 values to a Lisp function. Gcpro more variables.
7569 (uniprop_table_uncompress)
7570 (uniprop_decode_value_run_length): New functions.
7571 (uniprop_decoder, uniprop_decoder_count): New variables.
7572 (uniprop_get_decoder, uniprop_encode_value_character)
7573 (uniprop_encode_value_run_length, uniprop_encode_value_numeric):
7574 New functions.
7575 (uniprop_encoder, uniprop_encoder_count): New variables.
7576 (uniprop_get_encoder, uniprop_table)
7577 (Funicode_property_table_internal, Fget_unicode_property_internal)
7578 (Fput_unicode_property_internal): New functions.
7579 (syms_of_chartab): DEFSYM Qchar_code_property_table, defsubr
7580 Sunicode_property_table_internal, Sget_unicode_property_internal,
7581 and Sput_unicode_property_internal. Defvar_lisp
7582 char-code-property-alist.
7583
7584 * composite.c (CHAR_COMPOSABLE_P): Adjust for the change of
7585 Vunicode_category_table.
7586
7587 * font.c (font_range): Adjust for the change of
7588 Vunicode_category_table.
7589
7590 2011-07-07 Dan Nicolaescu <dann@ics.uci.edu>
7591
7592 * m/iris4d.h: Remove file, move contents ...
7593 * s/irix6-5.h: ... here.
7594
7595 2011-07-06 Paul Eggert <eggert@cs.ucla.edu>
7596
7597 Remove unportable assumption about struct layout (Bug#8884).
7598 * alloc.c (mark_buffer):
7599 * buffer.c (reset_buffer_local_variables, Fbuffer_local_variables)
7600 (clone_per_buffer_values): Don't assume that
7601 sizeof (struct buffer) is a multiple of sizeof (Lisp_Object).
7602 This isn't true in general, and it's particularly not true
7603 if Emacs is configured with --with-wide-int.
7604 * buffer.h (FIRST_FIELD_PER_BUFFER, LAST_FIELD_PER_BUFFER):
7605 New macros, used in the buffer.c change.
7606
7607 2011-07-05 Jan Djärv <jan.h.d@swipnet.se>
7608
7609 * xsettings.c: Use both GConf and GSettings if both are available.
7610 (store_config_changed_event): Add comment.
7611 (dpyinfo_valid, store_font_name_changed, map_tool_bar_style)
7612 (store_tool_bar_style_changed): New functions.
7613 (store_monospaced_changed): Add comment. Call dpyinfo_valid.
7614 (struct xsettings): Move font inside HAVE_XFT.
7615 (GSETTINGS_TOOL_BAR_STYLE, GSETTINGS_FONT_NAME): New defines.
7616 (GSETTINGS_MONO_FONT): Rename from SYSTEM_MONO_FONT.
7617 Move inside HAVE_XFT.
7618 (something_changed_gsettingsCB): Rename from something_changedCB.
7619 Check for changes in GSETTINGS_TOOL_BAR_STYLE and GSETTINGS_FONT_NAME
7620 also.
7621 (GCONF_TOOL_BAR_STYLE, GCONF_FONT_NAME): New defines.
7622 (GCONF_MONO_FONT): Rename from SYSTEM_MONO_FONT. Move inside HAVE_XFT.
7623 (something_changed_gconfCB): Rename from something_changedCB.
7624 Check for changes in GCONF_TOOL_BAR_STYLE and GCONF_FONT_NAME also.
7625 (parse_settings): Move check for font inside HAVE_XFT.
7626 (read_settings, apply_xft_settings): Add comment.
7627 (read_and_apply_settings): Add comment. Call map_tool_bar_style and
7628 store_tool_bar_style_changed. Move check for font inside HAVE_XFT and
7629 call store_font_name_changed.
7630 (xft_settings_event): Add comment.
7631 (init_gsettings): Add comment. Get values for GSETTINGS_TOOL_BAR_STYLE
7632 and GSETTINGS_FONT_NAME. Move check for fonts within HAVE_XFT.
7633 (init_gconf): Add comment. Get values for GCONF_TOOL_BAR_STYLE
7634 and GCONF_FONT_NAME. Move check for fonts within HAVE_XFT.
7635 (xsettings_initialize): Call init_gsettings last.
7636 (xsettings_get_system_font, xsettings_get_system_normal_font):
7637 Add comment.
7638
7639 2011-07-05 Paul Eggert <eggert@cs.ucla.edu>
7640
7641 Random fixes. E.g., (random) never returned negative values.
7642 * fns.c (Frandom): Use GET_EMACS_TIME for random seed, and add the
7643 subseconds part to the entropy, as that's a bit more random.
7644 Prefer signed to unsigned, since the signedness doesn't matter and
7645 in general we prefer signed. When given a limit, use a
7646 denominator equal to INTMASK + 1, not to VALMASK + 1, because the
7647 latter isn't right if USE_2_TAGS_FOR_INTS.
7648 * sysdep.c (get_random): Return a value in the range 0..INTMASK,
7649 not 0..VALMASK. Don't discard "excess" bits that random () returns.
7650
7651 2011-07-04 Stefan Monnier <monnier@iro.umontreal.ca>
7652
7653 * textprop.c (text_property_stickiness):
7654 Obey Vtext_property_default_nonsticky.
7655 (syms_of_textprop): Add `display' to Vtext_property_default_nonsticky.
7656 * w32fns.c (syms_of_w32fns):
7657 * xfns.c (syms_of_xfns): Don't Add `display' since it's there by default.
7658
7659 2011-07-04 Paul Eggert <eggert@cs.ucla.edu>
7660
7661 * fileio.c (barf_or_query_if_file_exists): Use S_ISDIR.
7662 This is more efficient than Ffile_directory_p and avoids a minor race.
7663
7664 2011-07-04 Lars Magne Ingebrigtsen <larsi@gnus.org>
7665
7666 * buffer.c (Foverlay_put): Say what the return value is
7667 (bug#7835).
7668
7669 * fileio.c (barf_or_query_if_file_exists): Check first if the file
7670 is a directory before asking whether to use the file name
7671 (bug#7564).
7672 (barf_or_query_if_file_exists): Make the "File is a directory"
7673 error be more correct.
7674
7675 * fns.c (Frequire): Remove the mention of the .gz files, since
7676 that's installation-specific, but keep the mention of
7677 `get-load-suffixes'.
7678
7679 2011-07-04 Paul Eggert <eggert@cs.ucla.edu>
7680
7681 * editfns.c (Fformat_time_string): Don't assume strlen fits in int.
7682 Report string overflow if the output is too long.
7683
7684 2011-07-04 Juanma Barranquero <lekktu@gmail.com>
7685
7686 * gnutls.c (Fgnutls_boot): Don't mention :verify-error.
7687 (syms_of_gnutls): Remove duplicate DEFSYM for
7688 Qgnutls_bootprop_verify_hostname_error, an error for
7689 Qgnutls_bootprop_verify_error (which is no longer used).
7690
7691 * eval.c (find_handler_clause): Remove parameters `sig' and `data',
7692 unused since 2011-01-26T20:02:07Z!monnier@iro.umontreal.ca. All callers changed.
7693 Also (re)move comments that are misplaced or no longer relevant.
7694
7695 2011-07-03 Lars Magne Ingebrigtsen <larsi@gnus.org>
7696
7697 * callint.c (Finteractive): Clarify the meaning of "@" (bug#8813).
7698
7699 2011-07-03 Chong Yidong <cyd@stupidchicken.com>
7700
7701 * xfaces.c (Finternal_merge_in_global_face): Modify the foreground
7702 and background color parameters if they have been changed.
7703
7704 2011-07-03 Lars Magne Ingebrigtsen <larsi@gnus.org>
7705
7706 * editfns.c (Fformat): Clarify the - and 0 flags (bug#6659).
7707
7708 2011-07-03 Paul Eggert <eggert@cs.ucla.edu>
7709
7710 * xsettings.c (SYSTEM_FONT): Define only when used.
7711 No need to define when HAVE_GSETTINGS || !HAVE_XFT.
7712
7713 * keymap.c (access_keymap_1): Now static.
7714
7715 2011-07-02 Chong Yidong <cyd@stupidchicken.com>
7716
7717 * keyboard.c (command_loop_1): If a down-mouse event is unbound,
7718 leave any prefix arg for the up event (Bug#1586).
7719
7720 2011-07-02 Lars Magne Ingebrigtsen <larsi@gnus.org>
7721
7722 * lread.c (syms_of_lread): Mention single symbols defined by
7723 `defvar' or `defconst' (bug#7154).
7724
7725 * fns.c (Frequire): Mention .el.gz files (bug#7314).
7726 (Frequire): Mention get-load-suffixes.
7727
7728 2011-07-02 Martin Rudalics <rudalics@gmx.at>
7729
7730 * window.h (window): Remove clone_number slot.
7731 * window.c (Fwindow_clone_number, Fset_window_clone_number):
7732 Remove.
7733 (make_parent_window, make_window, saved_window)
7734 (Fset_window_configuration, save_window_save): Don't deal with
7735 clone numbers.
7736 * buffer.c (Qclone_number): Remove declaration.
7737 (sort_overlays, overlay_strings): Don't deal with clone numbers.
7738
7739 2011-07-02 Stefan Monnier <monnier@iro.umontreal.ca>
7740
7741 Add multiple inheritance to keymaps.
7742 * keymap.c (Fmake_composed_keymap): New function.
7743 (Fset_keymap_parent): Simplify.
7744 (fix_submap_inheritance): Remove.
7745 (access_keymap_1): New function extracted from access_keymap to handle
7746 embedded parents and handle lists of maps.
7747 (access_keymap): Use it.
7748 (Fkeymap_prompt, map_keymap_internal, map_keymap, store_in_keymap)
7749 (Fcopy_keymap): Handle embedded parents.
7750 (Fcommand_remapping, define_as_prefix): Simplify.
7751 (Fkey_binding): Simplify.
7752 (syms_of_keymap): Move minibuffer-local-completion-map,
7753 minibuffer-local-filename-completion-map,
7754 minibuffer-local-must-match-map, and
7755 minibuffer-local-filename-must-match-map to Elisp.
7756 (syms_of_keymap): Defsubr make-composed-keymap.
7757 * keyboard.c (menu_bar_items): Use map_keymap_canonical.
7758 (parse_menu_item): Trivial simplification.
7759
7760 2011-07-01 Glenn Morris <rgm@gnu.org>
7761
7762 * Makefile.in (SETTINGS_LIBS): Fix typo.
7763
7764 2011-07-01 Kazuhiro Ito <kzhr@d1.dion.ne.jp> (tiny patch)
7765
7766 * coding.c (Fencode_coding_string): Record the last coding system
7767 used, as the function doc string says (bug#8738).
7768
7769 2011-07-01 Jan Djärv <jan.h.d@swipnet.se>
7770
7771 * xsettings.c (store_monospaced_changed): Take new font as arg and
7772 check for change against current_mono_font.
7773 (EMACS_TYPE_SETTINGS): Remove this and related defines.
7774 (emacs_settings_constructor, emacs_settings_get_property)
7775 (emacs_settings_set_property, emacs_settings_class_init)
7776 (emacs_settings_init, gsettings_obj): Remove.
7777 (something_changedCB): New function for HAVE_GSETTINGS.
7778 (something_changedCB): HAVE_GCONF: Call store_monospaced_changed
7779 with value as argument.
7780 (init_gsettings): Check that GSETTINGS_SCHEMA exists before calling
7781 g_settings_new (Bug#8967). Do not create gsettings_obj.
7782 Remove calls to g_settings_bind. Connect something_changedCB to
7783 "changed".
7784
7785 * xgselect.c: Add defined (HAVE_GSETTINGS).
7786 (xgselect_initialize): Ditto.
7787
7788 * process.c: Add defined (HAVE_GSETTINGS) for xgselect.h
7789 (wait_reading_process_output): Add defined (HAVE_GSETTINGS) for
7790 xg_select.
7791
7792 2011-07-01 Paul Eggert <eggert@cs.ucla.edu>
7793
7794 * eval.c (struct backtrace): Simplify and port the data structure.
7795 Do not assume that "int nargs : BITS_PER_INT - 2;" produces a
7796 signed bit field, as this assumption is not portable and it makes
7797 Emacs crash when compiled with Sun C 5.8 on sparc. Do not use
7798 "char debug_on_exit : 1" as this is not portable either; instead,
7799 use the portable "unsigned int debug_on_exit : 1". Remove unused
7800 member evalargs. Remove obsolete comments about cc bombing out.
7801
7802 2011-06-30 Jan Djärv <jan.h.d@swipnet.se>
7803
7804 * xsettings.c: Include glib-object.h, gio/gio.h if HAVE_GSETTINGS.
7805 Let HAVE_GSETTINGS override HAVE_GCONF.
7806 (store_monospaced_changed): New function.
7807 (EMACS_SETTINGS): A new type derived from GObject to handle
7808 GSettings notifications.
7809 (emacs_settings_constructor, emacs_settings_get_property)
7810 (emacs_settings_set_property, emacs_settings_class_init):
7811 New functions.
7812 (gsettings_client, gsettings_obj): New variables.
7813 (GSETTINGS_SCHEMA): New define.
7814 (something_changedCB): Call store_monospaced_changed.
7815 (init_gsettings): New function.
7816 (xsettings_initialize): Call init_gsettings.
7817 (syms_of_xsettings): Initialize gsettings_client, gsettings_obj
7818 to NULL.
7819
7820 * Makefile.in (SETTINGS_CFLAGS, SETTINGS_LIBS): Rename from
7821 GCONF_CFLAGS/LIBS.
7822
7823 2011-06-29 Martin Rudalics <rudalics@gmx.at>
7824
7825 * window.c (resize_root_window, grow_mini_window)
7826 (shrink_mini_window): Rename Qresize_root_window to
7827 Qwindow_resize_root_window and Qresize_root_window_vertically to
7828 Qwindow_resize_root_window_vertically.
7829
7830 2011-06-28 Paul Eggert <eggert@cs.ucla.edu>
7831
7832 * gnutls.c (Qgnutls_bootprop_verify_error): Remove unused var.
7833
7834 2011-06-27 Juanma Barranquero <lekktu@gmail.com>
7835
7836 * makefile.w32-in: Redesign dependencies so they reflect more
7837 clearly which files are directly included by each source file,
7838 and not through other includes.
7839
7840 2011-06-27 Martin Rudalics <rudalics@gmx.at>
7841
7842 * buffer.c (Qclone_number): Declare static and DEFSYM it.
7843 (sort_overlays, overlay_strings): When an overlay's clone number
7844 matches the window's clone number process the overlay even if
7845 the overlay's window property doesn't match the current window.
7846
7847 * window.c (Fwindow_vchild): Rename to Fwindow_top_child.
7848 (Fwindow_hchild): Rename to Fwindow_left_child.
7849 (Fwindow_next): Rename to Fwindow_next_sibling.
7850 (Fwindow_prev): Rename to Fwindow_prev_sibling.
7851 (resize_window_check): Rename to window_resize_check.
7852 (resize_window_apply): Rename to window_resize_apply.
7853 (Fresize_window_apply): Rename to Fwindow_resize_apply.
7854 (Fdelete_other_windows_internal, resize_frame_windows)
7855 (Fsplit_window_internal, Fdelete_window_internal)
7856 (grow_mini_window, shrink_mini_window)
7857 (Fresize_mini_window_internal): Fix callers accordingly.
7858
7859 2011-06-26 Jan Djärv <jan.h.d@swipnet.se>
7860
7861 * emacsgtkfixed.h: State that this is only used with Gtk+3.
7862 (emacs_fixed_set_min_size): Remove.
7863 (emacs_fixed_new): Take frame as argument.
7864
7865 * emacsgtkfixed.c: State that this is only used with Gtk+3.
7866 (_EmacsFixedPrivate): Remove minwidth/height.
7867 Add struct frame *f.
7868 (emacs_fixed_init): Initialize priv->f.
7869 (get_parent_class, emacs_fixed_set_min_size): Remove.
7870 (emacs_fixed_new): Set priv->f to argument.
7871 (emacs_fixed_get_preferred_width)
7872 (emacs_fixed_get_preferred_height): Use min_width/height from
7873 frames size_hint to set minimum and natural (Bug#8919).
7874 (XSetWMSizeHints, XSetWMNormalHints): Override these functions
7875 and use min_width/height from frames size_hint to set
7876 min_width/height (Bug#8919).
7877
7878 * gtkutil.c (xg_create_frame_widgets): Pass f to emacs_fixed_new.
7879 (x_wm_set_size_hint): Remove call to emacs_fixed_set_min_size.
7880 Fix indentation.
7881
7882 2011-06-26 Eli Zaretskii <eliz@gnu.org>
7883
7884 * bidi.c (bidi_paragraph_init): Test for ZV_BYTE before calling
7885 bidi_at_paragraph_end, since fast_looking_at doesn't like to be
7886 called at ZV.
7887
7888 2011-06-26 Chong Yidong <cyd@stupidchicken.com>
7889
7890 * process.c (wait_reading_process_output): Bypass select if
7891 waiting for a cell while ignoring keyboard input, and input is
7892 pending. Suggested by Jan Djärv (Bug#8869).
7893
7894 2011-06-25 Paul Eggert <eggert@cs.ucla.edu>
7895
7896 Use gnulib's dup2 module instead of rolling our own.
7897 * sysdep.c (dup2) [!HAVE_DUP2]: Remove; gnulib now does this.
7898
7899 2011-06-25 YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
7900
7901 * dispnew.c (scrolling_window): Before scrolling, turn off a
7902 mouse-highlight in the window being scrolled.
7903
7904 2011-06-24 Juanma Barranquero <lekktu@gmail.com>
7905
7906 Move DEFSYM to lisp.h and use everywhere.
7907
7908 * character.h (DEFSYM): Move declaration...
7909 * lisp.h (DEFSYM): ...here.
7910
7911 * gnutls.c:
7912 * minibuf.c:
7913 * w32menu.c:
7914 * w32proc.c:
7915 * w32select.c: Don't include character.h.
7916
7917 * alloc.c (syms_of_alloc):
7918 * buffer.c (syms_of_buffer):
7919 * bytecode.c (syms_of_bytecode):
7920 * callint.c (syms_of_callint):
7921 * casefiddle.c (syms_of_casefiddle):
7922 * casetab.c (init_casetab_once):
7923 * category.c (init_category_once, syms_of_category):
7924 * ccl.c (syms_of_ccl):
7925 * cmds.c (syms_of_cmds):
7926 * composite.c (syms_of_composite):
7927 * dbusbind.c (syms_of_dbusbind):
7928 * dired.c (syms_of_dired):
7929 * dispnew.c (syms_of_display):
7930 * doc.c (syms_of_doc):
7931 * editfns.c (syms_of_editfns):
7932 * emacs.c (syms_of_emacs):
7933 * eval.c (syms_of_eval):
7934 * fileio.c (syms_of_fileio):
7935 * fns.c (syms_of_fns):
7936 * frame.c (syms_of_frame):
7937 * fringe.c (syms_of_fringe):
7938 * insdel.c (syms_of_insdel):
7939 * keymap.c (syms_of_keymap):
7940 * lread.c (init_obarray, syms_of_lread):
7941 * macros.c (syms_of_macros):
7942 * msdos.c (syms_of_msdos):
7943 * print.c (syms_of_print):
7944 * process.c (syms_of_process):
7945 * search.c (syms_of_search):
7946 * sound.c (syms_of_sound):
7947 * syntax.c (init_syntax_once, syms_of_syntax):
7948 * terminal.c (syms_of_terminal):
7949 * textprop.c (syms_of_textprop):
7950 * undo.c (syms_of_undo):
7951 * w32.c (globals_of_w32):
7952 * window.c (syms_of_window):
7953 * xdisp.c (syms_of_xdisp):
7954 * xfaces.c (syms_of_xfaces):
7955 * xfns.c (syms_of_xfns):
7956 * xmenu.c (syms_of_xmenu):
7957 * xsettings.c (syms_of_xsettings):
7958 * xterm.c (syms_of_xterm): Use DEFSYM.
7959
7960 2011-06-24 Teodor Zlatanov <tzz@lifelogs.com>
7961
7962 * gnutls.c (syms_of_gnutls): Use the DEFSYM macro from character.h.
7963
7964 2011-06-23 Paul Eggert <eggert@cs.ucla.edu>
7965
7966 Integer and buffer overflow fixes (Bug#8873).
7967
7968 * print.c (printchar, strout): Check for string overflow.
7969 (PRINTPREPARE, printchar, strout):
7970 Don't set size unless allocation succeeds.
7971
7972 * minibuf.c (read_minibuf_noninteractive): Use ptrdiff_t, not int,
7973 for sizes. Check for string overflow more accurately.
7974 Simplify newline removal at end; this suppresses a GCC 4.6.0 warning.
7975
7976 * macros.c: Integer and buffer overflow fixes.
7977 * keyboard.h (struct keyboard.kbd_macro_bufsize):
7978 * macros.c (Fstart_kbd_macro, store_kbd_macro_char):
7979 Use ptrdiff_t, not int, for sizes.
7980 Don't increment bufsize until after realloc succeeds.
7981 Check for size-calculation overflow.
7982 (Fstart_kbd_macro): Use EMACS_INT, not int, for XINT result.
7983
7984 * lisp.h (DEFVAR_KBOARD): Use offsetof instead of char * finagling.
7985
7986 * lread.c: Integer overflow fixes.
7987 (read_integer): Radix is now EMACS_INT, not int,
7988 to improve quality of diagnostics for out-of-range radices.
7989 Calculate buffer size correctly for out-of-range radices.
7990 (read1): Check for integer overflow in radices, and in
7991 read-circle numbers.
7992 (read_escape): Avoid int overflow.
7993 (Fload, openp, read_buffer_size, read1)
7994 (substitute_object_recurse, read_vector, read_list, map_obarray):
7995 Use ptrdiff_t, not int, for sizes.
7996 (read1): Use EMACS_INT, not int, for sizes.
7997 Check for size overflow.
7998
7999 * image.c (cache_image): Check for size arithmetic overflow.
8000
8001 * lread.c: Integer overflow issues.
8002 (saved_doc_string_size, saved_doc_string_length)
8003 (prev_saved_doc_string_size, prev_saved_doc_string_length):
8004 Now ptrdiff_t, not int.
8005 (read1): Don't assume doc string length fits in int. Check for
8006 out-of-range doc string lengths.
8007 (read_list): Don't assume file position fits in int.
8008 (read_escape): Check for hex character overflow.
8009
8010 2011-06-22 Leo Liu <sdl.web@gmail.com>
8011
8012 * minibuf.c (Fcompleting_read_default, Vcompleting_read_function):
8013 Move to minibuffer.el.
8014
8015 2011-06-22 Paul Eggert <eggert@cs.ucla.edu>
8016
8017 Fixes for GLYPH_DEBUG found by GCC 4.6.0 static checking.
8018 The following patches are for when GLYPH_DEBUG && !XASSERT.
8019 * dispextern.h (trace_redisplay_p, dump_glyph_string):
8020 * dispnew.c (flush_stdout):
8021 * xdisp.c (dump_glyph_row, dump_glyph_matrix, dump_glyph):
8022 Mark as externally visible.
8023 * dispnew.c (check_window_matrix_pointers): Now static.
8024 * dispnew.c (window_to_frame_vpos):
8025 * xfns.c (unwind_create_frame):
8026 * xterm.c (x_check_font): Remove unused local.
8027 * scroll.c (CHECK_BOUNDS):
8028 * xfaces.c (cache_fache): Rename local to avoid shadowing.
8029 * xfns.c, w32fns.c (image_cache_refcount, dpyinfo_refcount): Now static.
8030 * xdisp.c (check_window_end): Now a no-op if !XASSERTS.
8031 (debug_first_unchanged_at_end_vpos, debug_last_unchanged_at_beg_vpos)
8032 (debug_dvpos, debug_dy, debug_delta, debug_delta_bytes, debug_end_vpos):
8033 Now static.
8034 (debug_method_add): Use va_list and vsprintf rather than relying
8035 on undefined behavior with wrong number of arguments.
8036 (dump_glyph, dump_glyph_row, Fdump_glyph_matrix):
8037 Don't assume ptrdiff_t and EMACS_INT are the same width as int.
8038 In this code, it's OK to assume C99 behavior for ptrdiff_t formats
8039 since we're not interested in debugging glyphs with old libraries.
8040 * xfaces.c (cache_face): Move debugging code earlier; this pacifies
8041 GCC 4.6.0's static checking.
8042
8043 2011-06-22 Paul Eggert <eggert@cs.ucla.edu>
8044
8045 Integer overflow and signedness fixes (Bug#8873).
8046 A few related buffer overrun fixes, too.
8047
8048 * font.c (font_score): Use EMACS_INT, not int, to store XINT value.
8049
8050 * dispextern.h (struct face.stipple):
8051 * image.c (x_bitmap_height, x_bitmap_width, x_bitmap_pixmap)
8052 (x_bitmap_mask, x_allocate_bitmap_record)
8053 (x_create_bitmap_from_data, x_create_bitmap_from_file)
8054 (x_destroy_bitmap, x_destroy_all_bitmaps, x_create_bitmap_mask)
8055 (x_create_bitmap_from_xpm_data):
8056 * nsterm.h (struct ns_display_info.bitmaps_size, .bitmaps_last):
8057 * w32term.h (struct w32_display_info.icon_bitmap_id, .bitmaps_size)
8058 (.bitmaps_last):
8059 * xfaces.c (load_pixmap):
8060 * xterm.c (x_bitmap_icon, x_wm_set_icon_pixmap):
8061 * xterm.h (struct x_display_info.icon_bitmap_id, .bitmaps_size)
8062 (.bitmaps_last, struct x_output.icon_bitmap):
8063 Use ptrdiff_t, not int, for bitmap indexes.
8064 (x_allocate_bitmap_record): Check for size overflow.
8065 * dispextern.h, lisp.h: Adjust to API changes elsewhere.
8066
8067 Use ptrdiff_t, not int, for overlay counts.
8068 * buffer.h (overlays_at, sort_overlays, GET_OVERLAYS_AT):
8069 * editfns.c (overlays_around, get_pos_property):
8070 * textprop.c (get_char_property_and_overlay):
8071 * xdisp.c (next_overlay_change, note_mouse_highlight):
8072 * xfaces.c (face_at_buffer_position):
8073 * buffer.c (OVERLAY_COUNT_MAX): New macro.
8074 (overlays_at, overlays_in, sort_overlays, Foverlays_at)
8075 (Fnext_overlay_change, Fprevious_overlay_change)
8076 (mouse_face_overlay_overlaps, Foverlays_in):
8077 Use ptrdiff_t, not int, for sizes.
8078 (overlays_at, overlays_in): Check for size-calculation overflow.
8079
8080 * xterm.c (xim_initialize, same_x_server): Strlen may not fit in int.
8081
8082 * xsmfns.c (smc_save_yourself_CB, x_session_initialize): Avoid strlen.
8083 (x_session_initialize): Do not assume string length fits in int.
8084
8085 * xsettings.c (apply_xft_settings): Fix potential buffer overrun.
8086 This is unlikely, but can occur if DPI is outlandish.
8087
8088 * xsettings.c (Ffont_get_system_normal_font, Ffont_get_system_font):
8089 * xselect.c (Fx_get_atom_name): Avoid need for strlen.
8090
8091 * xrdb.c: Don't assume strlen fits in int; avoid some strlens.
8092 * xrdb.c (magic_file_p, search_magic_path):
8093 Omit last arg SUFFIX; it was always 0. All callers changed.
8094 (magic_file_p): Use ptrdiff_t, not int. Check for size overflow.
8095
8096 * xfont.c (xfont_match): Avoid need for strlen.
8097
8098 * xfns.c: Don't assume strlen fits in int.
8099 (xic_create_fontsetname, x_window): Use ptrdiff_t, not int.
8100
8101 * xdisp.c (message_log_check_duplicate): Return intmax_t,
8102 not unsigned long, as we prefer signed integers. All callers changed.
8103 Detect integer overflow in repeat count.
8104 (message_dolog): Don't assume print length fits in 39 bytes.
8105 (display_mode_element): Don't assume strlen fits in int.
8106
8107 * termcap.c: Don't assume sizes fit in int and never overflow.
8108 (struct termcap_buffer, tgetent): Use ptrdiff_t, not int, for sizes.
8109 (gobble_line): Check for size-calculation overflow.
8110
8111 * minibuf.c (Fread_buffer):
8112 * lread.c (intern, intern_c_string):
8113 * image.c (xpm_scan) [HAVE_NS && !HAVE_XPM]:
8114 Don't assume string length fits in int.
8115
8116 * keyboard.c (parse_tool_bar_item):
8117 * gtkutil.c (style_changed_cb): Avoid need for strlen.
8118
8119 * font.c: Don't assume string length fits in int.
8120 (font_parse_xlfd, font_parse_fcname, font_unparse_fcname):
8121 Use ptrdiff_t, not int.
8122 (font_intern_prop): Don't assume string length fits in int.
8123 Don't assume integer property fits in fixnum.
8124 * font.h (font_intern_prop): 2nd arg is now ptrdiff_t, not int.
8125
8126 * filelock.c: Fix some buffer overrun and integer overflow issues.
8127 (get_boot_time): Don't assume gzip command string fits in 100 bytes.
8128 Reformulate so as not to need the command string.
8129 Invoke gzip -cd rather than gunzip, as it's more portable.
8130 (lock_info_type, lock_file_1, lock_file):
8131 Don't assume pid_t and time_t fit in unsigned long.
8132 (LOCK_PID_MAX): Remove; we now use more-reliable bounds.
8133 (current_lock_owner): Prefer signed type for sizes.
8134 Use memcpy, not strncpy, where memcpy is what is really wanted.
8135 Don't assume (via atoi) that time_t and pid_t fit in int.
8136 Check for time_t and/or pid_t out of range, e.g., via a network share.
8137 Don't alloca where an auto var works fine.
8138
8139 * fileio.c: Fix some integer overflow issues.
8140 (file_name_as_directory, Fexpand_file_name, Fsubstitute_in_file_name):
8141 Don't assume string length fits in int.
8142 (directory_file_name): Don't assume string length fits in long.
8143 (make_temp_name): Don't assume pid fits in int, or that its print
8144 length is less than 20.
8145
8146 * data.c (Fsubr_name): Rewrite to avoid a strlen call.
8147
8148 * coding.c (make_subsidiaries): Don't assume string length fits in int.
8149
8150 * callproc.c (child_setup): Rewrite to avoid two strlen calls.
8151
8152 * process.c (Fformat_network_address): Use EMACS_INT, not EMACS_UINT.
8153 We prefer signed integers, even for size calculations.
8154
8155 * emacs.c: Don't assume string length fits in 'int'.
8156 (DEFINE_DUMMY_FUNCTION, sort_args): Use ptrdiff_t, not int.
8157 (main): Don't invoke strlen when not needed.
8158
8159 * dbusbind.c (XD_ERROR): Don't arbitrarily truncate string.
8160 (XD_DEBUG_MESSAGE): Don't waste a byte.
8161
8162 * callproc.c (getenv_internal_1, getenv_internal)
8163 (Fgetenv_internal):
8164 * buffer.c (init_buffer): Don't assume string length fits in 'int'.
8165
8166 * lread.c (invalid_syntax): Omit length argument.
8167 All uses changed. This doesn't fix a bug, but it simplifies the
8168 code away from its former Hollerith-constant appearance, and it's
8169 one less 'int' to worry about when looking at integer-overflow issues.
8170 (string_to_number): Simplify 2011-04-26 change by invoking xsignal1.
8171
8172 * lisp.h (DEFUN): Remove bogus use of sizeof (struct Lisp_Subr).
8173 This didn't break anything, but it didn't help either.
8174 It's confusing to put a bogus integer in a place where the actual
8175 value does not matter.
8176 (LIST_END_P): Remove unused macro and its bogus comment.
8177 (make_fixnum_or_float): Remove unnecessary cast to EMACS_INT.
8178
8179 * lisp.h (union Lisp_Object.i): EMACS_INT, not EMACS_UINT.
8180 This is for consistency with the ordinary, non-USE_LISP_UNION_TYPE,
8181 implementation.
8182 (struct Lisp_Bool_Vector.size): EMACS_INT, not EMACS_UINT.
8183 We prefer signed types, and the value cannot exceed the EMACS_INT
8184 range anyway (because otherwise the length would not be representable).
8185 (XSET) [USE_LISP_UNION_TYPE]: Use uintptr_t and intptr_t,
8186 not EMACS_UINT and EMACS_INT, when converting pointer to integer.
8187 This avoids a GCC warning when WIDE_EMACS_INT.
8188
8189 * indent.c (sane_tab_width): New function.
8190 (current_column, scan_for_column, Findent_to, position_indentation)
8191 (compute_motion): Use it. This is just for clarity.
8192 (Fcompute_motion): Don't assume hscroll and tab offset fit in int.
8193
8194 * image.c (xbm_image_p): Don't assume stated width, height fit in int.
8195
8196 * lisp.h (lint_assume): New macro.
8197 * composite.c (composition_gstring_put_cache):
8198 * ftfont.c (ftfont_shape_by_flt): Use it to pacify GCC 4.6.0.
8199
8200 * editfns.c, insdel.c:
8201 Omit unnecessary forward decls, to simplify future changes.
8202
8203 * ftfont.c (ftfont_shape_by_flt): Use signed integers for lengths.
8204
8205 * font.c (Ffont_shape_gstring): Don't assume glyph len fits in 'int'.
8206
8207 * fns.c (Ffillarray): Don't assume bool vector size fits in 'int'.
8208 Use much-faster test for byte-length change.
8209 Don't assume string byte-length fits in 'int'.
8210 Check that character arg fits in 'int'.
8211 (mapcar1): Declare byte as byte, for clarity.
8212
8213 * alloc.c (Fmake_bool_vector): Avoid unnecessary multiplication.
8214
8215 * fns.c (concat): Catch string overflow earlier.
8216 Do not rely on integer wraparound.
8217
8218 * dispextern.h (struct it.overlay_strings_charpos)
8219 (struct it.selective): Now EMACS_INT, not int.
8220 * xdisp.c (forward_to_next_line_start)
8221 (back_to_previous_visible_line_start)
8222 (reseat_at_next_visible_line_start, next_element_from_buffer):
8223 Don't arbitrarily truncate the value of 'selective' to int.
8224
8225 * xdisp.c (init_iterator): Use XINT, not XFASTINT; it might be < 0.
8226
8227 * composite.c: Don't truncate sizes to 'int'.
8228 (composition_gstring_p, composition_reseat_it)
8229 (composition_adjust_point): Use EMACS_INT, not int.
8230 (get_composition_id, composition_gstring_put_cache): Use EMACS_INT,
8231 not EMACS_UINT, for indexes.
8232
8233 * category.h (CATEGORY_SET_P): Remove unnecessary cast to EMACS_INT.
8234
8235 * buffer.c: Include <verify.h>.
8236 (struct sortvec.priority, struct sortstr.priority):
8237 Now EMACS_INT, not int.
8238 (compare_overlays, cmp_for_strings): Avoid subtraction overflow.
8239 (struct sortstr.size, record_overlay_string)
8240 (struct sortstrlist.size, struct sortlist.used):
8241 Don't truncate size to int.
8242 (record_overlay_string): Check for size-calculation overflow.
8243 (init_buffer_once): Check at compile-time, not run-time.
8244
8245 2011-06-22 Jim Meyering <meyering@redhat.com>
8246
8247 Don't leak an XBM-image-sized buffer
8248 * image.c (xbm_load): Free the image buffer after using it.
8249
8250 2011-06-21 Paul Eggert <eggert@cs.ucla.edu>
8251
8252 Port to Sun C.
8253 * composite.c (find_automatic_composition): Omit needless 'return 0;'
8254 that Sun C diagnosed.
8255 * fns.c (secure_hash): Fix pointer signedness issue.
8256 * intervals.c (static_offset_intervals): New function.
8257 (offset_intervals): Use it.
8258
8259 2011-06-21 Leo Liu <sdl.web@gmail.com>
8260
8261 * deps.mk (fns.o):
8262 * makefile.w32-in ($(BLD)/fns.$(O)): Include sha256.h and
8263 sha512.h.
8264
8265 * fns.c (secure_hash): Rename from crypto_hash_function and change
8266 the first arg to accept symbols.
8267 (Fsecure_hash): New primitive.
8268 (syms_of_fns): New symbols.
8269
8270 2011-06-20 Deniz Dogan <deniz@dogan.se>
8271
8272 * process.c (Fset_process_buffer): Clarify return value in
8273 docstring.
8274
8275 2011-06-18 Chong Yidong <cyd@stupidchicken.com>
8276
8277 * dispnew.c (add_window_display_history): Use BVAR.
8278
8279 * xdisp.c (debug_method_add): Use BVAR.
8280 (check_window_end, dump_glyph_matrix, dump_glyph)
8281 (dump_glyph_row, dump_glyph_string): Convert arglist to ANSI C.
8282
8283 * xfaces.c (check_lface_attrs, check_lface, dump_realized_face):
8284 Likewise.
8285
8286 * xfns.c (Fx_create_frame, x_create_tip_frame): Delay image cache
8287 check till after the cache is created in init_frame_faces.
8288
8289 2011-06-17 Stefan Monnier <monnier@iro.umontreal.ca>
8290
8291 * fns.c (Fsafe_length): Yet another int/Lisp_Object mixup.
8292
8293 2011-06-16 Paul Eggert <eggert@cs.ucla.edu>
8294
8295 * lisp.h: Include <limits.h>, for INT_MAX, LONG_MAX, LLONG_MAX.
8296 Without this, prin1 mishandles Lisp_Misc_Save_Value printing on
8297 hosts with pre-C99 libraries, because pD is wrongly defined to "t".
8298
8299 Improve buffer-overflow checking (Bug#8873).
8300 * fileio.c (Finsert_file_contents):
8301 * insdel.c (insert_from_buffer_1, replace_range, replace_range_2):
8302 Remove the old (too-loose) buffer overflow checks.
8303 They weren't needed, since make_gap checks for buffer overflow.
8304 * insdel.c (make_gap_larger): Catch buffer overflows that were missed.
8305 The old code merely checked for Emacs fixnum overflow, and relied
8306 on undefined (wraparound) behavior. The new code avoids undefined
8307 behavior, and also checks for ptrdiff_t and/or size_t overflow.
8308
8309 * editfns.c (Finsert_char): Don't dump core with very negative counts.
8310 Tune. Don't use wider integers than needed. Don't use alloca.
8311 Use a bigger 'string' buffer. Rewrite to avoid 'n > 0' test.
8312
8313 * insdel.c (replace_range): Fix buf overflow when insbytes < outgoing.
8314
8315 * insdel.c, lisp.h (buffer_overflow): New function.
8316 (insert_from_buffer_1, replace_range, replace_range_2):
8317 * insdel.c (make_gap_larger):
8318 * editfns.c (Finsert_char):
8319 * fileio.c (Finsert_file_contents): Use it, to normalize wording.
8320
8321 * buffer.h (BUF_BYTES_MAX): Cast to ptrdiff_t so that it's signed.
8322
8323 2011-06-15 Paul Eggert <eggert@cs.ucla.edu>
8324
8325 Integer overflow and signedness fixes (Bug#8873, Bug#8828).
8326
8327 * ccl.c (ASCENDING_ORDER): New macro, to work around GCC bug 43772.
8328 (GET_CCL_RANGE, IN_INT_RANGE): Use it.
8329
8330 * fileio.c: Don't assume EMACS_INT fits in off_t.
8331 (emacs_lseek): New static function.
8332 (Finsert_file_contents, Fwrite_region): Use it.
8333 Use SEEK_SET, SEEK_CUR, SEEK_END as appropriate.
8334
8335 * fns.c (Fload_average): Don't assume 100 * load average fits in int.
8336
8337 * fns.c: Don't overflow int when computing a list length.
8338 * fns.c (QUIT_COUNT_HEURISTIC): New constant.
8339 (Flength, Fsafe_length): Use EMACS_INT, not int, to avoid unwanted
8340 truncation on 64-bit hosts. Check for QUIT every
8341 QUIT_COUNT_HEURISTIC entries rather than every other entry; that's
8342 faster and is responsive enough.
8343 (Flength): Report an error instead of overflowing an integer.
8344 (Fsafe_length): Return a float if the value is not representable
8345 as a fixnum. This shouldn't happen except in contrived situations.
8346 (Fnthcdr, Fsort): Don't assume list length fits in int.
8347 (Fcopy_sequence): Don't assume vector length fits in int.
8348
8349 * alloc.c: Check that resized vectors' lengths fit in fixnums.
8350 (header_size, word_size): New constants.
8351 (allocate_vectorlike): Don't check size overflow here.
8352 (allocate_vector): Check it here instead, since this is the only
8353 caller of allocate_vectorlike that could cause overflow.
8354 Check that the new vector's length is representable as a fixnum.
8355
8356 * fns.c (next_almost_prime): Don't return a multiple of 3 or 5.
8357 The previous code was bogus. For example, next_almost_prime (32)
8358 returned 39, which is undesirable as it is a multiple of 3; and
8359 next_almost_prime (24) returned 25, which is a multiple of 5 so
8360 why was the code bothering to check for multiples of 7?
8361
8362 * bytecode.c (exec_byte_code): Use ptrdiff_t, not int, for vector length.
8363
8364 * eval.c, doprnt.c (SIZE_MAX): Remove; inttypes.h defines this now.
8365
8366 Variadic C functions now count arguments with ptrdiff_t.
8367 This partly undoes my 2011-03-30 change, which replaced int with size_t.
8368 Back then I didn't know that the Emacs coding style prefers signed int.
8369 Also, in the meantime I found a few more instances where arguments
8370 were being counted with int, which may truncate counts on 64-bit
8371 machines, or EMACS_INT, which may be unnecessarily wide.
8372 * lisp.h (struct Lisp_Subr.function.aMANY)
8373 (DEFUN_ARGS_MANY, internal_condition_case_n, safe_call):
8374 Arg counts are now ptrdiff_t, not size_t.
8375 All variadic functions and their callers changed accordingly.
8376 (struct gcpro.nvars): Now size_t, not size_t. All uses changed.
8377 * bytecode.c (exec_byte_code): Check maxdepth for overflow,
8378 to avoid potential buffer overrun. Don't assume arg counts fit in 'int'.
8379 * callint.c (Fcall_interactively): Check arg count for overflow,
8380 to avoid potential buffer overrun. Use signed char, not 'int',
8381 for 'varies' array, so that we needn't bother to check its size
8382 calculation for overflow.
8383 * editfns.c (Fformat): Use ptrdiff_t, not EMACS_INT, to count args.
8384 * eval.c (apply_lambda):
8385 * fns.c (Fmapconcat): Use XFASTINT, not XINT, to get args length.
8386 (struct textprop_rec.argnum): Now ptrdiff_t, not int. All uses changed.
8387 (mapconcat): Use ptrdiff_t, not int and EMACS_INT, to count args.
8388
8389 * callint.c (Fcall_interactively): Don't use index var as event count.
8390
8391 * vm-limit.c (check_memory_limits): Fix incorrect extern function decls.
8392 * mem-limits.h (SIZE): Remove; no longer used.
8393
8394 * xterm.c (x_alloc_nearest_color_1): Prefer int to long when int works.
8395
8396 Remove unnecessary casts.
8397 * xterm.c (x_term_init):
8398 * xfns.c (x_set_border_pixel):
8399 * widget.c (create_frame_gcs): Remove casts to unsigned long etc.
8400 These aren't needed now that we assume ANSI C.
8401
8402 * sound.c (Fplay_sound_internal): Remove cast to unsigned long.
8403 It's more likely to cause problems (due to unsigned overflow)
8404 than to cure them.
8405
8406 * dired.c (Ffile_attributes): Don't use 32-bit hack on 64-bit hosts.
8407
8408 * unexelf.c (unexec): Don't assume BSS addr fits in unsigned.
8409
8410 * xterm.c (handle_one_xevent): Omit unnecessary casts to unsigned.
8411
8412 * keyboard.c (modify_event_symbol): Don't limit alist len to UINT_MAX.
8413
8414 * lisp.h (CHAR_TABLE_SET): Omit now-redundant test.
8415
8416 * lread.c (Fload): Don't compare a possibly-garbage time_t value.
8417
8418 GLYPH_CODE_FACE returns EMACS_INT, not int.
8419 * dispextern.h (merge_faces):
8420 * xfaces.c (merge_faces):
8421 * xdisp.c (get_next_display_element, next_element_from_display_vector):
8422 Don't assume EMACS_INT fits in int.
8423
8424 * character.h (CHAR_VALID_P): Remove unused parameter.
8425 * fontset.c, lisp.h, xdisp.c: All uses changed.
8426
8427 * editfns.c (Ftranslate_region_internal): Omit redundant test.
8428
8429 * fns.c (concat): Minor tuning based on overflow analysis.
8430 This doesn't fix any bugs. Use int to hold character, instead
8431 of constantly refetching from Emacs object. Use XFASTINT, not
8432 XINT, for value known to be a character. Don't bother comparing
8433 a single byte to 0400, as it's always less.
8434
8435 * floatfns.c (Fexpt):
8436 * fileio.c (make_temp_name): Omit unnecessary cast to unsigned.
8437
8438 * editfns.c (Ftranslate_region_internal): Use int, not EMACS_INT
8439 for characters.
8440
8441 * doc.c (get_doc_string): Omit (unsigned)c that mishandled negatives.
8442
8443 * data.c (Faset): If ARRAY is a string, check that NEWELT is a char.
8444 Without this fix, on a 64-bit host (aset S 0 4294967386) would
8445 incorrectly succeed when S was a string, because 4294967386 was
8446 truncated before it was used.
8447
8448 * chartab.c (Fchar_table_range): Use CHARACTERP to check range.
8449 Otherwise, an out-of-range integer could cause undefined behavior
8450 on a 64-bit host.
8451
8452 * composite.c: Use int, not EMACS_INT, for characters.
8453 (fill_gstring_body, composition_compute_stop_pos): Use int, not
8454 EMACS_INT, for values that are known to be in character range.
8455 This doesn't fix any bugs but is the usual style inside Emacs and
8456 may generate better code on 32-bit machines.
8457
8458 Make sure a 64-bit char is never passed to ENCODE_CHAR.
8459 This is for reasons similar to the recent CHAR_STRING fix.
8460 * charset.c (Fencode_char): Check that character arg is actually
8461 a character. Pass an int to ENCODE_CHAR.
8462 * charset.h (ENCODE_CHAR): Verify that the character argument is no
8463 wider than 'int', as a compile-time check to prevent future regressions
8464 in this area.
8465
8466 * character.c (char_string): Remove unnecessary casts.
8467
8468 Make sure a 64-bit char is never passed to CHAR_STRING.
8469 Otherwise, CHAR_STRING would do the wrong thing on a 64-bit platform,
8470 by silently ignoring the top 32 bits, allowing some values
8471 that were far too large to be valid characters.
8472 * character.h: Include <verify.h>.
8473 (CHAR_STRING, CHAR_STRING_ADVANCE): Verify that the character
8474 arguments are no wider than unsigned, as a compile-time check
8475 to prevent future regressions in this area.
8476 * data.c (Faset):
8477 * editfns.c (Fchar_to_string, general_insert_function, Finsert_char)
8478 (Fsubst_char_in_region):
8479 * fns.c (concat):
8480 * xdisp.c (decode_mode_spec_coding):
8481 Adjust to CHAR_STRING's new requirement.
8482 * editfns.c (Finsert_char, Fsubst_char_in_region):
8483 * fns.c (concat): Check that character args are actually
8484 characters. Without this test, these functions did the wrong
8485 thing with wildly out-of-range values on 64-bit hosts.
8486
8487 Remove incorrect casts to 'unsigned' that lose info on 64-bit hosts.
8488 These casts should not be needed on 32-bit hosts, either.
8489 * keyboard.c (read_char):
8490 * lread.c (Fload): Remove casts to unsigned.
8491
8492 * lisp.h (UNSIGNED_CMP): New macro.
8493 This fixes comparison bugs on 64-bit hosts.
8494 (ASCII_CHAR_P): Use it.
8495 * casefiddle.c (casify_object):
8496 * character.h (ASCII_BYTE_P, CHAR_VALID_P)
8497 (SINGLE_BYTE_CHAR_P, CHAR_STRING):
8498 * composite.h (COMPOSITION_ENCODE_RULE_VALID):
8499 * dispextern.h (FACE_FROM_ID):
8500 * keyboard.c (read_char): Use UNSIGNED_CMP.
8501
8502 * xmenu.c (dialog_selection_callback) [!USE_GTK]: Cast to intptr_t,
8503 not to EMACS_INT, to avoid GCC warning.
8504
8505 * xfns.c (x_set_scroll_bar_default_width): Remove unused 'int' locals.
8506
8507 * buffer.h (PTR_BYTE_POS, BUF_PTR_BYTE_POS): Remove harmful cast.
8508 The cast incorrectly truncated 64-bit byte offsets to 32 bits, and
8509 isn't needed on 32-bit machines.
8510
8511 * buffer.c (Fgenerate_new_buffer_name):
8512 Use EMACS_INT for count, not int.
8513 (advance_to_char_boundary): Return EMACS_INT, not int.
8514
8515 * data.c (Qcompiled_function): Now static.
8516
8517 * window.c (window_body_lines): Now static.
8518
8519 * image.c (gif_load): Rename local to avoid shadowing.
8520
8521 * lisp.h (SAFE_ALLOCA_LISP): Check for integer overflow.
8522 (struct Lisp_Save_Value): Use ptrdiff_t, not int, for 'integer' member.
8523 * alloc.c (make_save_value): Integer argument is now of type
8524 ptrdiff_t, not int.
8525 (mark_object): Use ptrdiff_t, not int.
8526 * lisp.h (pD): New macro.
8527 * print.c (print_object): Use it.
8528
8529 * alloc.c: Use EMACS_INT, not int, to count objects.
8530 (total_conses, total_markers, total_symbols, total_vector_size)
8531 (total_free_conses, total_free_markers, total_free_symbols)
8532 (total_free_floats, total_floats, total_free_intervals)
8533 (total_intervals, total_strings, total_free_strings):
8534 Now EMACS_INT, not int. All uses changed.
8535 (Fgarbage_collect): Compute overall total using a double, so that
8536 integer overflow is less likely to be a problem. Check for overflow
8537 when converting back to an integer.
8538 (n_interval_blocks, n_string_blocks, n_float_blocks, n_cons_blocks)
8539 (n_vectors, n_symbol_blocks, n_marker_blocks): Remove.
8540 These were 'int' variables that could overflow on 64-bit hosts;
8541 they were never used, so remove them instead of repairing them.
8542 (nzombies, ngcs, max_live, max_zombies): Now EMACS_INT, not 'int'.
8543 (inhibit_garbage_collection): Set gc_cons_threshold to max value.
8544 Previously, this ceilinged at INT_MAX, but that doesn't work on
8545 64-bit machines.
8546 (allocate_pseudovector): Don't use EMACS_INT when int would do.
8547
8548 * alloc.c (Fmake_bool_vector): Don't assume vector size fits in int.
8549 (allocate_vectorlike): Check for ptrdiff_t overflow.
8550 (mark_vectorlike, mark_char_table, mark_object): Avoid EMACS_UINT
8551 when a (possibly-narrower) signed value would do just as well.
8552 We prefer using signed arithmetic, to avoid comparison confusion.
8553
8554 * alloc.c: Catch some string size overflows that we were missing.
8555 (XMALLOC_OVERRUN_CHECK_SIZE) [!XMALLOC_OVERRUN_CHECK]: Define to 0,
8556 for convenience in STRING_BYTES_MAX.
8557 (STRING_BYTES_MAX): New macro, superseding the old one in lisp.h.
8558 The definition here is exact; the one in lisp.h was approximate.
8559 (allocate_string_data): Check for string overflow. This catches
8560 some instances we weren't catching before. Also, it catches
8561 size_t overflow on (unusual) hosts where SIZE_MAX <= min
8562 (PTRDIFF_MAX, MOST_POSITIVE_FIXNUM), e.g., when size_t is 32 bits
8563 and ptrdiff_t and EMACS_INT are both 64 bits.
8564
8565 * character.c, coding.c, doprnt.c, editfns.c, eval.c:
8566 All uses of STRING_BYTES_MAX replaced by STRING_BYTES_BOUND.
8567 * lisp.h (STRING_BYTES_BOUND): Rename from STRING_BYTES_MAX.
8568
8569 * character.c (string_escape_byte8): Fix nbytes/nchars typo.
8570
8571 * alloc.c (Fmake_string): Check for out-of-range init.
8572
8573 2011-06-15 Stefan Monnier <monnier@iro.umontreal.ca>
8574
8575 * eval.c (Fdefvaralias): Also mark the target as variable-special-p.
8576
8577 2011-06-14 Jan Djärv <jan.h.d@swipnet.se>
8578
8579 * xfns.c (x_set_scroll_bar_default_width): Remove argument to
8580 xg_get_default_scrollbar_width.
8581
8582 * gtkutil.c: Include emacsgtkfixed.h if HAVE_GTK3.
8583 (int_gtk_range_get_value): Move to the scroll bar part of the file.
8584 (style_changed_cb): Call update_theme_scrollbar_width and call
8585 x_set_scroll_bar_default_width and xg_frame_set_char_size for
8586 all frames (Bug#8505).
8587 (xg_create_frame_widgets): Call emacs_fixed_new if HAVE_GTK3 (Bug#8505).
8588 Call gtk_window_set_resizable if HAVE_GTK3.
8589 (x_wm_set_size_hint): Call emacs_fixed_set_min_size with min width
8590 and height if HAVE_GTK3 (Bug#8505).
8591 (scroll_bar_width_for_theme): New variable.
8592 (update_theme_scrollbar_width): New function.
8593 (xg_get_default_scrollbar_width): Move code to
8594 update_theme_scrollbar_width, just return scroll_bar_width_for_theme.
8595 (xg_initialize): Call update_theme_scrollbar_width.
8596
8597 * gtkutil.h (xg_get_default_scrollbar_width): Remove argument.
8598
8599 * emacsgtkfixed.c, emacsgtkfixed.h: New files.
8600
8601 2011-06-12 Martin Rudalics <rudalics@gmx.at>
8602
8603 * frame.c (make_frame): Call other_buffer_safely instead of
8604 other_buffer.
8605
8606 * window.c (temp_output_buffer_show): Call display_buffer with
8607 second argument Vtemp_buffer_show_specifiers and reset latter
8608 immediately after the call.
8609 (Vtemp_buffer_show_specifiers): New variable.
8610 (auto_window_vscroll_p, next_screen_context_lines)
8611 (Vscroll_preserve_screen_position): Remove leading asterisks from
8612 doc-strings.
8613
8614 2011-06-12 Paul Eggert <eggert@cs.ucla.edu>
8615
8616 Fix minor problems found by GCC 4.6.0 static checking.
8617 * buffer.c (Qclone_number): Remove for now, as it's unused.
8618 (record_buffer, Funrecord_buffer): Rename local to avoid shadowing.
8619 (record_buffer): Remove unused local.
8620 * frame.c (other_visible_frames, frame_buffer_list): Now static.
8621 (set_frame_buffer_list): Remove; unused.
8622 * frame.h (other_visible_frames): Remove decl.
8623 * keyboard.h (menu_items_inuse): Declare only if USE_GTK || USE_MOTIF.
8624 * lisp.h (frame_buffer_list, set_frame_buffer_list): Remove decls.
8625 (add_gpm_wait_descriptor, delete_gpm_wait_descriptor): Declare only
8626 if HAVE_GPM.
8627 * menu.c (menu_items_inuse): Now static unless USE_GTK || USE_MOTIF.
8628 * process.c (add_gpm_wait_descriptor, delete_gpm_wait_descriptor):
8629 Define only if HAVE_GPM.
8630 * widget.c (EmacsFrameResize, emacsFrameClassRec): Now static.
8631 (update_hints_inhibit): Remove; never set. All uses removed.
8632 * widgetprv.h (emacsFrameClassRec): Remove decl.
8633 * window.c (delete_deletable_window): Now returns void, since it
8634 wasn't returning anything.
8635 (compare_window_configurations): Remove unused locals.
8636 * xfns.c (x_set_scroll_bar_default_width): Remove unused locals.
8637 * xmenu.c (x_menu_set_in_use): Define only if USE_GTK || USE_MOTIF.
8638 (dialog_selection_callback) [!USE_GTK]: Prefer intptr_t for integers
8639 the same widths as pointers. This follows up on the 2011-05-06 patch.
8640 * xterm.c (x_alloc_lighter_color_for_widget): Define only if USE_LUCID.
8641 * xterm.h: Likewise.
8642 (x_menu_set_in_use): Declare only if USE_GTK || USE_MOTIF.
8643
8644 2011-06-12 Juanma Barranquero <lekktu@gmail.com>
8645
8646 * makefile.w32-in: Update dependencies.
8647 (LISP_H): Add lib/intprops.h.
8648
8649 2011-06-11 Chong Yidong <cyd@stupidchicken.com>
8650
8651 * image.c (gif_load): Add animation frame delay to the metadata.
8652 (syms_of_image): Use DEFSYM. New symbol `delay'.
8653
8654 2011-06-11 Martin Rudalics <rudalics@gmx.at>
8655
8656 * window.c (delete_deletable_window): Re-add.
8657 (Fset_window_configuration): Rewrite to handle dead buffers and
8658 consequently deletable windows.
8659 (window_tree, Fwindow_tree): Remove. Supply functionality in
8660 window.el.
8661 (compare_window_configurations): Simplify code.
8662
8663 2011-06-11 Andreas Schwab <schwab@linux-m68k.org>
8664
8665 * image.c (imagemagick_load_image): Fix type mismatch.
8666 (Fimagemagick_types): Likewise.
8667
8668 * window.h (replace_buffer_in_windows): Declare.
8669
8670 2011-06-11 Martin Rudalics <rudalics@gmx.at>
8671
8672 * buffer.c: New Lisp objects Qbuffer_list_update_hook and
8673 Qclone_number. Remove external declaration of Qdelete_window.
8674 (Fbuffer_list): Rewrite doc-string. Minor restructuring of
8675 code.
8676 (Fget_buffer_create, Fmake_indirect_buffer, Frename_buffer):
8677 Run Qbuffer_list_update_hook if allowed.
8678 (Fother_buffer): Rewrite doc-string. Major rewrite for new
8679 buffer list implementation.
8680 (other_buffer_safely): New function.
8681 (Fkill_buffer): Replace call to replace_buffer_in_all_windows by
8682 calls to replace_buffer_in_windows and
8683 replace_buffer_in_windows_safely. Run Qbuffer_list_update_hook
8684 if allowed.
8685 (record_buffer): Inhibit quitting and rewrite using quittable
8686 functions. Run Qbuffer_list_update_hook if allowed.
8687 (Frecord_buffer, Funrecord_buffer): New functions.
8688 (switch_to_buffer_1, Fswitch_to_buffer): Remove.
8689 Move switch-to-buffer to window.el.
8690 (bury-buffer): Move to window.el.
8691 (Vbuffer_list_update_hook): New variable.
8692
8693 * lisp.h (other_buffer_safely): Add prototype in buffer.c
8694 section.
8695
8696 * window.h (resize_frame_windows): Move up in code.
8697 (Fwindow_frame): Remove EXFUN.
8698 (replace_buffer_in_all_windows): Remove prototype.
8699 (replace_buffer_in_windows_safely): Add prototype.
8700
8701 * window.c: Declare Qdelete_window static again. Move down
8702 declaration of select_count.
8703 (Fnext_window, Fprevious_window): Rewrite doc-strings.
8704 (Fother_window): Move to window.el.
8705 (window_loop): Remove DELETE_BUFFER_WINDOWS and UNSHOW_BUFFER
8706 cases. Add REPLACE_BUFFER_IN_WINDOWS_SAFELY case.
8707 (Fdelete_windows_on, Freplace_buffer_in_windows): Move to
8708 window.el.
8709 (replace_buffer_in_windows): Implement by calling
8710 Qreplace_buffer_in_windows.
8711 (replace_buffer_in_all_windows): Remove with some functionality
8712 moved into replace_buffer_in_windows_safely.
8713 (replace_buffer_in_windows_safely): New function.
8714 (select_window_norecord, select_frame_norecord): Move in front
8715 of run_window_configuration_change_hook. Remove now obsolete
8716 declarations.
8717 (Fset_window_buffer): Rewrite doc-string.
8718 Call Qrecord_window_buffer.
8719 (keys_of_window): Move binding for other-window to window.el.
8720
8721 2011-06-11 Chong Yidong <cyd@stupidchicken.com>
8722
8723 * dispextern.h (struct image): Replace data member, whose int_val
8724 and ptr_val fields were not used by anything, with a single
8725 lisp_val object.
8726
8727 * image.c (Fimage_metadata, make_image, mark_image, tiff_load)
8728 (gif_clear_image, gif_load, imagemagick_load_image)
8729 (gs_clear_image, gs_load): Callers changed.
8730
8731 2011-06-10 Paul Eggert <eggert@cs.ucla.edu>
8732
8733 * buffer.h: Include <time.h>, for time_t.
8734 Needed to build on FreeBSD 8.2. Problem reported by Herbert J. Skuhra.
8735
8736 Fix minor problems found by static checking.
8737
8738 * image.c (PixelGetMagickColor): Declare if ImageMagick headers don't.
8739
8740 Make identifiers static if they are not used in other modules.
8741 * data.c (Qcompiled_function, Qframe, Qvector):
8742 * image.c (QimageMagick, Qsvg):
8743 * minibuf.c (Qmetadata):
8744 * window.c (resize_window_check, resize_root_window): Now static.
8745 * window.h (resize_window_check, resize_root_window): Remove decls.
8746
8747 * window.c (window_deletion_count, delete_deletable_window):
8748 Remove; unused.
8749 (window_body_lines): Now static.
8750 (Fdelete_other_windows_internal): Mark vars as initialized.
8751 Make sure 'resize_failed' is initialized.
8752 (run_window_configuration_change_hook): Rename local to avoid shadowing.
8753 (resize_window_apply): Remove unused local.
8754 * window.h (delete_deletable_window): Remove decl.
8755
8756 * image.c (gif_load, svg_load_image): Rename locals to avoid shadowing.
8757 (imagemagick_load_image): Fix pointer signedness problem by changing
8758 last arg from unsigned char * to char *. All uses changed.
8759 Also, fix a local for similar reasons.
8760 Remove unused locals. Remove locals to avoid shadowing.
8761 (fn_rsvg_handle_free): Remove; unused.
8762 (svg_load, svg_load_image): Fix pointer signedness problem.
8763 (imagemagick_load_image): Don't use garbage pointer image_wand.
8764
8765 * ftfont.c (ftfont_get_metrics, ftfont_drive_otf): Remove unused locals.
8766
8767 2011-06-10 Chong Yidong <cyd@stupidchicken.com>
8768
8769 * image.c (gif_load): Fix omitted cast error introduced by
8770 2011-06-06 change.
8771
8772 2011-06-10 Martin Rudalics <rudalics@gmx.at>
8773
8774 * window.h (resize_proportionally, orig_total_lines)
8775 (orig_top_line): Remove from window structure.
8776 (set_window_height, set_window_width, change_window_heights)
8777 (Fdelete_window): Remove prototypes.
8778 (resize_frame_windows): Remove duplicate declaration.
8779
8780 2011-06-10 Eli Zaretskii <eliz@gnu.org>
8781
8782 * window.h (resize_frame_windows, resize_window_check)
8783 (delete_deletable_window, resize_root_window)
8784 (resize_frame_windows): Declare prototypes.
8785
8786 * window.c (resize_window_apply): Make definition be "static" to
8787 match the prototype.
8788
8789 2011-06-10 Martin Rudalics <rudalics@gmx.at>
8790
8791 * window.c: Remove declarations of Qwindow_size_fixed,
8792 window_min_size_1, window_min_size_2, window_min_size,
8793 size_window, window_fixed_size_p, enlarge_window, delete_window.
8794 Remove static from declaration of Qdelete_window, it's
8795 temporarily needed by Fbury_buffer.
8796 (replace_window): Don't assign orig_top_line and
8797 orig_total_lines.
8798 (Fdelete_window, delete_window): Remove. Window deletion is
8799 handled by window.el.
8800 (window_loop): Remove DELETE_OTHER_WINDOWS case.
8801 Replace Fdelete_window calls with calls to Qdelete_window.
8802 (Fdelete_other_windows): Remove. Deleting other windows is
8803 handled by window.el.
8804 (window_fixed_size_p): Remove. Fixed-sizeness of windows is
8805 handled in window.el.
8806 (window_min_size_2, window_min_size_1, window_min_size): Remove.
8807 Window minimum sizes are handled in window.el.
8808 (shrink_windows, size_window, set_window_height)
8809 (set_window_width, change_window_heights, window_height)
8810 (window_width, CURBEG, CURSIZE, enlarge_window)
8811 (adjust_window_trailing_edge, Fadjust_window_trailing_edge)
8812 (Fenlarge_window, Fshrink_window): Remove. Window resizing is
8813 handled in window.el.
8814 (make_dummy_parent): Rename to make_parent_window and give it a
8815 second argument horflag.
8816 (make_window): Don't set resize_proportionally any more.
8817 (Fsplit_window): Remove. Windows are split in window.el.
8818 (save_restore_action, save_restore_orig_size)
8819 (shrink_window_lowest_first, save_restore_orig_size): Remove.
8820 Resize mini windows in window.el.
8821 (grow_mini_window, shrink_mini_window): Implement by calling
8822 Qresize_root_window_vertically, resize_window_check and
8823 resize_window_apply.
8824 (saved_window, Fset_window_configuration, save_window_save):
8825 Do not handle orig_top_line, orig_total_lines, and
8826 resize_proportionally.
8827 (window_min_height, window_min_width): Move to window.el.
8828 (keys_of_window): Move bindings for delete-other-windows,
8829 split-window, delete-window and enlarge-window to window.el.
8830
8831 * buffer.c: Temporarily extern Qdelete_window.
8832 (Fbury_buffer): Temporarily call Qdelete_window instead of
8833 Fdelete_window (Fbury_buffer will move to window.el soon).
8834
8835 * frame.c (set_menu_bar_lines_1): Remove code handling
8836 orig_top_line and orig_total_lines.
8837
8838 * dispnew.c (adjust_frame_glyphs_initially): Don't use
8839 set_window_height but set heights directly.
8840 (change_frame_size_1): Use resize_frame_windows.
8841
8842 * xdisp.c (init_xdisp): Don't use set_window_height but set
8843 heights directly.
8844
8845 * xfns.c (x_set_menu_bar_lines, x_set_tool_bar_lines):
8846 Use resize_frame_windows instead of change_window_heights and run
8847 run_window_configuration_change_hook.
8848
8849 * w32fns.c (x_set_tool_bar_lines): Use resize_frame_windows
8850 instead of change_window_heights and run
8851 run_window_configuration_change_hook.
8852
8853 2011-06-09 Martin Rudalics <rudalics@gmx.at>
8854
8855 * window.c (replace_window): Rename second argument REPLACEMENT to
8856 NEW. New third argument SETFLAG. Rewrite.
8857 (delete_window, make_dummy_parent): Call replace_window with
8858 third argument 1.
8859 (window_list_1): Move down in code.
8860 (run_window_configuration_change_hook): Move set_buffer part
8861 before select_frame_norecord part in order to unwind correctly.
8862 Rename count1 to count.
8863 (recombine_windows, delete_deletable_window, resize_root_window)
8864 (Fdelete_other_windows_internal)
8865 (Frun_window_configuration_change_hook, make_parent_window)
8866 (resize_window_check, resize_window_apply, Fresize_window_apply)
8867 (resize_frame_windows, Fsplit_window_internal)
8868 (Fdelete_window_internal, Fresize_mini_window_internal):
8869 New functions.
8870 (syms_of_window): New variables Vwindow_splits and Vwindow_nest.
8871
8872 2011-06-08 Martin Rudalics <rudalics@gmx.at>
8873
8874 * window.h (window): Add some new members to window structure -
8875 normal_lines, normal_cols, new_total, new_normal, clone_number,
8876 splits, nest, prev_buffers, next_buffers.
8877 (WINDOW_TOTAL_SIZE): Move here from window.c.
8878 (MIN_SAFE_WINDOW_WIDTH, MIN_SAFE_WINDOW_HEIGHT): Define here.
8879
8880 * window.c (Fwindow_height, Fwindow_width, Fwindow_full_width_p):
8881 Remove.
8882 (make_dummy_parent): Set new members of windows structure.
8883 (make_window): Move down in code. Handle new members of window
8884 structure.
8885 (Fwindow_clone_number, Fwindow_splits, Fset_window_splits)
8886 (Fwindow_nest, Fset_window_nest, Fwindow_new_total)
8887 (Fwindow_normal_size, Fwindow_new_normal, Fwindow_prev_buffers)
8888 (Fset_window_prev_buffers, Fwindow_next_buffers)
8889 (Fset_window_next_buffers, Fset_window_clone_number):
8890 New functions.
8891 (Fwindow_hscroll, Fwindow_at, Fwindow_point, Fwindow_start)
8892 (Fwindow_end, Fwindow_line_height, Fset_window_dedicated_p):
8893 Doc-string fixes.
8894 (Fwindow_parameters, Fwindow_parameter, Fset_window_parameter):
8895 Argument WINDOW can be now internal window too.
8896 (Fwindow_use_time): Move up in code.
8897 (Fget_buffer_window): Rename argument FRAME to ALL-FRAMES.
8898 Rewrite doc-string.
8899 (Fset_window_configuration, saved_window)
8900 (Fcurrent_window_configuration, save_window_save): Handle new
8901 members of window structure.
8902 (WINDOW_TOTAL_SIZE, MIN_SAFE_WINDOW_WIDTH)
8903 (MIN_SAFE_WINDOW_HEIGHT): Move to window.h.
8904 (syms_of_window): New Lisp objects Qrecord_window_buffer,
8905 Qwindow_deletable_p, Qdelete_window, Qreplace_buffer_in_windows,
8906 Qget_mru_window, Qresize_root_window,
8907 Qresize_root_window_vertically, Qsafe, Qabove, Qbelow,
8908 Qauto_buffer_name; staticpro them.
8909
8910 2011-06-07 Martin Rudalics <rudalics@gmx.at>
8911
8912 * window.c (Fwindow_total_size, Fwindow_left_column)
8913 (Fwindow_top_line, window_body_lines, Fwindow_body_size)
8914 (Fwindow_list_1): New functions.
8915 (window_box_text_cols): Replace with window_body_cols.
8916 (Fwindow_width, Fscroll_left, Fscroll_right):
8917 Use window_body_cols instead of window_box_text_cols.
8918 (delete_window, Fset_window_configuration):
8919 Call delete_all_subwindows with window as argument.
8920 (delete_all_subwindows): Take a window as argument and not a
8921 structure. Rewrite.
8922 (window_loop): Remove handling of GET_LRU_WINDOW and
8923 GET_LARGEST_WINDOW.
8924 (Fget_lru_window, Fget_largest_window): Move to window.el.
8925
8926 * window.h: Extern window_body_cols instead of
8927 window_box_text_cols. delete_all_subwindows now takes a
8928 Lisp_Object as argument.
8929
8930 * indent.c (compute_motion, Fcompute_motion):
8931 Use window_body_cols instead of window_box_text_cols.
8932
8933 * frame.c (delete_frame): Call delete_all_subwindows with root
8934 window as argument.
8935
8936 2011-06-07 Daniel Colascione <dan.colascione@gmail.com>
8937
8938 * fns.c (Fputhash): Document return value.
8939
8940 2011-06-06 Chong Yidong <cyd@stupidchicken.com>
8941
8942 * image.c (gif_load): Implement gif89a spec "no disposal" method.
8943
8944 2011-06-06 Paul Eggert <eggert@cs.ucla.edu>
8945
8946 Cons<->int and similar integer overflow fixes (Bug#8794).
8947
8948 Check for overflow when converting integer to cons and back.
8949 * charset.c (Fdefine_charset_internal, Fdecode_char):
8950 Use cons_to_unsigned to catch overflow.
8951 (Fencode_char): Use INTEGER_TO_CONS.
8952 * composite.h (LGLYPH_CODE): Use cons_to_unsigned.
8953 (LGLYPH_SET_CODE): Use INTEGER_TO_CONS.
8954 * data.c (long_to_cons, cons_to_long): Remove.
8955 (cons_to_unsigned, cons_to_signed): New functions.
8956 These signal an error for invalid or out-of-range values.
8957 * dired.c (Ffile_attributes): Use INTEGER_TO_CONS.
8958 * fileio.c (Fset_visited_file_modtime): Use CONS_TO_INTEGER.
8959 * font.c (Ffont_variation_glyphs):
8960 * fontset.c (Finternal_char_font): Use INTEGER_TO_CONS.
8961 * lisp.h: Include <intprops.h>.
8962 (INTEGER_TO_CONS, CONS_TO_INTEGER): New macros.
8963 (cons_to_signed, cons_to_unsigned): New decls.
8964 (long_to_cons, cons_to_long): Remove decls.
8965 * undo.c (record_first_change): Use INTEGER_TO_CONS.
8966 (Fprimitive_undo): Use CONS_TO_INTEGER.
8967 * xfns.c (Fx_window_property): Likewise.
8968 * xselect.c: Include <limits.h>.
8969 (x_own_selection, selection_data_to_lisp_data):
8970 Use INTEGER_TO_CONS.
8971 (x_handle_selection_request, x_handle_selection_clear)
8972 (x_get_foreign_selection, Fx_disown_selection_internal)
8973 (Fx_get_atom_name, x_send_client_event): Use CONS_TO_INTEGER.
8974 (lisp_data_to_selection_data): Use cons_to_unsigned.
8975 (x_fill_property_data): Use cons_to_signed.
8976 Report values out of range.
8977
8978 Check for buffer and string overflow more precisely.
8979 * buffer.h (BUF_BYTES_MAX): New macro.
8980 * lisp.h (STRING_BYTES_MAX): New macro.
8981 * alloc.c (Fmake_string):
8982 * character.c (string_escape_byte8):
8983 * coding.c (coding_alloc_by_realloc):
8984 * doprnt.c (doprnt):
8985 * editfns.c (Fformat):
8986 * eval.c (verror):
8987 Use STRING_BYTES_MAX, not MOST_POSITIVE_FIXNUM,
8988 since they may not be the same number.
8989 * editfns.c (Finsert_char):
8990 * fileio.c (Finsert_file_contents):
8991 Likewise for BUF_BYTES_MAX.
8992
8993 * image.c: Use ptrdiff_t, not int, for sizes.
8994 (slurp_file): Switch from int to ptrdiff_t.
8995 All uses changed.
8996 (slurp_file): Check that file size fits in both size_t (for
8997 malloc) and ptrdiff_t (for sanity and safety).
8998
8999 * fileio.c (Fverify_visited_file_modtime): Avoid time overflow
9000 if b->modtime has its maximal value.
9001
9002 * dired.c (Ffile_attributes): Don't assume EMACS_INT has >32 bits.
9003
9004 Don't assume time_t can fit into int.
9005 * buffer.h (struct buffer.modtime): Now time_t, not int.
9006 * fileio.c (Fvisited_file_modtime): No need for time_t cast now.
9007 * undo.c (Fprimitive_undo): Use time_t, not int, for time_t value.
9008
9009 Minor fixes for signed vs unsigned integers.
9010 * character.h (MAYBE_UNIFY_CHAR):
9011 * charset.c (maybe_unify_char):
9012 * keyboard.c (read_char, reorder_modifiers):
9013 XINT -> XFASTINT, since the integer must be nonnegative.
9014 * ftfont.c (ftfont_spec_pattern):
9015 * keymap.c (access_keymap, silly_event_symbol_error):
9016 XUINT -> XFASTINT, since the integer must be nonnegative.
9017 (Fsingle_key_description, preferred_sequence_p): XUINT -> XINT,
9018 since it makes no difference and we prefer signed.
9019 * keyboard.c (record_char): Use XUINT when all the neighbors do.
9020 (access_keymap): NATNUMP -> INTEGERP, since the integer must be
9021 nonnegative.
9022
9023 2011-06-06 Stefan Monnier <monnier@iro.umontreal.ca>
9024
9025 * window.h (Fwindow_frame): Declare.
9026
9027 2011-06-06 Paul Eggert <eggert@cs.ucla.edu>
9028
9029 * alloc.c: Simplify handling of large-request failures (Bug#8800).
9030 (SPARE_MEMORY): Always define.
9031 (LARGE_REQUEST): Remove.
9032 (memory_full): Use SPARE_MEMORY rather than LARGE_REQUEST.
9033
9034 2011-06-06 Martin Rudalics <rudalics@gmx.at>
9035
9036 * lisp.h: Move EXFUNS for Fframe_root_window,
9037 Fframe_first_window and Fset_frame_selected_window to window.h.
9038
9039 * window.h: Move EXFUNS for Fframe_root_window,
9040 Fframe_first_window and Fset_frame_selected_window here from
9041 lisp.h.
9042
9043 * frame.c (Fwindow_frame, Fframe_first_window)
9044 (Fframe_root_window, Fframe_selected_window)
9045 (Fset_frame_selected_window): Move to window.c.
9046 (Factive_minibuffer_window): Move to minibuf.c.
9047 (Fother_visible_frames_p): New function.
9048
9049 * minibuf.c (Factive_minibuffer_window): Move here from frame.c.
9050
9051 * window.c (decode_window, decode_any_window): Move up in code.
9052 (Fwindowp, Fwindow_live_p): Rewrite doc-strings.
9053 (inhibit_frame_unsplittable): Remove unused variable.
9054 (Fwindow_buffer): Move up and rewrite doc-string.
9055 (Fwindow_parent, Fwindow_vchild, Fwindow_hchild, Fwindow_next)
9056 (Fwindow_prev): New functions.
9057 (Fwindow_frame): Move here from frame.c. Accept any window as
9058 argument.
9059 (Fframe_root_window, Fframe_first_window)
9060 (Fframe_selected_window): Move here from frame.c. Accept frame
9061 or arbitrary window as argument. Update doc-strings.
9062 (Fminibuffer_window): Move up in code.
9063 (Fwindow_minibuffer_p): Move up in code and simplify.
9064 (Fset_frame_selected_window): Move here from frame.c.
9065 Marginal rewrite.
9066 (Fselected_window, select_window, Fselect_window): Move up in
9067 code. Minor doc-string fixes.
9068
9069 2011-06-06 Paul Eggert <eggert@cs.ucla.edu>
9070
9071 * alloc.c (memory_full) [SYSTEM_MALLOC]: Port to MacOS (Bug#8800).
9072 Do not assume that spare memory exists; that assumption is valid
9073 only if SYSTEM_MALLOC.
9074 (LARGE_REQUEST): New macro, so that the issue of large requests
9075 is separated from the issue of spare memory.
9076
9077 2011-06-05 Andreas Schwab <schwab@linux-m68k.org>
9078
9079 * editfns.c (Fformat): Correctly handle zero flag with hexadecimal
9080 format. (Bug#8806)
9081
9082 * gtkutil.c (xg_get_default_scrollbar_width): Avoid warning.
9083
9084 * xfns.c (x_set_scroll_bar_default_width): Move declarations
9085 before statements.
9086
9087 2011-06-05 Jan Djärv <jan.h.d@swipnet.se>
9088
9089 * gtkutil.c (xg_get_default_scrollbar_width): New function.
9090
9091 * gtkutil.h: Declare xg_get_default_scrollbar_width.
9092
9093 * xfns.c (x_set_scroll_bar_default_width): If USE_GTK, get
9094 min width by calling x_set_scroll_bar_default_width (Bug#8505).
9095
9096 2011-06-05 Juanma Barranquero <lekktu@gmail.com>
9097
9098 * xdisp.c (single_display_spec_intangible_p): Remove declaration.
9099
9100 2011-06-04 Chong Yidong <cyd@stupidchicken.com>
9101
9102 * xselect.c (x_clipboard_manager_save): Remove redundant arg.
9103 (x_clipboard_manager_save): Add return value.
9104 (x_clipboard_manager_error_1, x_clipboard_manager_error_2):
9105 New error handlers.
9106 (x_clipboard_manager_save_frame, x_clipboard_manager_save_all):
9107 Obey Vx_select_enable_clipboard_manager. Catch errors in
9108 x_clipboard_manager_save (Bug#8779).
9109 (Vx_select_enable_clipboard_manager): New variable.
9110 (x_get_foreign_selection): Reduce scope of x_catch_errors (Bug#8790).
9111
9112 2011-06-04 Dan Nicolaescu <dann@ics.uci.edu>
9113
9114 * emacs.c (main): Warn when starting a GTK emacs in daemon mode.
9115
9116 2011-06-04 YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
9117
9118 * fringe.c (update_window_fringes): Don't update overlay arrow bitmap
9119 in the current matrix if keep_current_p is non-zero.
9120
9121 2011-06-04 Eli Zaretskii <eliz@gnu.org>
9122
9123 * bidi.c (bidi_level_of_next_char): Fix last change.
9124
9125 2011-06-03 Eli Zaretskii <eliz@gnu.org>
9126
9127 Support bidi reordering of text covered by display properties.
9128
9129 * bidi.c (bidi_copy_it): Use offsetof instead of emulating it.
9130 (bidi_fetch_char, bidi_fetch_char_advance): New functions.
9131 (bidi_cache_search, bidi_cache_iterator_state)
9132 (bidi_paragraph_init, bidi_resolve_explicit, bidi_resolve_weak)
9133 (bidi_level_of_next_char, bidi_move_to_visually_next):
9134 Support character positions inside a run of characters covered by a
9135 display string.
9136 (bidi_paragraph_init, bidi_resolve_explicit_1)
9137 (bidi_level_of_next_char): Call bidi_fetch_char and
9138 bidi_fetch_char_advance instead of FETCH_CHAR and
9139 FETCH_CHAR_ADVANCE.
9140 (bidi_init_it): Initialize new members.
9141 (LRE_CHAR, RLE_CHAR, PDF_CHAR, LRO_CHAR, RLO_CHAR): Remove macro
9142 definitions.
9143 (bidi_explicit_dir_char): Lookup character type in bidi_type_table,
9144 instead of using explicit *_CHAR codes.
9145 (bidi_resolve_explicit, bidi_resolve_weak):
9146 Use FETCH_MULTIBYTE_CHAR instead of FETCH_CHAR, as reordering of
9147 bidirectional text is supported only in multibyte buffers.
9148 (bidi_init_it): Accept additional argument FRAME_WINDOW_P and use
9149 it to initialize the frame_window_p member of struct bidi_it.
9150 (bidi_cache_iterator_state, bidi_resolve_explicit_1)
9151 (bidi_resolve_explicit, bidi_resolve_weak)
9152 (bidi_level_of_next_char, bidi_move_to_visually_next): Abort if
9153 bidi_it->nchars is non-positive.
9154 (bidi_level_of_next_char): Don't try to lookup the cache for the
9155 next/previous character if nothing is cached there yet, or if we
9156 were just reseat()'ed to a new position.
9157
9158 * xdisp.c (set_cursor_from_row): Set start and stop points
9159 according to the row's direction when priming the loop that looks
9160 for the glyph on which to display cursor.
9161 (single_display_spec_intangible_p): Function deleted.
9162 (display_prop_intangible_p): Reimplement to call
9163 handle_display_spec instead of single_display_spec_intangible_p.
9164 Accept 3 additional arguments needed by handle_display_spec.
9165 This fixes incorrect cursor motion across display property with complex
9166 values: lists, `(when COND...)' forms, etc.
9167 (single_display_spec_string_p): Support property values that are
9168 lists with the argument STRING its top-level element.
9169 (display_prop_string_p): Fix the condition for processing a
9170 property that is a list to be consistent with handle_display_spec.
9171 (handle_display_spec): New function, refactored from the
9172 last portion of handle_display_prop.
9173 (compute_display_string_pos): Accept additional argument
9174 FRAME_WINDOW_P. Call handle_display_spec to determine whether the
9175 value of a `display' property is a "replacing spec".
9176 (handle_single_display_spec): Accept 2 additional arguments BUFPOS
9177 and FRAME_WINDOW_P. If IT is NULL, don't set up the iterator from
9178 the display property, but just return a value indicating whether
9179 the display property will replace the characters it covers.
9180 (Fcurrent_bidi_paragraph_direction): Initialize the nchars and
9181 frame_window_p members of struct bidi_it.
9182 (compute_display_string_pos, compute_display_string_end):
9183 New functions.
9184 (push_it): Accept second argument POSITION, where pop_it should
9185 jump to continue iteration.
9186 (reseat_1): Initialize bidi_it.disp_pos.
9187
9188 * keyboard.c (adjust_point_for_property): Adjust the call to
9189 display_prop_intangible_p to its new signature.
9190
9191 * dispextern.h (struct bidi_it): New member frame_window_p.
9192 (bidi_init_it): Update prototypes.
9193 (display_prop_intangible_p): Update prototype.
9194 (compute_display_string_pos, compute_display_string_end):
9195 Declare prototypes.
9196 (struct bidi_it): New members nchars and disp_pos. ch_len is now
9197 EMACS_INT.
9198
9199 2011-06-02 Paul Eggert <eggert@cs.ucla.edu>
9200
9201 Malloc failure behavior now depends on size of allocation.
9202 * alloc.c (buffer_memory_full, memory_full): New arg NBYTES.
9203 * lisp.h: Change signatures accordingly.
9204 * alloc.c, buffer.c, editfns.c, menu.c, minibuf.c, xterm.c:
9205 All callers changed. (Bug#8762)
9206
9207 * gnutls.c: Use Emacs's memory allocators.
9208 Without this change, the gnutls library would invoke malloc etc.
9209 directly, which causes problems on non-SYNC_INPUT hosts, and which
9210 runs afoul of improving memory_full behavior. (Bug#8761)
9211 (fn_gnutls_global_set_mem_functions): New macro or function pointer.
9212 (emacs_gnutls_global_init): Use it to specify xmalloc, xrealloc,
9213 xfree instead of the default malloc, realloc, free.
9214 (Fgnutls_boot): No need to check for memory allocation failure,
9215 since xmalloc does that for us.
9216
9217 Remove arbitrary limit of 2**31 entries in hash tables. (Bug#8771)
9218 * category.c (hash_get_category_set):
9219 * ccl.c (ccl_driver):
9220 * charset.c (Fdefine_charset_internal):
9221 * charset.h (struct charset.hash_index):
9222 * composite.c (get_composition_id, gstring_lookup_cache)
9223 (composition_gstring_put_cache):
9224 * composite.h (struct composition.hash_index):
9225 * dispextern.h (struct image.hash):
9226 * fns.c (next_almost_prime, larger_vector, cmpfn_eql)
9227 (cmpfn_equal, cmpfn_user_defined, hashfn_eq, hashfn_eql)
9228 (hashfn_equal, hashfn_user_defined, make_hash_table)
9229 (maybe_resize_hash_table, hash_lookup, hash_put)
9230 (hash_remove_from_table, hash_clear, sweep_weak_table, SXHASH_COMBINE)
9231 (sxhash_string, sxhash_list, sxhash_vector, sxhash_bool_vector)
9232 (Fsxhash, Fgethash, Fputhash, Fmaphash):
9233 * image.c (make_image, search_image_cache, lookup_image)
9234 (xpm_put_color_table_h):
9235 * lisp.h (struct Lisp_Hash_Table):
9236 * minibuf.c (Ftry_completion, Fall_completions, Ftest_completion):
9237 * print.c (print): Use 'EMACS_UINT' and 'EMACS_INT'
9238 for hashes and hash indexes, instead of 'unsigned' and 'int'.
9239 * alloc.c (allocate_vectorlike):
9240 Check for overflow in vector size calculations.
9241 * ccl.c (ccl_driver):
9242 Check for overflow when converting EMACS_INT to int.
9243 * fns.c, image.c: Remove unnecessary static decls that would otherwise
9244 need to be updated by these changes.
9245 * fns.c (make_hash_table, maybe_resize_hash_table):
9246 Check for integer overflow with large hash tables.
9247 (make_hash_table, maybe_resize_hash_table, Fmake_hash_table):
9248 Prefer the faster XFLOAT_DATA to XFLOATINT where either will do.
9249 (SXHASH_REDUCE): New macro.
9250 (sxhash_string, sxhash_list, sxhash_vector, sxhash_bool_vector):
9251 Use it instead of discarding useful hash info with large hash values.
9252 (sxhash_float): New function.
9253 (sxhash): Use it. No more need for "& INTMASK" due to above changes.
9254 * lisp.h (FIXNUM_BITS): New macro, useful for SXHASH_REDUCE etc.
9255 (MOST_NEGATIVE_FIXNUM, MOST_POSITIVE_FIXNUM, INTMASK):
9256 Rewrite to use FIXNUM_BITS, as this simplifies things.
9257 (next_almost_prime, larger_vector, sxhash, hash_lookup, hash_put):
9258 Adjust signatures to match updated version of code.
9259 (consing_since_gc): Now EMACS_INT, since a single hash table can
9260 use more than INT_MAX bytes.
9261
9262 2011-06-01 Dan Nicolaescu <dann@ics.uci.edu>
9263
9264 Make it possible to build with GCC-4.6+ -O2 -flto.
9265
9266 * emacs.c (__malloc_initialize_hook): Mark as EXTERNALLY_VISIBLE.
9267
9268 2011-06-01 Stefan Monnier <monnier@iro.umontreal.ca>
9269
9270 * minibuf.c (get_minibuffer, read_minibuf_unwind):
9271 Call minibuffer-inactive-mode.
9272
9273 2011-05-31 Juanma Barranquero <lekktu@gmail.com>
9274
9275 * makefile.w32-in ($(BLD)/data.$(O), $(BLD)/editfns.$(O)):
9276 Update dependencies.
9277
9278 2011-05-31 Dan Nicolaescu <dann@ics.uci.edu>
9279
9280 * data.c (init_data): Remove code for UTS, this system is not
9281 supported anymore.
9282
9283 2011-05-31 Dan Nicolaescu <dann@ics.uci.edu>
9284
9285 Don't force ./temacs to start in terminal mode.
9286
9287 * frame.c (make_initial_frame): Initialize faces in all cases, not
9288 only when CANNOT_DUMP is defined.
9289 * dispnew.c (init_display): Remove CANNOT_DUMP condition.
9290
9291 2011-05-31 Dan Nicolaescu <dann@ics.uci.edu>
9292
9293 * dispnew.c (add_window_display_history): Use const for the string
9294 pointer. Remove declaration, not needed.
9295
9296 2011-05-31 Paul Eggert <eggert@cs.ucla.edu>
9297
9298 Use 'inline', not 'INLINE'.
9299 <http://lists.gnu.org/archive/html/emacs-devel/2011-05/msg00914.html>
9300 * alloc.c, fontset.c (INLINE): Remove.
9301 * alloc.c, bidi.c, charset.c, coding.c, dispnew.c, fns.c, image.c:
9302 * intervals.c, keyboard.c, process.c, syntax.c, textprop.c, w32term.c:
9303 * xdisp.c, xfaces.c, xterm.c: Replace all uses of INLINE with inline.
9304 * gmalloc.c (register_heapinfo): Use inline unconditionally.
9305 * lisp.h (LISP_MAKE_RVALUE): Use inline, not __inline__.
9306
9307 2011-05-31 Dan Nicolaescu <dann@ics.uci.edu>
9308
9309 Make it possible to run ./temacs.
9310
9311 * callproc.c (set_initial_environment): Remove CANNOT_DUMP code,
9312 syms_of_callproc does the same thing. Remove test for
9313 "initialized", do it in the caller.
9314 * emacs.c (main): Avoid calling set_initial_environment when dumping.
9315
9316 2011-05-31 Stefan Monnier <monnier@iro.umontreal.ca>
9317
9318 * minibuf.c (Finternal_complete_buffer): Return `category' metadata.
9319 (read_minibuf): Use get_minibuffer.
9320 (syms_of_minibuf): Use DEFSYM.
9321 (Qmetadata): New var.
9322 * data.c (Qbuffer): Don't make it static.
9323 (syms_of_data): Use DEFSYM.
9324
9325 2011-05-31 Paul Eggert <eggert@cs.ucla.edu>
9326
9327 * ccl.c (CCL_CODE_RANGE): Allow negative numbers. (Bug#8751)
9328 (CCL_CODE_MIN): New macro.
9329
9330 2011-05-30 Paul Eggert <eggert@cs.ucla.edu>
9331
9332 * alloc.c (lisp_align_malloc): Omit unnecessary val==NULL tests.
9333
9334 * eval.c (Qdebug): Now static.
9335 * lisp.h (Qdebug): Remove decl. This reverts a part of the
9336 2011-04-26T11:26:05Z!dan.colascione@gmail.com that inadvertently undid part of
9337 2011-04-14T06:48:41Z!eggert@cs.ucla.edu.
9338
9339 2011-05-29 Chong Yidong <cyd@stupidchicken.com>
9340
9341 * image.c: Various fixes to ImageMagick code comments.
9342 (Fimagemagick_types): Doc fix.
9343
9344 2011-05-29 Paul Eggert <eggert@cs.ucla.edu>
9345
9346 Minor fixes prompted by GCC 4.6.0 warnings.
9347
9348 * xselect.c (converted_selections, conversion_fail_tag): Now static.
9349
9350 * emacs.c [HAVE_X_WINDOWS]: Include "xterm.h".
9351 (x_clipboard_manager_save_all): Move extern decl to ...
9352 * xterm.h: ... here, so that it can be checked for consistency.
9353
9354 2011-05-29 Chong Yidong <cyd@stupidchicken.com>
9355
9356 * xselect.c (x_clipboard_manager_save_frame)
9357 (x_clipboard_manager_save_all): New functions.
9358 (Fx_clipboard_manager_save): Lisp function deleted.
9359
9360 * emacs.c (Fkill_emacs): Call x_clipboard_manager_save_all.
9361 * frame.c (delete_frame): Call x_clipboard_manager_save_frame.
9362
9363 * xterm.h: Update prototype.
9364
9365 2011-05-28 William Xu <william.xwl@gmail.com>
9366
9367 * nsterm.m (ns_term_shutdown): Synchronize user defaults before
9368 exiting (Bug#8239).
9369
9370 2011-05-28 Jim Meyering <meyering@redhat.com>
9371
9372 Avoid a sign-extension bug in crypto_hash_function.
9373 * fns.c (to_uchar): Define.
9374 (crypto_hash_function): Use it to convert some newly-signed
9375 variables to unsigned, to avoid sign-extension bugs. For example,
9376 without this change, (md5 "truc") would evaluate to
9377 45723a2aff78ff4fff7fff1114760e62 rather than the expected
9378 45723a2af3788c4ff17f8d1114760e62. Reported by Antoine Levitt in
9379 https://lists.gnu.org/archive/html/emacs-devel/2011-05/msg00883.html.
9380
9381 2011-05-27 Paul Eggert <eggert@cs.ucla.edu>
9382
9383 Integer overflow fixes.
9384
9385 * dbusbind.c: Serial number integer overflow fixes.
9386 (CHECK_DBUS_SERIAL_GET_SERIAL): New macro.
9387 (Fdbus_call_method_asynchronously, xd_read_message_1): Use a float
9388 to hold a serial number that is too large for a fixnum.
9389 (Fdbus_method_return_internal, Fdbus_method_error_internal):
9390 Check for serial numbers out of range. Decode any serial number
9391 that was so large that it became a float. (Bug#8722)
9392
9393 * dbusbind.c: Use XFASTINT rather than XUINT, and check for nonneg.
9394 (Fdbus_call_method, Fdbus_call_method_asynchronously):
9395 Use XFASTINT rather than XUINT when numbers are nonnegative.
9396 (xd_append_arg, Fdbus_method_return_internal):
9397 (Fdbus_method_error_internal): Likewise. Also, for unsigned
9398 arguments, check that Lisp number is nonnegative, rather than
9399 silently wrapping negative numbers around. (Bug#8722)
9400 (xd_read_message_1): Don't assume dbus_uint32_t can fit in int.
9401 (Bug#8722)
9402
9403 * data.c (arith_driver, Flsh): Avoid unnecessary casts to EMACS_UINT.
9404
9405 * ccl.c (ccl_driver): Redo slightly to avoid the need for 'unsigned'.
9406
9407 ccl: Add integer overflow checks.
9408 * ccl.c (CCL_CODE_MAX, GET_CCL_RANGE, GET_CCL_CODE, GET_CCL_INT):
9409 (IN_INT_RANGE): New macros.
9410 (ccl_driver): Use them to check for integer overflow when
9411 decoding a CCL program. Many of the new checks are whether XINT (x)
9412 fits in int; it doesn't always, on 64-bit hosts. The new version
9413 doesn't catch all possible integer overflows, but it's an
9414 improvement. (Bug#8719)
9415
9416 * alloc.c (make_event_array): Use XINT, not XUINT.
9417 There's no need for unsigned here.
9418
9419 * mem-limits.h (EXCEEDS_LISP_PTR) [!USE_LSB_TAG]: EMACS_UINT -> uintptr_t
9420 This follows up to the 2011-05-06 change that substituted uintptr_t
9421 for EMACS_INT. This case wasn't caught back then.
9422
9423 Rework Fformat to avoid integer overflow issues.
9424 * editfns.c: Include <float.h> unconditionally, as it's everywhere
9425 now (part of C89). Include <verify.h>.
9426 (MAX_10_EXP, CONVERTED_BYTE_SIZE): Remove; no longer needed.
9427 (pWIDE, pWIDElen, signed_wide, unsigned_wide): New defns.
9428 (Fformat): Avoid the prepass trying to compute sizes; it was only
9429 approximate and thus did not catch overflow reliably. Instead, walk
9430 through the format just once, formatting and computing sizes as we go,
9431 checking for integer overflow at every step, and allocating a larger
9432 buffer as needed. Keep track separately whether the format is
9433 multibyte. Keep only the most-recently calculated precision, rather
9434 than them all. Record whether each argument has been converted to
9435 string. Use EMACS_INT, not int, for byte and char and arg counts.
9436 Support field widths and precisions larger than INT_MAX. Avoid
9437 sprintf's undefined behavior with conversion specifications such as %#d
9438 and %.0c. Fix bug with strchr succeeding on '\0' when looking for
9439 flags. Fix bug with (format "%c" 256.0). Avoid integer overflow when
9440 formatting out-of-range floating point numbers with int
9441 formats. (Bug#8668)
9442
9443 * lisp.h (FIXNUM_OVERFLOW_P): Work even if arg is a NaN.
9444
9445 * data.c: Avoid integer truncation in expressions involving floats.
9446 * data.c: Include <intprops.h>.
9447 (arith_driver): When there's an integer overflow in an expression
9448 involving floating point, convert the integers to floating point
9449 so that the resulting value does not suffer from catastrophic
9450 integer truncation. For example, on a 64-bit host (* 4
9451 most-negative-fixnum 0.5) should yield about -4.6e+18, not zero.
9452 Do not rely on undefined behavior after integer overflow.
9453
9454 merge count_size_as_multibyte, parse_str_to_multibyte
9455 * character.c, character.h (count_size_as_multibyte):
9456 Rename from parse_str_to_multibyte; all uses changed.
9457 Check for integer overflow.
9458 * insdel.c, lisp.h (count_size_as_multibyte): Remove,
9459 since it's now a duplicate of the other. This is more of
9460 a character than a buffer op, so better that it's in character.c.
9461 * fns.c, print.c: Adjust to above changes.
9462
9463 2011-05-27 Stefan Monnier <monnier@iro.umontreal.ca>
9464
9465 * xselect.c (x_convert_selection): Yet another int/Lisp_Object mixup.
9466
9467 2011-05-27 Paul Eggert <eggert@cs.ucla.edu>
9468
9469 * xselect.c: Fix minor problems prompted by GCC 4.6.0 warnings.
9470 (x_handle_selection_request, frame_for_x_selection): Remove unused vars.
9471 (x_clipboard_manager_save): Now static.
9472 (Fx_clipboard_manager_save): Rename local to avoid shadowing.
9473
9474 * fns.c: Fix minor problems prompted by GCC 4.6.0 warnings.
9475 (crypto_hash_function): Now static.
9476 Fix pointer signedness problems. Avoid unnecessary initializations.
9477
9478 2011-05-27 Chong Yidong <cyd@stupidchicken.com>
9479
9480 * termhooks.h (Vselection_alist): Make it terminal-local.
9481
9482 * terminal.c (create_terminal): Initialize it.
9483
9484 * xselect.c: Support for clipboard managers.
9485 (Vselection_alist): Move to termhooks.h as terminal-local var.
9486 (LOCAL_SELECTION): New macro.
9487 (x_atom_to_symbol): Handle x_display_info_for_display fail case.
9488 (symbol_to_x_atom): Remove gratuitous arg.
9489 (x_handle_selection_request, lisp_data_to_selection_data)
9490 (x_get_foreign_selection, Fx_register_dnd_atom): Callers changed.
9491 (x_own_selection, x_get_local_selection, x_convert_selection):
9492 New arg, specifying work frame. Use terminal-local Vselection_alist.
9493 (some_frame_on_display): Delete unused function.
9494 (Fx_own_selection_internal, Fx_get_selection_internal)
9495 (Fx_disown_selection_internal, Fx_selection_owner_p)
9496 (Fx_selection_exists_p): New optional frame arg.
9497 (frame_for_x_selection, Fx_clipboard_manager_save): New functions.
9498 (x_handle_selection_clear): Don't treat other terminals with the
9499 same keyboard specially. Use the terminal-local Vselection_alist.
9500 (x_clear_frame_selections): Use Frun_hook_with_args.
9501
9502 * xterm.c (x_term_init): Intern ATOM and CLIPBOARD_MANAGER atoms.
9503
9504 * xterm.h: Add support for those atoms.
9505
9506 2011-05-26 Chong Yidong <cyd@stupidchicken.com>
9507
9508 * xselect.c: ICCCM-compliant handling of MULTIPLE targets.
9509 (converted_selections, conversion_fail_tag): New global variables.
9510 (x_selection_request_lisp_error): Free the above.
9511 (x_get_local_selection): Remove unnecessary code.
9512 (x_reply_selection_request): Args changed; handle arbitrary array
9513 of converted selections stored in converted_selections.
9514 Separate the XChangeProperty and SelectionNotify steps.
9515 (x_handle_selection_request): Rewrite to handle MULTIPLE target.
9516 (x_convert_selection): New function.
9517 (x_handle_selection_event): Simplify.
9518 (x_get_foreign_selection): Don't ignore incoming requests while
9519 waiting for an answer; this will fail when we implement
9520 SAVE_TARGETS, and seems unnecessary anyway.
9521 (selection_data_to_lisp_data): Recognize ATOM_PAIR type.
9522 (Vx_sent_selection_functions): Doc fix.
9523
9524 2011-05-26 Leo Liu <sdl.web@gmail.com>
9525
9526 * editfns.c (Ftranspose_regions): Allow empty regions. (Bug#8699)
9527
9528 2011-05-25 YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
9529
9530 * dispextern.h (struct glyph_row): New member fringe_bitmap_periodic_p.
9531
9532 * dispnew.c (shift_glyph_matrix, scrolling_window): Mark scrolled row
9533 for fringe update if it has periodic bitmap.
9534 (row_equal_p): Also compare left_fringe_offset, right_fringe_offset,
9535 and fringe_bitmap_periodic_p.
9536
9537 * fringe.c (get_fringe_bitmap_data): New function.
9538 (draw_fringe_bitmap_1, update_window_fringes): Use it.
9539 (update_window_fringes): Record periodicity of fringe bitmap in glyph
9540 row. Mark glyph row for fringe update if periodicity changed.
9541
9542 * xdisp.c (try_window_reusing_current_matrix): Don't mark scrolled row
9543 for fringe update unless it has periodic bitmap.
9544
9545 2011-05-25 Kenichi Handa <handa@m17n.org>
9546
9547 * xdisp.c (get_next_display_element): Set correct it->face_id for
9548 a static composition.
9549
9550 2011-05-24 Leo Liu <sdl.web@gmail.com>
9551
9552 * deps.mk (fns.o):
9553 * makefile.w32-in ($(BLD)/fns.$(O)): Include sha1.h.
9554
9555 * fns.c (crypto_hash_function, Fsha1): New function.
9556 (Fmd5): Use crypto_hash_function.
9557 (syms_of_fns): Add Ssha1.
9558
9559 2011-05-22 Paul Eggert <eggert@cs.ucla.edu>
9560
9561 * gnutls.c: Remove unused macros.
9562 (fn_gnutls_transport_set_lowat, fn_gnutls_transport_set_pull_function):
9563 (fn_gnutls_transport_set_push_function) [!WINDOWSNT]:
9564 Remove macros that are defined and never used.
9565 Caught by gcc -Wunused-macros (GCC 4.6.0, Fedora 14).
9566
9567 2011-05-22 Chong Yidong <cyd@stupidchicken.com>
9568
9569 * xselect.c (syms_of_xselect): Remove unused symbol SAVE_TARGETS.
9570 (Fx_get_selection_internal): Minor cleanup.
9571 (Fx_own_selection_internal): Rename arguments for consistency with
9572 select.el.
9573
9574 2011-05-22 Paul Eggert <eggert@cs.ucla.edu>
9575
9576 * xselect.c (QSAVE_TARGETS): New static var, to fix build failure.
9577
9578 2011-05-22 Chong Yidong <cyd@stupidchicken.com>
9579
9580 * xselect.c (syms_of_xselect): Include character.h; use DEFSYM.
9581
9582 2011-05-21 YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
9583
9584 * dispnew.c (scrolling_window): Don't exclude the case that the
9585 last enabled row in the desired matrix touches the bottom boundary.
9586
9587 2011-05-21 Glenn Morris <rgm@gnu.org>
9588
9589 * Makefile.in ($(etc)/DOC): Make second command line even shorter.
9590 (SOME_MACHINE_OBJECTS): Replace FONT_OBJ by its maximal expansion,
9591 and add some more files.
9592
9593 2011-05-20 Eli Zaretskii <eliz@gnu.org>
9594
9595 * callproc.c (Fcall_process) [MSDOS]: Fix arguments to
9596 report_file_error introduced by the change from 2011-05-07.
9597
9598 2011-05-20 Paul Eggert <eggert@cs.ucla.edu>
9599
9600 * systime.h (Time): Define only if emacs is defined.
9601 This is to allow ../lib-src/profile.c to be compiled on FreeBSD,
9602 where the include path doesn't have X11/X.h by default. See
9603 <http://lists.gnu.org/archive/html/emacs-devel/2011-05/msg00561.html>.
9604
9605 2011-05-20 Kenichi Handa <handa@m17n.org>
9606
9607 * composite.c (find_automatic_composition): Fix previous change.
9608
9609 2011-05-20 Glenn Morris <rgm@gnu.org>
9610
9611 * lisp.mk: New file, split from Makefile.in.
9612 * Makefile.in (lisp): Move to separate file, inserted by @lisp_frag@.
9613 (shortlisp): Remove.
9614 ($(etc)/DOC): Edit lisp.mk rather than using $shortlisp.
9615
9616 2011-05-19 Glenn Morris <rgm@gnu.org>
9617
9618 * Makefile.in (MSDOS_SUPPORT_REAL, MSDOS_SUPPORT, NS_SUPPORT)
9619 (REAL_MOUSE_SUPPORT, GPM_MOUSE_SUPPORT, MOUSE_SUPPORT, TOOLTIP_SUPPORT)
9620 (BASE_WINDOW_SUPPORT, X_WINDOW_SUPPORT, WINDOW_SUPPORT): Remove.
9621 (lisp): Set the order to that of loadup.el.
9622 (shortlisp): Make it a copy of $lisp.
9623 (SOME_MACHINE_LISP): Remove.
9624 ($(etc)/DOC): Depend just on $lisp, not $SOME_MACHINE_LISP too.
9625 Use just $shortlisp, not $SOME_MACHINE_LISP too.
9626
9627 2011-05-18 Kenichi Handa <handa@m17n.org>
9628
9629 * composite.c (CHAR_COMPOSABLE_P): Add more check for efficiency.
9630 (BACKWARD_CHAR): Wrap the arg STOP by parenthesis.
9631 (find_automatic_composition): Mostly rewrite for efficiency.
9632
9633 2011-05-18 Juanma Barranquero <lekktu@gmail.com>
9634
9635 * makefile.w32-in: Update dependencies.
9636
9637 2011-05-18 Christoph Scholtes <cschol2112@googlemail.com>
9638
9639 * menu.c: Include limits.h (fixes the MS-Windows build broken by
9640 2011-06-18T18:49:19Z!cyd@stupidchicken.com).
9641
9642 2011-05-18 Paul Eggert <eggert@cs.ucla.edu>
9643
9644 Fix some integer overflow issues, such as string length overflow.
9645
9646 * insdel.c (count_size_as_multibyte): Check for string overflow.
9647
9648 * character.c (lisp_string_width): Check for string overflow.
9649 Use EMACS_INT, not int, for string indexes and lengths; in
9650 particular, 2nd arg is now EMACS_INT, not int. Do not crash if
9651 the resulting string length overflows an EMACS_INT; instead,
9652 report a string overflow if no precision given. When checking for
9653 precision exhaustion, use a check that cannot possibly have
9654 integer overflow. (Bug#8675)
9655 * character.h (lisp_string_width): Adjust to new signature.
9656
9657 * alloc.c (string_overflow): New function.
9658 (Fmake_string): Use it. This doesn't change behavior, but saves
9659 a few bytes and will simplify future changes.
9660 * character.c (string_escape_byte8): Likewise.
9661 * lisp.h (string_overflow): New decl.
9662
9663 Fixups, following up to the user-interface timestamp change.
9664 * nsterm.m (last_mouse_movement_time, ns_mouse_position): Use Time
9665 for UI timestamps, instead of unsigned long.
9666 * msdos.c (mouse_get_pos): Likewise.
9667 * w32inevt.c (movement_time, w32_console_mouse_position): Likewise.
9668 * w32gui.h (Time): Define by including "systime.h" rather than by
9669 declaring it ourselves. (Bug#8664)
9670
9671 * dispextern.h (struct image): Don't assume time_t <= unsigned long.
9672 * image.c (clear_image_cache): Likewise.
9673
9674 * term.c (term_mouse_position): Don't assume time_t wraparound.
9675
9676 Be more systematic about user-interface timestamps.
9677 Before, the code sometimes used 'Time', sometimes 'unsigned long',
9678 and sometimes 'EMACS_UINT', to represent these timestamps.
9679 This change causes it to use 'Time' uniformly, as that's what X uses.
9680 This makes the code easier to follow, and makes it easier to catch
9681 integer overflow bugs such as Bug#8664.
9682 * frame.c (Fmouse_position, Fmouse_pixel_position):
9683 Use Time, not unsigned long, for user-interface timestamps.
9684 * keyboard.c (last_event_timestamp, kbd_buffer_get_event): Likewise.
9685 (button_down_time, make_lispy_position, make_lispy_movement): Likewise.
9686 * keyboard.h (last_event_timestamp): Likewise.
9687 * menu.c (Fx_popup_menu) [!HAVE_X_WINDOWS]: Likewise.
9688 * menu.h (xmenu_show): Likewise.
9689 * term.c (term_mouse_position): Likewise.
9690 * termhooks.h (struct input_event.timestamp): Likewise.
9691 (struct terminal.mouse_position_hook): Likewise.
9692 * xmenu.c (create_and_show_popup_menu, xmenu_show): Likewise.
9693 * xterm.c (XTmouse_position, x_scroll_bar_report_motion): Likewise.
9694 * systime.h (Time): New decl. Pull it in from <X11/X.h> if
9695 HAVE_X_WINDOWS, otherwise define it as unsigned long, which is
9696 what it was before.
9697 * menu.h, termhooks.h: Include "systime.h", for Time.
9698
9699 * keyboard.c (make_lispy_event): Fix problem in integer overflow.
9700 Don't assume that the difference between two unsigned long values
9701 can fit into an integer. At this point, we know button_down_time
9702 <= event->timestamp, so the difference must be nonnegative, so
9703 there's no need to cast the result if double-click-time is
9704 nonnegative, as it should be; check that it's nonnegative, just in
9705 case. This bug is triggered when events are more than 2**31 ms
9706 apart (about 25 days). (Bug#8664)
9707
9708 * xselect.c (last_event_timestamp): Remove duplicate decl.
9709 (x_own_selection): Remove needless cast to unsigned long.
9710
9711 * xmenu.c (set_frame_menubar): Use int, not EMACS_UINT, for indexes
9712 that always fit in int. Use a sentinel instead of a counter, to
9713 avoid a temp and to allay GCC's concerns about possible int overflow.
9714 * frame.h (struct frame): Use int for menu_bar_items_used
9715 instead of EMACS_INT, since it always fits in int.
9716
9717 * menu.c (grow_menu_items): Check for int overflow.
9718
9719 * xmenu.c (set_frame_menubar): Don't mishandle vectors with no nils.
9720
9721 * xterm.c: Use EMACS_INT for Emacs modifiers, and int for X modifiers.
9722 Before, the code was not consistent. These values cannot exceed
9723 2**31 - 1 so there's no need to make them unsigned.
9724 (x_x_to_emacs_modifiers): Accept int and return EMACS_INT.
9725 (x_emacs_to_x_modifiers): Accept EMACS_INT and return int.
9726 (x_x_to_emacs_modifiers, x_emacs_to_x_modifiers): Reject non-integers
9727 as modifiers.
9728 * xterm.h (x_x_to_emacs_modifiers): Adjust to signature change.
9729
9730 * lisp.h (XINT) [USE_LISP_UNION_TYPE]: Cast to EMACS_INT.
9731 (XUINT) [USE_LISP_UNION_TYPE]: Cast to EMACS_UINT.
9732 Otherwise, GCC 4.6.0 warns about printf (pI, XINT (...)),
9733 presumably because the widths might not match.
9734
9735 * window.c (size_window): Avoid needless test at loop start.
9736
9737 2011-05-18 Courtney Bane <emacs-bugs-7626@cbane.org> (tiny change)
9738
9739 * term.c (Fresume_tty): Restore hooks before reinitializing (bug#8687).
9740
9741 2011-05-12 Drew Adams <drew.adams@oracle.com>
9742
9743 * textprop.c (Fprevious_single_char_property_change): Doc fix (bug#8655).
9744
9745 2011-05-12 YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
9746
9747 * w32term.c (w32_draw_fringe_bitmap): Rename local vars `left' and
9748 `width' to `bar_area_x' and `bar_area_width', respectively.
9749 (x_scroll_run): Take account of fringe background extension.
9750
9751 * xterm.c (x_draw_fringe_bitmap) [USE_TOOLKIT_SCROLL_BARS]:
9752 Rename local vars `left' and `width' to `bar_area_x' and
9753 `bar_area_width', respectively.
9754 (x_scroll_run) [USE_TOOLKIT_SCROLL_BARS]: Take account of fringe
9755 background extension.
9756
9757 2011-05-10 Jim Meyering <meyering@redhat.com>
9758
9759 * xdisp.c (x_intersect_rectangles): Fix typo "the the -> the".
9760
9761 2011-05-10 Juanma Barranquero <lekktu@gmail.com>
9762
9763 * image.c (Finit_image_library): Return t for built-in image types,
9764 like pbm and xbm. (Bug#8640)
9765
9766 2011-05-09 Andreas Schwab <schwab@linux-m68k.org>
9767
9768 * w32menu.c (set_frame_menubar): Fix submenu allocation.
9769
9770 2011-05-07 Eli Zaretskii <eliz@gnu.org>
9771
9772 * w32console.c (Fset_screen_color): Doc fix.
9773 (Fget_screen_color): New function.
9774 (syms_of_ntterm): Defsubr it.
9775
9776 * callproc.c (call_process_cleanup) [MSDOS]: Don't close and
9777 unlink the temporary file if Fcall_process didn't create it in the
9778 first place.
9779 (Fcall_process) [MSDOS]: Don't create tempfile if stdout of the
9780 child process will be redirected to a file specified with `:file'.
9781 Don't try to re-open tempfile in that case, and set fd[0] to -1 as
9782 cue to call_process_cleanup not to close that handle.
9783
9784 2011-05-07 Ben Key <bkey76@gmail.com>
9785
9786 * makefile.w32-in: The bootstrap-temacs rule now makes use of
9787 one of two shell specific rules, either bootstrap-temacs-CMD or
9788 bootstrap-temacs-SH. The bootstrap-temacs-SH rule is identical
9789 to the previous implementation of the bootstrap-temacs rule.
9790 The bootstrap-temacs-CMD rule is similar to the previous
9791 implementation of the bootstrap-temacs rule except that it
9792 makes use of the ESC_CFLAGS variable instead of the CFLAGS
9793 variable.
9794
9795 These changes, along with some changes to nt/configure.bat,
9796 nt/gmake.defs, and nt/nmake.defs, are required to extend my
9797 earlier fix to add support for --cflags and --ldflags options
9798 that include quotes so that it works whether make uses cmd or
9799 sh as the shell.
9800
9801 2011-05-06 Michael Albinus <michael.albinus@gmx.de>
9802
9803 * dbusbind.c (QCdbus_type_unix_fd): Declare static.
9804 (xd_remove_watch): Don't check QCdbus_type_unix_fd for SYMBOLP, it
9805 is a constant.
9806 (Fdbus_init_bus, xd_read_queued_messages): Bus can be a symbol or
9807 a string. Handle both cases.
9808 (Fdbus_call_method_asynchronously, Fdbus_register_signal)
9809 (Fdbus_register_method): Use Qinvalid_function.
9810
9811 2011-05-06 Juanma Barranquero <lekktu@gmail.com>
9812
9813 * makefile.w32-in: Update dependencies.
9814 (LISP_H): Add inttypes.h and stdin.h.
9815 (PROCESS_H): Add unistd.h.
9816
9817 2011-05-06 Eli Zaretskii <eliz@gnu.org>
9818
9819 * lread.c: Include limits.h (fixes the MS-Windows build broken by
9820 2011-05-06T07:13:19Z!eggert@cs.ucla.edu).
9821
9822 2011-05-06 Paul Eggert <eggert@cs.ucla.edu>
9823
9824 * image.c (Finit_image_library) [!HAVE_NTGUI]: Omit unused local.
9825
9826 * term.c (vfatal): Remove stray call to va_end.
9827 It's not needed and the C Standard doesn't allow it here anyway.
9828
9829 Use C99's va_copy to avoid undefined behavior on x86-64 GNU/Linux.
9830 * eval.c (verror): doprnt a copy of ap, not the original. (Bug#8545)
9831
9832 * eval.c (verror): OK to create a string of up to MOST_POSITIVE_FIXNUM
9833 bytes.
9834
9835 * term.c: Don't include <stdarg.h>, as <lisp.h> does that.
9836
9837 * callproc.c (Fcall_process): Use 'volatile' to avoid vfork clobbering.
9838
9839 * process.c (Fformat_network_address): Fix typo: args2 -> *args2.
9840
9841 * xmenu.c (set_frame_menubar): Fix typo: int * -> int (3 times).
9842
9843 * coding.c (detect_coding_charset): Fix typo: * 2 -> *4 (Bug#8601).
9844
9845 * charset.h (struct charset.code_space): Now has 15 elements, not 16.
9846 * charset.c (Fdefine_charset_internal): Don't initialize
9847 charset.code_space[15]. The value was garbage, on hosts with
9848 32-bit int (Bug#8600).
9849
9850 * lread.c (read_integer): Be more consistent with string-to-number.
9851 Use string_to_number to do the actual conversion; this avoids
9852 rounding errors and fixes some other screwups. Without this fix,
9853 for example, #x1fffffffffffffff was misread as -2305843009213693952.
9854 (digit_to_number): Move earlier, for benefit of read_integer.
9855 Return -1 if the digit is out of range for the base, -2 if it is
9856 not a digit in any supported base. (Bug#8602)
9857
9858 * doprnt.c (doprnt): Support arbitrary pI values, such as "I64".
9859
9860 * dispnew.c (scrolling_window): Return 1 if we scrolled,
9861 to match comment at start of function. This also removes a
9862 GCC warning about overflow in a 32+64-bit port.
9863
9864 * lisp.h (EMACS_INT, EMACS_UINT, BITS_PER_EMACS_INT, pI): Simplify.
9865
9866 * dbusbind.c: Do not use XPNTR on a value that may be an integer.
9867 Reported by Stefan Monnier in
9868 <http://lists.gnu.org/archive/html/emacs-devel/2011-04/msg00919.html>.
9869 (xd_remove_watch, Fdbus_init_bus, xd_read_queued_messages):
9870 Use SYMBOLP-guarded XSYMBOL, not XPNTR.
9871
9872 * lisp.h (EMACS_INTPTR): Remove. All uses changed to intptr_t.
9873 (EMACS_UINTPTR): Likewise, with uintptr_t.
9874
9875 * lisp.h: Prefer 64-bit EMACS_INT if available.
9876 (EMACS_INT, EMACS_UINT, BITS_PER_EMACS_INT, pI): Define to 64-bit
9877 on 32-bit hosts that have 64-bit int, so that they can access
9878 large files.
9879 However, temporarily disable this change unless the temporary
9880 symbol WIDE_EMACS_INT is defined.
9881
9882 * lread.c, process.c: Do not include <inttypes.h>; lisp.h does it now.
9883
9884 Prefer intptr_t/uintptr_t for integers the same widths as pointers.
9885 This removes an assumption that EMACS_INT and long are the same
9886 width as pointers. The assumption is true for Emacs porting targets
9887 now, but we want to make other targets possible.
9888 * lisp.h: Include <inttypes.h>, for INTPTR_MAX, UINTPTR_MAX.
9889 (EMACS_INTPTR, EMACS_UINTPTR): New macros.
9890 In the rest of the code, change types of integers that hold casted
9891 pointers to EMACS_INTPTR and EMACS_UINTPTR, systematically
9892 replacing EMACS_INT, long, EMACS_UINT, and unsigned long.
9893 (XTYPE): Don't cast arg to EMACS_UINT; normally is not needed.
9894 (XSET): Cast type of XTYPE arg to EMACS_INTPTR; it is needed here.
9895 No need to cast type when ORing.
9896 (XPNTR): Return a value of type EMACS_INTPTR or EMACS_UINTPTR.
9897 * alloc.c (lisp_align_malloc): Remove a no-longer-needed cast.
9898 * doc.c (store_function_docstring): Use EMACS_INTPTR, so as not to
9899 assume EMACS_INT is the same width as char *.
9900 * gtkutil.c (xg_gtk_scroll_destroy, xg_tool_bar_button_cb):
9901 (xg_tool_bar_callback, xg_tool_bar_help_callback, xg_make_tool_item):
9902 Remove no-longer-needed casts.
9903 (xg_create_scroll_bar, xg_tool_bar_button_cb, xg_tool_bar_callback):
9904 (xg_tool_bar_help_callback, xg_make_tool_item):
9905 Use EMACS_INTPTR to hold an integer
9906 that will be cast to void *; this can avoid a GCC warning
9907 if EMACS_INT is not the same width as void *.
9908 * menu.c (find_and_call_menu_selection): Remove no-longer-needed cast.
9909 * xdisp.c (display_echo_area_1, resize_mini_window_1):
9910 (current_message_1, set_message_1):
9911 Use a local to convert to proper width without a cast.
9912 * xmenu.c (dialog_selection_callback): Likewise.
9913
9914 * sysdep.c (get_random): Don't assume EMACS_INT is no wider than long.
9915 Also, don't assume VALBITS / RAND_BITS is less than 5,
9916 and don't rely on undefined behavior when shifting a 1 left into
9917 the sign bit.
9918 * lisp.h (get_random): Change signature to match.
9919
9920 * lread.c (hash_string): Use size_t, not int, for hash computation.
9921 Normally we prefer signed values; but hashing is special, because
9922 it's better to use unsigned division on hash table sizes so that
9923 the remainder is nonnegative. Also, size_t is the natural width
9924 for hashing into memory. The previous code used 'int', which doesn't
9925 retain enough info to hash well into very large tables.
9926 (oblookup, oblookup_last_bucket_number, Funintern): Likewise.
9927
9928 * dbusbind.c: Don't possibly lose pointer info when converting.
9929 (xd_remove_watch, Fdbus_init_bus, xd_read_queued_messages):
9930 Use XPNTR rather than XHASH, so that the high-order bits of
9931 the pointer aren't lost when converting through void *.
9932
9933 * eval.c (Fautoload): Don't double-shift a pointer.
9934
9935 * fns.c (Frandom): Let EMACS_UINT be wider than unsigned long.
9936
9937 2011-05-06 Juanma Barranquero <lekktu@gmail.com>
9938
9939 * gnutls.c (DEF_GNUTLS_FN):
9940 * image.c (DEF_IMGLIB_FN): Make function pointers static.
9941
9942 2011-05-05 Andreas Schwab <schwab@linux-m68k.org>
9943
9944 * lread.c (lisp_file_lexically_bound_p): Stop scanning at end
9945 marker. (Bug#8610)
9946
9947 2011-05-05 Eli Zaretskii <eliz@gnu.org>
9948
9949 * w32heap.c (allocate_heap) [USE_LISP_UNION_TYPE || USE_LSB_TAG]:
9950 New version that can reserve upto 2GB of heap space.
9951
9952 2011-05-05 Chong Yidong <cyd@stupidchicken.com>
9953
9954 * nsfns.m (Fns_read_file_name): Doc fix (Bug#8534).
9955
9956 2011-05-05 Teodor Zlatanov <tzz@lifelogs.com>
9957
9958 * gnutls.c (fn_gnutls_certificate_set_x509_key_file): Add alias to
9959 `gnutls_certificate_set_x509_key_file'.
9960
9961 2011-05-05 Juanma Barranquero <lekktu@gmail.com>
9962
9963 * makefile.w32-in ($(BLD)/image.$(O), $(BLD)/process.$(O)):
9964 Update dependencies.
9965
9966 2011-05-04 Juanma Barranquero <lekktu@gmail.com>
9967
9968 * gnutls.h (emacs_gnutls_write, emacs_gnutls_read):
9969 * gnutls.c (emacs_gnutls_write, emacs_gnutls_read):
9970 Remove unused parameter `fildes'.
9971 * process.c (read_process_output, send_process): Don't pass it.
9972
9973 2011-05-04 Juanma Barranquero <lekktu@gmail.com>
9974
9975 Fix previous change: the library cache is defined in w32.c.
9976 * image.c (CACHE_IMAGE_TYPE) [!HAVE_NTGUI]: Define to noop.
9977 (Finit_image_library): Wrap Vlibrary_cache on "#ifdef HAVE_NTGUI".
9978
9979 2011-05-04 Juanma Barranquero <lekktu@gmail.com>
9980
9981 Implement dynamic loading of GnuTLS on Windows.
9982
9983 * gnutls.h (GNUTLS_EMACS_ERROR_NOT_LOADED): New macro.
9984 (emacs_gnutls_write, emacs_gnutls_read): Mark as extern.
9985 (emacs_gnutls_record_check_pending, emacs_gnutls_transport_set_errno):
9986 Declare.
9987
9988 * gnutls.c (Qgnutls_dll): Define.
9989 (DEF_GNUTLS_FN, LOAD_GNUTLS_FN): New macros.
9990 (gnutls_*): Declare function pointers.
9991 (init_gnutls_functions): New function to initialize function pointers.
9992 (emacs_gnutls_handshake, Fgnutls_error_string, Fgnutls_deinit)
9993 (emacs_gnutls_global_init, Fgnutls_bye): Use function pointers.
9994 (emacs_gnutls_record_check_pending, emacs_gnutls_transport_set_errno):
9995 Wrappers for gnutls_record_check_pending and gnutls_transport_set_errno.
9996 (emacs_gnutls_write, emacs_gnutls_read)
9997 (emacs_gnutls_handle_error, Fgnutls_error_fatalp)
9998 (Fgnutls_available_p): New function.
9999 (Fgnutls_boot): Call Fgnutls_available_p. Use function pointers.
10000 (syms_of_gnutls) <Qgnutls_dll>: Initialize and staticpro it.
10001 (syms_of_gnutls) <Sgnutls_available_p>: defsubr it.
10002
10003 * image.c: Include w32.h.
10004 (Vimage_type_cache): Delete.
10005 (syms_of_image) <Vimage_type_cache>: Don't initialize and staticpro it.
10006 (CACHE_IMAGE_TYPE, Finit_image_library): Use Vlibrary_cache instead.
10007 (w32_delayed_load): Move to w32.c.
10008
10009 * w32.h (VlibraryCache, QCloaded_from, w32_delayed_load): Declare.
10010
10011 * w32.c (QCloaded_from, Vlibrary_cache): Define.
10012 (w32_delayed_load): Move from image.c. When loading a library, record
10013 its filename in the :loaded-from property of the library id.
10014 (globals_of_w32) <QCloaded_from, Vlibrary_cache>:
10015 Initialize and staticpro them.
10016 (emacs_gnutls_pull, emacs_gnutls_push): Call emacs_gnutls_* functions.
10017
10018 * process.c: Include lisp.h before w32.h, not after.
10019 (wait_reading_process_output): Call emacs_gnutls_record_check_pending
10020 instead of gnutls_record_check_pending.
10021
10022 * callproc.c, emacs.c: Include lisp.h before w32.h, not after.
10023
10024 2011-05-04 Teodor Zlatanov <tzz@lifelogs.com>
10025
10026 * gnutls.c (Fgnutls_boot): Support :keylist and :crlfiles options
10027 instead of :keyfiles. Give GnuTLS the keylist and the CRL lists
10028 as passed in.
10029
10030 2011-05-03 Jan Djärv <jan.h.d@swipnet.se>
10031
10032 * xterm.c (x_set_frame_alpha): Do not set property on anything
10033 else than FRAME_X_OUTER_WINDOW (Bug#8608).
10034
10035 2011-05-02 Juanma Barranquero <lekktu@gmail.com>
10036
10037 * sysdep.c (get_tty_size) [WINDOWSNT]: Implement. (Bug#8596)
10038
10039 2011-05-02 Juanma Barranquero <lekktu@gmail.com>
10040
10041 * gnutls.c (Qgnutls_log_level, Qgnutls_code, Qgnutls_anon)
10042 (Qgnutls_x509pki, Qgnutls_e_interrupted, Qgnutls_e_again)
10043 (Qgnutls_e_invalid_session, Qgnutls_e_not_ready_for_handshake)
10044 (gnutls_global_initialized, Qgnutls_bootprop_priority)
10045 (Qgnutls_bootprop_trustfiles, Qgnutls_bootprop_keyfiles)
10046 (Qgnutls_bootprop_callbacks, Qgnutls_bootprop_loglevel)
10047 (Qgnutls_bootprop_hostname, Qgnutls_bootprop_verify_flags)
10048 (Qgnutls_bootprop_verify_error, Qgnutls_bootprop_verify_hostname_error)
10049 (Qgnutls_bootprop_callbacks_verify): Make static.
10050
10051 2011-05-01 Andreas Schwab <schwab@linux-m68k.org>
10052
10053 * callproc.c: Indentation fixup.
10054
10055 * sysdep.c (wait_for_termination_1): Make static.
10056 (wait_for_termination, interruptible_wait_for_termination):
10057 Move after wait_for_termination_1.
10058
10059 2011-05-01 Lars Magne Ingebrigtsen <larsi@gnus.org>
10060
10061 * sysdep.c (interruptible_wait_for_termination): New function
10062 which is like wait_for_termination, but allows keyboard
10063 interruptions.
10064
10065 * callproc.c (Fcall_process): Add (:file "file") as an option for
10066 the STDOUT buffer.
10067 (Fcall_process_region): Ditto.
10068
10069 2011-04-30 Eli Zaretskii <eliz@gnu.org>
10070
10071 * dosfns.c (Fint86, Fdos_memget, Fdos_memput): Use `ASIZE (FOO)'
10072 rather than `XVECTOR (FOO)->size'.
10073
10074 * process.c: Remove HAVE_INTTYPES_H condition from inclusion of
10075 inttypes.h, as a gnulib replacement is used if it not available in
10076 system headers.
10077
10078 2011-04-21 Eli Zaretskii <eliz@gnu.org>
10079
10080 Lift the MOST_POSITIVE_FIXNUM/4 limitation on visited files.
10081 * fileio.c (Finsert_file_contents): Don't limit file size to 1/4
10082 of MOST_POSITIVE_FIXNUM. (Bug#8528)
10083
10084 * coding.c (coding_alloc_by_realloc): Error out if destination
10085 will grow beyond MOST_POSITIVE_FIXNUM.
10086 (decode_coding_emacs_mule): Abort if there isn't enough place in
10087 charbuf for the composition carryover bytes. Reserve an extra
10088 space for up to 2 characters produced in a loop.
10089 (decode_coding_iso_2022): Abort if there isn't enough place in
10090 charbuf for the composition carryover bytes.
10091
10092 2011-04-21 Eli Zaretskii <eliz@gnu.org>
10093
10094 * doprnt.c (doprnt) [!HAVE_LONG_LONG_INT]: Error out instead of
10095 aborting when %lld or %lll format is passed.
10096 [!HAVE_UNSIGNED_LONG_LONG_INT]: Error out instead of aborting when
10097 %llo or %llx format is passed. (Bug#8545)
10098
10099 * window.c (window_scroll_line_based): Use a marker instead of
10100 simple variables to record original value of point. (Bug#7952)
10101
10102 * doprnt.c (doprnt): Fix the case where a multibyte sequence
10103 produced by %s or %c overflows available buffer space. (Bug#8545)
10104
10105 2011-04-28 Paul Eggert <eggert@cs.ucla.edu>
10106
10107 * doprnt.c (doprnt): Omit useless test; int overflow check (Bug#8545).
10108 (SIZE_MAX): Move defn after all includes, as they might #define it.
10109
10110 2011-04-28 Juanma Barranquero <lekktu@gmail.com>
10111
10112 * w32.c (init_environment): Warn about defaulting HOME to C:\.
10113
10114 2011-04-28 Juanma Barranquero <lekktu@gmail.com>
10115
10116 * keyboard.c (Qdelayed_warnings_hook): Define.
10117 (command_loop_1): Run `delayed-warnings-hook'
10118 if Vdelayed_warnings_list is non-nil.
10119 (syms_of_keyboard) <delayed-warnings-hook>: DEFSYM it.
10120 (syms_of_keyboard) <delayed-warnings-list>: DEFVAR_LISP it.
10121
10122 2011-04-28 Eli Zaretskii <eliz@gnu.org>
10123
10124 * doprnt.c (doprnt): Don't return value smaller than the buffer
10125 size if the message was truncated. (Bug#8545).
10126
10127 2011-04-28 Juanma Barranquero <lekktu@gmail.com>
10128
10129 * w32fns.c (Fx_change_window_property, Fx_delete_window_property)
10130 (Fx_window_property): #if-0 the whole functions, not just the bodies.
10131
10132 2011-04-27 Paul Eggert <eggert@cs.ucla.edu>
10133
10134 * doprnt.c (doprnt): Support "ll" length modifier, for long long.
10135
10136 2011-04-27 Juanma Barranquero <lekktu@gmail.com>
10137
10138 * makefile.w32-in: Update dependencies.
10139
10140 2011-04-27 Eli Zaretskii <eliz@gnu.org>
10141
10142 Improve `doprnt' and its usage. (Bug#8545)
10143 * doprnt.c (doprnt): Make sure `format' is never accessed beyond
10144 `format_end'. Remove support for %l as a conversion specifier.
10145 Don't use xrealloc. Improve diagnostics when the %l size modifier
10146 is used. Update the commentary.
10147
10148 * eval.c (verror): Simplify calculation of size_t.
10149
10150 * coding.c (Ffind_operation_coding_system): Fix diagnostic error
10151 messages.
10152
10153 2011-04-27 Yoshiaki Kasahara <kasahara@nc.kyushu-u.ac.jp> (tiny change)
10154
10155 * buffer.c (init_buffer) [USE_MMAP_FOR_BUFFERS]: Adjust to aliasing
10156 change.
10157
10158 2011-04-27 Paul Eggert <eggert@cs.ucla.edu>
10159
10160 * nsmenu.m: Replace all uses of XVECTOR with ASIZE and AREF.
10161 This makes this file independent of the recent pseudovector change.
10162
10163 2011-04-26 Paul Eggert <eggert@cs.ucla.edu>
10164
10165 * keyboard.c (handle_user_signal): Fix pointer signedness problem.
10166
10167 * gnutls.c (emacs_gnutls_handle_error): Remove unused local.
10168 (Fgnutls_boot): gnutls_certificate_verify_peers2 wants unsigned *.
10169 Remove unused local.
10170 (emacs_gnutls_write): Don't use uninitialized rtnval if nbyte <= 0.
10171
10172 * lisp.h: Fix a problem with aliasing and vector headers. (Bug#8546)
10173 GCC 4.6.0 optimizes based on type-based alias analysis.
10174 For example, if b is of type struct buffer * and v of type struct
10175 Lisp_Vector *, then gcc -O2 was incorrectly assuming that &b->size
10176 != &v->size, and therefore "v->size = 1; b->size = 2; return
10177 v->size;" must therefore return 1. This assumption is incorrect
10178 for Emacs, since it type-puns struct Lisp_Vector * with many other
10179 types. To fix this problem, this patch adds a new type struct
10180 vectorlike_header that documents the constraints on layout of vectors
10181 and pseudovectors, and helps optimizing compilers not get fooled
10182 by Emacs's type punning. It also adds the macros XSETTYPED_PVECTYPE
10183 XSETTYPED_PSEUDOVECTOR, TYPED_PSEUDOVECTORP, for similar reasons.
10184 * lisp.h (XSETTYPED_PVECTYPE): New macro, specifying the name of
10185 the size member.
10186 (XSETPVECTYPE): Rewrite in terms of new macro.
10187 (XSETPVECTYPESIZE): New macro, specifying both type and size.
10188 This is a bit clearer, and further avoids the possibility of
10189 undesirable aliasing.
10190 (XSETTYPED_PSEUDOVECTOR): New macro, specifying the size.
10191 (XSETPSEUDOVECTOR): Rewrite in terms of XSETTYPED_PSEUDOVECTOR.
10192 (XSETSUBR): Rewrite in terms of XSETTYPED_PSEUDOVECTOR and XSIZE,
10193 since Lisp_Subr is a special case (no "next" field).
10194 (ASIZE): Now uses header.size rather than size.
10195 All previous uses of XVECTOR (foo)->size replaced to use this macro,
10196 to avoid the hassle of writing XVECTOR (foo)->header.size.
10197 (struct vectorlike_header): New type.
10198 (TYPED_PSEUDOVECTORP): New macro, also specifying the C type of the
10199 object, to help avoid aliasing.
10200 (PSEUDOVECTORP): Rewrite in terms of TYPED_PSEUDOVECTORP.
10201 (SUBRP): Likewise, since Lisp_Subr is a special case.
10202 * lisp.h (struct Lisp_Vector, struct Lisp_Char_Table):
10203 (struct Lisp_Sub_Char_Table, struct Lisp_Bool_Vector):
10204 (struct Lisp_Hash_Table): Combine first two members into a single
10205 struct vectorlike_header member. All uses of "size" and "next" members
10206 changed to be "header.size" and "header.next".
10207 * buffer.h (struct buffer): Likewise.
10208 * font.h (struct font_spec, struct font_entity, struct font): Likewise.
10209 * frame.h (struct frame): Likewise.
10210 * process.h (struct Lisp_Process): Likewise.
10211 * termhooks.h (struct terminal): Likewise.
10212 * window.c (struct save_window_data, struct saved_window): Likewise.
10213 * window.h (struct window): Likewise.
10214 * alloc.c (allocate_buffer, Fmake_bool_vector, allocate_pseudovector):
10215 Use XSETPVECTYPESIZE, not XSETPVECTYPE, to avoid aliasing problems.
10216 * buffer.c (init_buffer_once): Likewise.
10217 * lread.c (defsubr): Use XSETTYPED_PVECTYPE, since Lisp_Subr is a
10218 special case.
10219 * process.c (Fformat_network_address): Use local var for size,
10220 for brevity.
10221
10222 * bytecode.c (exec_byte_code): Don't use XVECTOR before CHECK_VECTOR.
10223
10224 Make the Lisp reader and string-to-float more consistent (Bug#8525)
10225 * data.c (atof): Remove decl; no longer used or needed.
10226 (digit_to_number): Move to lread.c.
10227 (Fstring_to_number): Use new string_to_number function, to be
10228 consistent with how the Lisp reader treats infinities and NaNs.
10229 Do not assume that floating-point numbers represent EMACS_INT
10230 without losing information; this is not true on most 64-bit hosts.
10231 Avoid double-rounding errors, by insisting on integers when
10232 parsing non-base-10 numbers, as the documentation specifies.
10233 * lisp.h (string_to_number): New decl, replacing ...
10234 (isfloat_string): Remove.
10235 * lread.c: Include <inttypes.h>, for uintmax_t and strtoumax.
10236 (read1): Do not accept +. and -. as integers; this
10237 appears to have been a coding error. Similarly, do not accept
10238 strings like +-1e0 as floating point numbers. Do not report
10239 overflow for integer overflows unless the base is not 10 which
10240 means we have no simple and reliable way to continue.
10241 Break out the floating-point parsing into a new
10242 function string_to_number, so that Fstring_to_number parses
10243 floating point numbers consistently with the Lisp reader.
10244 (digit_to_number): Move here from data.c. Make it static inline.
10245 (E_CHAR, EXP_INT): Remove, replacing with ...
10246 (E_EXP): New macro, to solve the "1.0e+" problem mentioned below.
10247 (string_to_number): New function, replacing isfloat_string.
10248 This function checks for valid syntax and produces the resulting
10249 Lisp float number too. Rework it so that string-to-number
10250 no longer mishandles examples like "1.0e+". Use strtoumax,
10251 so that overflow for non-base-10 numbers is reported only when
10252 there's no portable and simple way to convert to floating point.
10253
10254 * textprop.c (set_text_properties_1): Rewrite for clarity,
10255 and to avoid GCC warning about integer overflow.
10256
10257 * intervals.h (struct interval): Use EMACS_INT for members
10258 where EMACS_UINT might cause problems. See
10259 <http://lists.gnu.org/archive/html/emacs-devel/2011-04/msg00514.html>.
10260 (CHECK_TOTAL_LENGTH): Remove cast to EMACS_INT; no longer needed.
10261 * intervals.c (interval_deletion_adjustment): Now returns EMACS_INT.
10262 All uses changed.
10263 (offset_intervals): Tell GCC not to worry about length overflow
10264 when negating a negative length.
10265
10266 * alloc.c (overrun_check_malloc, overrun_check_realloc): Now static.
10267 (overrun_check_free): Likewise.
10268
10269 * alloc.c (SDATA_SIZE) [!GC_CHECK_STRING_BYTES]: Avoid runtime check
10270 in the common case where SDATA_DATA_OFFSET is a multiple of Emacs
10271 word size.
10272
10273 * gnutls.c: Fix problems found by GCC 4.6.0 on Ubuntu 10.10.
10274 (gnutls_make_error): Rename local to avoid shadowing.
10275 (gnutls_emacs_global_deinit): ifdef out; not used.
10276 (Fgnutls_boot): Use const for pointer to readonly storage.
10277 Comment out unused local. Fix pointer signedness problems.
10278
10279 * lread.c (openp): Don't stuff size_t into an 'int'.
10280 Use <= on length, not < on length + 1, to avoid GCC 4.6.0 warning
10281 about possible signed overflow.
10282
10283 * gtkutil.c: Fix problems found by GCC 4.6.0 on Ubuntu 10.10.
10284 (GDK_KEY_g): Don't define if already defined.
10285 (xg_prepare_tooltip): Avoid pointer signedness problem.
10286 (xg_set_toolkit_scroll_bar_thumb): Redo to avoid two casts.
10287
10288 * process.c (Fnetwork_interface_info): Avoid left-shift undefined
10289 behavior with 1 << 31. GCC 4.6.0 warns about this on 32-bit hosts.
10290
10291 * xfns.c (Fx_window_property): Simplify a bit,
10292 to make a bit faster and to avoid GCC 4.6.0 warning.
10293 * xselect.c (x_get_window_property, x_handle_dnd_message): Likewise.
10294
10295 * fns.c (internal_equal): Don't assume size_t fits in int.
10296
10297 * alloc.c (compact_small_strings): Tighten assertion a little.
10298
10299 Replace pEd with more-general pI, and fix some printf arg casts.
10300 * lisp.h (pI): New macro, generalizing old pEd macro to other
10301 conversion specifiers. For example, use "...%"pI"d..." rather
10302 than "...%"pEd"...".
10303 (pEd): Remove. All uses replaced with similar uses of pI.
10304 * m/amdx86-64.h, m/ia64.h, m/ibms390x.h: Likewise.
10305 * alloc.c (check_pure_size): Don't overflow by converting size to int.
10306 * bidi.c (bidi_dump_cached_states): Use pI to avoid cast.
10307 * data.c (Fnumber_to_string): Use pI instead of if-then-else-abort.
10308 * dbusbind.c (xd_append_arg): Use pI to avoid cast.
10309 (Fdbus_method_return_internal, Fdbus_method_error_internal): Likewise.
10310 * font.c (font_unparse_xlfd): Avoid potential buffer overrun on
10311 64-bit hosts.
10312 (font_unparse_xlfd, font_unparse_fcname): Use pI to avoid casts.
10313 * keyboard.c (record_char, modify_event_symbol): Use pI to avoid casts.
10314 * print.c (safe_debug_print, print_object): Likewise.
10315 (print_object): Don't overflow by converting EMACS_INT or EMACS_UINT
10316 to int.
10317 Use pI instead of if-then-else-abort. Use %p to avoid casts,
10318 avoiding the 0 flag, which is not portable.
10319 * process.c (Fmake_network_process): Use pI to avoid cast.
10320 * region-cache.c (pp_cache): Likewise.
10321 * xdisp.c (decode_mode_spec): Likewise.
10322 * xrdb.c (x_load_resources) [USE_MOTIF]: Use pI to avoid undefined
10323 behavior on 64-bit hosts with printf arg.
10324 * xselect.c (x_queue_event): Use %p to avoid casts, avoiding 0 flag.
10325 (x_stop_queuing_selection_requests): Likewise.
10326 (x_get_window_property): Don't truncate byte count to an 'int'
10327 when tracing.
10328
10329 * frame.c (frame_name_fnn_p): Get rid of strtol, which isn't right
10330 here, since it parses constructs like leading '-' and spaces,
10331 which are not wanted; and it overflows with large numbers.
10332 Instead, simply match F[0-9]+, which is what is wanted anyway.
10333
10334 * alloc.c: Remove unportable assumptions about struct layout.
10335 (SDATA_SELECTOR, SDATA_DATA_OFFSET): New macros.
10336 (SDATA_OF_STRING, SDATA_SIZE, allocate_string_data):
10337 (allocate_vectorlike, make_pure_vector): Use the new macros,
10338 plus offsetof, to remove unportable assumptions about struct layout.
10339 These assumptions hold on all porting targets that I know of, but
10340 they are not guaranteed, they're easy to remove, and removing them
10341 makes further changes easier.
10342
10343 * alloc.c (BLOCK BYTES): Fix typo by changing "ablock" to "ablocks".
10344 This doesn't fix a bug but makes the code clearer.
10345 (string_overrun_cookie): Now const. Use initializers that
10346 don't formally overflow signed char, to avoid warnings.
10347 (allocate_string_data) [GC_CHECK_STRING_OVERRUN]: Fix typo that
10348 can cause Emacs to crash when string overrun checking is enabled.
10349 (allocate_buffer): Don't assume sizeof (struct buffer) is a
10350 multiple of sizeof (EMACS_INT); it need not be, if
10351 alignof(EMACS_INT) < sizeof (EMACS_INT).
10352 (check_sblock, check_string_bytes, check_string_free_list): Protoize.
10353
10354 2011-04-26 Juanma Barranquero <lekktu@gmail.com>
10355
10356 * keyboard.c (QCrtl): Rename from Qrtl. All uses changed.
10357
10358 2011-04-26 Teodor Zlatanov <tzz@lifelogs.com>
10359
10360 * gnutls.c (emacs_gnutls_handshake): Return an error if we're not
10361 supposed to be handshaking. (Bug#8556)
10362 Reported by Paul Eggert <eggert@cs.ucla.edu>.
10363
10364 2011-04-26 Daniel Colascione <dan.colascione@gmail.com>
10365
10366 * lisp.h (Qdebug): List symbol.
10367 * eval.c (Qdebug): Restore global linkage.
10368 * keyboard.c (debug-on-event): New variable.
10369 (handle_user_signal): Break into debugger when debug-on-event
10370 matches the current signal symbol.
10371
10372 2011-04-25 Dan Nicolaescu <dann@ics.uci.edu>
10373
10374 * alloc.c (check_sblock, check_string_bytes)
10375 (check_string_free_list): Convert to standard C.
10376
10377 2011-04-25 Teodor Zlatanov <tzz@lifelogs.com>
10378
10379 * w32.c (emacs_gnutls_push): Fix typo.
10380
10381 2011-04-25 Eli Zaretskii <eliz@gnu.org>
10382
10383 * gnutls.c (emacs_gnutls_handshake): Avoid compiler warnings about
10384 "cast to pointer from integer of different size".
10385
10386 Improve doprnt and its use in verror. (Bug#8545)
10387 * doprnt.c (doprnt): Document the set of format control sequences
10388 supported by the function. Use SAFE_ALLOCA instead of always
10389 using `alloca'.
10390
10391 * eval.c (verror): Don't limit the buffer size at size_max-1, that
10392 is one byte too soon. Don't use xrealloc; instead xfree and
10393 xmalloc anew.
10394
10395 2011-04-24 Teodor Zlatanov <tzz@lifelogs.com>
10396
10397 * gnutls.h: Add GNUTLS_STAGE_CALLBACKS enum to denote we're in the
10398 callbacks stage.
10399
10400 * gnutls.c: Renamed global_initialized to
10401 gnutls_global_initialized. Added internals for the
10402 :verify-hostname-error, :verify-error, and :verify-flags
10403 parameters of `gnutls-boot' and documented those parameters in the
10404 docstring. Start callback support.
10405 (emacs_gnutls_handshake): Add Woe32 support. Retry handshake
10406 unless a fatal error occurred. Call gnutls_alert_send_appropriate
10407 on error. Return error code.
10408 (emacs_gnutls_write): Call emacs_gnutls_handle_error.
10409 (emacs_gnutls_read): Likewise.
10410 (Fgnutls_boot): Return handshake error code.
10411 (emacs_gnutls_handle_error): New function.
10412 (wsaerror_to_errno): Likewise.
10413
10414 * w32.h (emacs_gnutls_pull): Add prototype.
10415 (emacs_gnutls_push): Likewise.
10416
10417 * w32.c (emacs_gnutls_pull): New function for GnuTLS on Woe32.
10418 (emacs_gnutls_push): Likewise.
10419
10420 2011-04-24 Claudio Bley <claudio.bley@gmail.com> (tiny change)
10421
10422 * process.c (wait_reading_process_output): Check if GnuTLS
10423 buffered some data internally if no FDs are set for TLS
10424 connections.
10425
10426 * makefile.w32-in (OBJ2): Add gnutls.$(O).
10427 (LIBS): Link to USER_LIBS.
10428 ($(BLD)/gnutls.$(0)): New target.
10429
10430 2011-04-24 Eli Zaretskii <eliz@gnu.org>
10431
10432 * xdisp.c (handle_single_display_spec): Rename the
10433 display_replaced_before_p argument into display_replaced_p, to
10434 make it consistent with the commentary. Fix typos in the
10435 commentary.
10436
10437 * textprop.c (syms_of_textprop): Remove dead code.
10438 (copy_text_properties): Delete obsolete commentary about an
10439 interface that was deleted long ago. Fix typos in the description
10440 of arguments.
10441
10442 * msdos.c (XMenuActivate, XMenuAddSelection): Adjust argument list
10443 to changes in oldXMenu/XMenu.h from 2011-04-16.
10444 <menu_help_message, prev_menu_help_message>: Constify.
10445 (IT_menu_make_room): menu->help_text is now `const char **';
10446 adjust.
10447
10448 * msdos.h (XMenuActivate, XMenuAddSelection): Adjust prototypes
10449 to changes in oldXMenu/XMenu.h from 2011-04-16.
10450 (struct XMenu): Declare `help_text' `const char **'.
10451
10452 * xfaces.c <Qunspecified>: Make extern again.
10453
10454 * syntax.c: Include sys/types.h before including regex.h, as
10455 required by POSIX.
10456
10457 * doc.c (get_doc_string): Improve the format passed to `error'.
10458
10459 * doprnt.c (doprnt): Improve commentary.
10460
10461 * term.c (init_tty) [MSDOS]: Fix 1st argument to maybe_fatal.
10462
10463 * Makefile.in (TAGS): Depend on $(M_FILE) and $(S_FILE), and scan
10464 them with etags.
10465
10466 * makefile.w32-in (globals.h): Add a dummy recipe, to make any
10467 changes in globals.h immediately force recompilation.
10468 (TAGS): Depend on $(CURDIR)/m/intel386.h and
10469 $(CURDIR)/s/ms-w32.h.
10470 (TAGS-gmake): Scan $(CURDIR)/m/intel386.h and $(CURDIR)/s/ms-w32.h.
10471
10472 * character.c (Fchar_direction): Function deleted.
10473 (syms_of_character): Don't defsubr it.
10474 <char-direction-table>: Deleted.
10475
10476 2011-04-23 Eli Zaretskii <eliz@gnu.org>
10477
10478 Fix doprnt so it could be used again safely in `verror'. (Bug#8435)
10479 * doprnt.c: Include limits.h.
10480 (SIZE_MAX): New macro.
10481 (doprnt): Return a size_t value. 2nd arg is now size_t.
10482 Many local variables are now size_t instead of int or unsigned.
10483 Improve overflow protection. Support `l' modifier for integer
10484 conversions. Support %l conversion. Don't assume an EMACS_INT
10485 argument for integer conversions and for %c.
10486
10487 * lisp.h (doprnt): Restore prototype.
10488
10489 * makefile.w32-in ($(BLD)/callint.$(O)): Depend on
10490 $(SRC)/character.h.
10491
10492 * Makefile.in (base_obj): Add back doprnt.o.
10493
10494 * deps.mk (doprnt.o): Add back prerequisites.
10495 (callint.o): Depend on character.h.
10496
10497 * eval.c (internal_lisp_condition_case): Include the handler
10498 representation in the error message.
10499 (verror): Call doprnt instead of vsnprintf. Fix an off-by-one bug
10500 when breaking from the loop.
10501
10502 * xdisp.c (vmessage): Call doprnt instead of vsnprintf.
10503
10504 * callint.c (Fcall_interactively): When displaying error message
10505 about invalid control letter, pass the character's codepoint, not
10506 a pointer to its multibyte form. Improve display of the character
10507 in octal and display also its hex code.
10508
10509 * character.c (char_string): Use %x to display the (unsigned)
10510 codepoint of an invalid character, to avoid displaying a bogus
10511 negative value.
10512
10513 * font.c (check_otf_features): Pass SDATA of SYMBOL_NAME to
10514 `error', not SYMBOL_NAME itself.
10515
10516 * coding.c (Fencode_sjis_char, Fencode_big5_char): Use %c for
10517 character arguments to `error'.
10518
10519 * charset.c (check_iso_charset_parameter): Fix incorrect argument
10520 to `error' in error message about FINAL_CHAR argument. Make sure
10521 FINAL_CHAR is a character, and use %c when it is passed as
10522 argument to `error'.
10523
10524 2011-04-23 Eli Zaretskii <eliz@gnu.org>
10525
10526 * s/ms-w32.h (localtime): Redirect to sys_localtime.
10527
10528 * w32.c: Include <time.h>.
10529 (sys_localtime): New function.
10530
10531 2011-04-23 Chong Yidong <cyd@stupidchicken.com>
10532
10533 * xdisp.c (init_xdisp): Initialize echo_area_window (Bug#6451).
10534
10535 * buffer.c (syms_of_buffer): Doc fix (Bug#6902).
10536
10537 2011-04-23 Samuel Thibault <sthibault@debian.org> (tiny change)
10538
10539 * sysdep.c (wait_for_termination): On GNU Hurd, kill returns -1 on
10540 zombies (Bug#8467).
10541
10542 2011-04-19 Eli Zaretskii <eliz@gnu.org>
10543
10544 * syntax.h (SETUP_SYNTAX_TABLE_FOR_OBJECT): Fix setting of
10545 gl_state.e_property when gl_state.object is Qt.
10546
10547 * insdel.c (make_gap_larger): Remove limitation of buffer size
10548 to <= INT_MAX.
10549
10550 2011-04-18 Chong Yidong <cyd@stupidchicken.com>
10551
10552 * xdisp.c (lookup_glyphless_char_display)
10553 (produce_glyphless_glyph): Handle cons cell entry in
10554 glyphless-char-display.
10555 (Vglyphless_char_display): Document it.
10556
10557 * term.c (produce_glyphless_glyph): Handle cons cell entry in
10558 glyphless-char-display.
10559
10560 2011-04-17 Chong Yidong <cyd@stupidchicken.com>
10561
10562 * xdisp.c (get_next_display_element): Remove unnecessary ifdefs.
10563
10564 * termhooks.h (FRAME_WINDOW_P): Remove duplicated definitions.
10565
10566 * dispextern.h (FACE_SUITABLE_FOR_ASCII_CHAR_P): Add missing
10567 definition for no-X builds.
10568
10569 2011-04-16 Paul Eggert <eggert@cs.ucla.edu>
10570
10571 Static checks with GCC 4.6.0 and non-default toolkits.
10572
10573 * s/sol2-6.h, s/unixware.h (PTY_TTY_NAME_SPRINTF): Protoize decl.
10574
10575 * process.c (keyboard_bit_set): Define only if SIGIO.
10576 (send_process_trap): Mark it with NO_RETURN if it doesn't return.
10577 (send_process): Repair possible setjmp clobbering.
10578
10579 * s/usg5-4-common.h (SETUP_SLAVE_PTY): Don't pass extra arg to 'fatal'.
10580
10581 * eval.c: Include <stdio.h>, for vsnprintf on non-GNU/Linux hosts.
10582
10583 * data.c (arith_error): Mark with NO_RETURN if it doesn't return.
10584
10585 * alloc.c (bytes_used_when_full, SPARE_MEMORY, BYTES_USED):
10586 Define only if needed.
10587
10588 * sysdep.c (_FILE_OFFSET_BITS): Make this hack even uglier
10589 by pacifying GCC about it. Maybe it's time to retire it?
10590 * xfaces.c (USG, __TIMEVAL__): Likewise.
10591
10592 * dispextern.h (struct redisplay_interface): Rename param
10593 to avoid shadowing.
10594 * termhooks.h (struct terminal): Likewise.
10595 * xterm.c (xembed_send_message): Likewise.
10596
10597 * insdel.c (make_gap_smaller): Define only if
10598 USE_MMAP_FOR_BUFFERS || REL_ALLOC || DOUG_LEA_MALLOC.
10599
10600 * keyboard.c (read_char): Make a var volatile so longjmp won't clobber
10601 it.
10602
10603 * emacs.c (MAX_HEAP_BSS_DIFF, my_edata): Move to where they're used,
10604 so that we aren't warned about unused symbols.
10605
10606 * xfns.c (Fx_file_dialog): Rename local to avoid shadowing.
10607
10608 * xdisp.c (x_produce_glyphs): Mark var as initialized (Bug#8512).
10609
10610 * xfns.c (x_real_positions): Mark locals as initialized.
10611
10612 * xmenu.c (xmenu_show): Don't use uninitialized vars.
10613
10614 * xterm.c: Fix problems found by static analysis with other toolkits.
10615 (toolkit_scroll_bar_interaction): Define and use only if USE_X_TOOLKIT.
10616 (x_dispatch_event): Declare static if USE_GTK, and
10617 define if USE_GTK || USE_X_TOOLKIT.
10618 (SET_SAVED_BUTTON_EVENT): Define only if USE_X_TOOLKIT || USE_GTK.
10619 * xterm.h (x_dispatch_event): Extern only if USE_X_TOOLKIT.
10620 * xterm.c, xterm.h (x_mouse_leave): Bring this function back, but only
10621 if defined HAVE_MENUS && !defined USE_X_TOOLKIT && !defined USE_GTK.
10622
10623 * xmenu.c (menu_help_callback): Pointer type fixes.
10624 Use const pointers when pointing at readonly data. Avoid pointer
10625 signedness clashes.
10626 (FALSE): Remove unused macro.
10627 (update_frame_menubar): Remove unused decl.
10628
10629 * xfns.c (Fx_hide_tip): Move locals to avoid shadowing.
10630
10631 * menu.c (push_submenu_start, push_submenu_end): Do not define unless
10632 USE_X_TOOLKIT || USE_GTK || HAVE_NS || defined HAVE_NTGUI.
10633 (single_menu_item): Rename local to avoid shadowing.
10634
10635 * keyboard.c (make_lispy_event): Remove unused local var.
10636
10637 * frame.c, frame.h (x_get_resource_string): Bring this back, but
10638 only if HAVE_X_WINDOWS && !USE_X_TOOLKIT.
10639
10640 * bitmaps: Change bitmaps from unsigned char back to the X11
10641 compatible char. Avoid the old compiler warnings about
10642 out-of-range initializers by using, for example, '\xab' rather
10643 than 0xab.
10644
10645 * xgselect.c (xgselect_initialize): Check vs interface
10646 even if ! (defined (USE_GTK) || defined (HAVE_GCONF)).
10647
10648 * xmenu.c (xmenu_show): Rename parm to avoid shadowing.
10649
10650 * xterm.c (x_create_toolkit_scroll_bar): Use const * for pointers
10651 to read-only memory.
10652
10653 * fns.c (vector): Remove; this old hack is no longer needed.
10654
10655 * xsmfns.c (create_client_leader_window): Rename shadowing arg.
10656 Remove unused var.
10657 (gdk_x11_set_sm_client_id) [!USE_GTK]: Don't define.
10658
10659 * xrdb.c (x_load_resources): Omit unused local.
10660
10661 * xfns.c (free_frame_menubar, atof): Remove duplicate decls.
10662 (x_window): Rename locals to avoid shadowing.
10663 (USG): Use the kludged USG macro, to pacify gcc.
10664
10665 * xterm.c (x_alloc_nearest_color_for_widget): Remove; unused.
10666 (x_term_init): Remove local to avoid shadowing.
10667
10668 * xfns.c, xterm.c (_XEditResCheckMessages): Protoize decl.
10669
10670 * xdisp.c, dispextern.h (set_vertical_scroll_bar): Now extern if
10671 USE_TOOLKIT_SCROLL_BARS && !USE_GTK, as xterm.c needs it then.
10672
10673 2011-04-16 Eli Zaretskii <eliz@gnu.org>
10674
10675 * gnutls.c (Fgnutls_boot): Don't pass Lisp_Object to `error'.
10676
10677 Fix regex.c, syntax.c and friends for buffers > 2GB.
10678 * syntax.h (struct gl_state_s): Declare character position members
10679 EMACS_INT.
10680
10681 * syntax.c (update_syntax_table): Declare 2nd argument EMACS_INT.
10682
10683 * textprop.c (verify_interval_modification, interval_of):
10684 Declare arguments EMACS_INT.
10685
10686 * intervals.c (adjust_intervals_for_insertion): Declare arguments
10687 EMACS_INT.
10688
10689 * intervals.h (CHECK_TOTAL_LENGTH): Cast to EMACS_INT, not `int'.
10690
10691 * indent.c (Fvertical_motion): Local variable it_start is now
10692 EMACS_INT.
10693
10694 * regex.c (re_match, re_match_2, re_match_2_internal)
10695 (bcmp_translate, regcomp, regexec, print_double_string)
10696 (group_in_compile_stack, re_search, re_search_2, regex_compile)
10697 (re_compile_pattern, re_exec): Declare arguments and local
10698 variables `size_t' and `ssize_t' and return values `regoff_t', as
10699 appropriate.
10700 (POP_FAILURE_REG_OR_COUNT) <pfreg>: Declare `long'.
10701 (CHECK_INFINITE_LOOP) <failure>: Declare `ssize_t'.
10702 <compile_stack_type>: `size' and `avail' are now `size_t'.
10703
10704 * regex.h <regoff_t>: Use ssize_t, not int.
10705 (re_search, re_search_2, re_match, re_match_2): Arguments that
10706 specify buffer/string position and length are now ssize_t and
10707 size_t. Return type is regoff_t.
10708
10709 2011-04-16 Ben Key <bkey76@gmail.com>
10710
10711 * nsfont.m: Fixed bugs in ns_get_family and
10712 ns_descriptor_to_entity that were caused by using free to
10713 deallocate memory blocks that were allocated by xmalloc (via
10714 xstrdup). This caused Emacs to crash when compiled with
10715 XMALLOC_OVERRUN_CHECK defined (when Emacs was configured with
10716 --enable-checking=xmallocoverrun). xfree is now used to
10717 deallocate these memory blocks.
10718
10719 2011-04-15 Paul Eggert <eggert@cs.ucla.edu>
10720
10721 * sysdep.c (emacs_read): Remove unnecessary check vs MAX_RW_COUNT.
10722
10723 emacs_write: Accept and return EMACS_INT for sizes.
10724 See http://lists.gnu.org/archive/html/emacs-devel/2011-04/msg00514.html
10725 et seq.
10726 * gnutls.c, gnutls.h (emacs_gnutls_read, emacs_gnutls_write):
10727 Accept and return EMACS_INT.
10728 (emacs_gnutls_write): Return the number of bytes written on
10729 partial writes.
10730 * sysdep.c, lisp.h (emacs_read, emacs_write): Likewise.
10731 (emacs_read, emacs_write): Remove check for negative size, as the
10732 Emacs source code has been audited now.
10733 * sysdep.c (MAX_RW_COUNT): New macro, to work around kernel bugs.
10734 (emacs_read, emacs_write): Use it.
10735 * process.c (send_process): Adjust to the new signatures of
10736 emacs_write and emacs_gnutls_write. Do not attempt to store
10737 a byte offset into an 'int'; it might overflow.
10738 See http://lists.gnu.org/archive/html/emacs-devel/2011-04/msg00483.html
10739
10740 * sound.c: Don't assume sizes fit in 'int'.
10741 (struct sound_device.period_size, alsa_period_size):
10742 Return EMACS_INT, not int.
10743 (struct sound_device.write, vox_write, alsa_write):
10744 Accept EMACS_INT, not int.
10745 (wav_play, au_play): Use EMACS_INT to store sizes and to
10746 record read return values.
10747
10748 2011-04-15 Ben Key <bkey76@gmail.com>
10749
10750 * keyboard.c (Qundefined): Don't declare static since it is used
10751 in nsfns.m.
10752 * xfaces.c (Qbold, Qexpanded, Qitalic, Qcondensed): Don't declare
10753 static since they are used in nsfont.m.
10754
10755 2011-04-15 Stefan Monnier <monnier@iro.umontreal.ca>
10756
10757 * process.c (Qprocessp): Don't declare static.
10758 * lisp.h (Qprocessp): Declare again.
10759
10760 2011-04-15 Juanma Barranquero <lekktu@gmail.com>
10761
10762 * font.c (Qopentype): Don't make static (used from w32uniscribe.c).
10763
10764 2011-04-14 Paul Eggert <eggert@cs.ucla.edu>
10765
10766 Improve C-level modularity by making more things 'static'.
10767
10768 Don't publish debugger-only interfaces to other modules.
10769 * lisp.h (safe_debug_print, debug_output_compilation_hack):
10770 (verify_bytepos, count_markers): Move decls to the only modules
10771 that need them.
10772 * region-cache.h (pp_cache): Likewise.
10773 * window.h (check_all_windows): Likewise.
10774 * marker.c, print.c, region-cache.c, window.c: Decls moved here.
10775
10776 * sysdep.c (croak): Now static, if
10777 defined TIOCNOTTY || defined USG5 || defined CYGWIN.
10778 * syssignal.h (croak): Declare only if not static.
10779
10780 * alloc.c (refill_memory_reserve): Now static if
10781 !defined REL_ALLOC || defined SYSTEM_MALLOC.
10782 * lisp.h (refill_memory_reserve): Declare only if not static.
10783
10784 * xsettings.c, xsettings.h (xsettings_get_system_normal_font):
10785 Define only if USE_LUCID.
10786
10787 * xrdb.c (x_customization_string, x_rm_string): Now static.
10788
10789 * xmenu.c (x_menu_wait_for_event): Export only if USE_MOTIF.
10790 * xterm.h (x_menu_wait_for_event): Declare only if USE_MOTIF.
10791
10792 * xdisp.c (draw_row_with_mouse_face): Now static.
10793 * dispextern.h (draw_row_with_mouse_fave): Remove decl.
10794
10795 * window.h (check_all_windows): Mark externally visible.
10796
10797 * window.c (window_deletion_count): Now static.
10798
10799 * undo.c: Make symbols static if they're not exported.
10800 (last_undo_buffer, last_boundary_position, pending_boundary):
10801 Now static.
10802
10803 * textprop.c (interval_insert_behind_hooks): Now static.
10804 (interval_insert_in_front_hooks): Likewise.
10805
10806 * term.c: Make symbols static if they're not exported.
10807 (tty_turn_off_highlight, get_tty_terminal, max_frame_cols):
10808 (max_frame_lines, tty_set_terminal_modes):
10809 (tty_reset_terminal_modes, tty_turn_off_highlight):
10810 (get_tty_terminal): Now static.
10811 (term_mouse_moveto): Do not define if HAVE_WINDOW_SYSTEM.
10812 * termhooks.h (term_mouse_moveto): Do not declare if
10813 HAVE_WINDOW_SYSTEM.
10814 * dispextern.h (tty_set_terminal_modes, tty_reset_terminal_modes):
10815 (tty_turn_off_highlight, get_tty_terminal): Remove decls.
10816
10817 * sysdep.c: Make symbols static if they're not exported.
10818 (emacs_get_tty, emacs_set_tty, old_fcntl_flags, old_fcntl_owner):
10819 Now static.
10820 (sigprocmask_set, full_mask): Remove; unused.
10821 (wait_debugging): Mark as visible.
10822 * syssignal.h (SIGFULLMASK, full_mask): Remove decls.
10823 * systty.h (emacs_get_tty, emacs_set_tty): Remove decls.
10824
10825 * syntax.c (syntax_temp): Define only if !__GNUC__.
10826
10827 * sound.c (current_sound_device, current_sound): Now static.
10828
10829 * search.c (searchbufs, searchbuf_head): Now static.
10830
10831 * scroll.c (scroll_cost): Remove; unused.
10832 * dispextern.h (scroll_cost): Remove decl.
10833
10834 * region-cache.h (pp_cache): Mark as externally visible.
10835
10836 * process.c: Make symbols static if they're not exported.
10837 (process_tick, update_tick, create_process, chan_process):
10838 (Vprocess_alist, proc_buffered_char, datagram_access):
10839 (fd_callback_data, send_process_frame, process_sent_to): Now static.
10840 (deactivate_process): Mark defn as static, as well as decl.
10841 * lisp.h (create_process): Remove decl.
10842 * process.h (chan_process, Vprocess_alist): Remove decls.
10843
10844 * print.c: Make symbols static if they're not exported.
10845 (print_depth, new_backquote_output, being_printed, print_buffer):
10846 (print_buffer_size, print_buffer_pos, print_buffer_pos_byte):
10847 (print_interval, print_number_index, initial_stderr_stream):
10848 Now static.
10849 * lisp.h (Fprinc): Remove decl.
10850 (debug_output_compilation_hack): Mark as externally visible.
10851
10852 * sysdep.c (croak): Move decl from here to syssignal.h.
10853 * syssignal.h (croak): Put it here, so the API can be checked when
10854 'croak' is called from dissociate_if_controlling_tty.
10855
10856 * minibuf.c: Make symbols static if they're not exported.
10857 (minibuf_save_list, choose_minibuf_frame): Now static.
10858 * lisp.h (choose_minibuf_frame): Remove decl.
10859
10860 * lisp.h (verify_bytepos, count_markers): Mark as externally visible.
10861
10862 * lread.c: Make symbols static if they're not exported.
10863 (read_objects, initial_obarray, oblookup_last_bucket_number):
10864 Now static.
10865 (make_symbol): Remove; unused.
10866 * lisp.h (initial_obarray, make_symbol): Remove decls.
10867
10868 * keyboard.c: Make symbols static if they're not exported.
10869 (single_kboard, recent_keys_index, total_keys, recent_keys):
10870 (this_command_key_count_reset, raw_keybuf, raw_keybuf_count):
10871 (this_single_command_key_start, echoing, last_auto_save):
10872 (read_key_sequence_cmd, dribble, recursive_edit_unwind):
10873 (command_loop, echo_now, keyboard_init_hook, help_char_p):
10874 (quit_throw_to_read_char, command_loop_2, top_level_1, poll_timer):
10875 (Vlispy_mouse_stem, double_click_count):
10876 Now static.
10877 (force_auto_save_soon): Define only if SIGDANGER.
10878 (ignore_mouse_drag_p): Now static if
10879 !defined HAVE_WINDOW_SYSTEM || defined USE_GTK || defined HAVE_NS.
10880 (print_help): Remove; unused.
10881 (stop_character, last_timer_event): Mark as externally visible.
10882 * keyboard.h (ignore_mouse_drag_p): Declare only if
10883 defined HAVE_WINDOW_SYSTEM && !defined USE_GTK && !defined HAVE_NS.
10884 (echo_now, help_char_p, quit_throw_to_read_char): Remove decls.
10885 * lisp.h (echoing): Remove decl.
10886 (force_auto_save_soon): Declare only if SIGDANGER.
10887 * xdisp.c (redisplay_window): Simplify code, to make it more
10888 obvious that ignore_mouse_drag_p is not accessed if !defined
10889 USE_GTK && !defined HAVE_NS.
10890
10891 * intervals.c: Make symbols static if they're not exported.
10892 (merge_properties_sticky, merge_interval_right, delete_interval):
10893 Now static.
10894 * intervals.h (merge_interval_right, delete_interval): Remove decls.
10895
10896 * insdel.c: Make symbols static if they're not exported.
10897 However, leave prepare_to_modify_buffer alone. It's never
10898 called from outside this function, but that appears to be a bug.
10899 (combine_after_change_list, combine_after_change_buffer):
10900 (adjust_after_replace, signal_before_change): Now static.
10901 (adjust_after_replace_noundo): Remove; unused.
10902 * lisp.h (adjust_after_replace, adjust_after_replace_noundo):
10903 (signal_before_change): Remove decls.
10904
10905 * indent.c (val_compute_motion, val_vmotion): Now static.
10906
10907 * image.c: Make symbols static if they're not exported.
10908 * dispextern.h (x_create_bitmap_from_xpm_data): Do not declare
10909 if USE_GTK.
10910 * image.c (x_create_bitmap_from_xpm_data): Do not define if USE_GTK.
10911 (xpm_color_cache, ct_table, ct_colors_allocated): Now static.
10912
10913 * fringe.c (standard_bitmaps): Now static.
10914 (max_used_fringe_bitmap): Now static, unless HAVE_NS.
10915
10916 * frame.c: Make symbols static if they're not exported.
10917 (x_report_frame_params, make_terminal_frame): Now static.
10918 (get_frame_param): Now static, unless HAVE_NS.
10919 (x_fullscreen_adjust): Define if WINDOWSNT, not if HAVE_WINDOW_SYSTEM.
10920 (x_get_resource_string): Remove; not used.
10921 * frame.h (make_terminal_frame, x_report_frame_params):
10922 (x_get_resource_string); Remove decls.
10923 (x_fullscreen_adjust): Declare only if WINDOWSNT.
10924 * lisp.h (get_frame_param): Declare only if HAVE_NS.
10925
10926 * font.c, fontset.c: Make symbols static if they're not exported.
10927 * dispextern.h (FACE_SUITABLE_FOR_ASCII_CHAR_P): New macro.
10928 (FACE_SUITABLE_FOR_CHAR_P): Use it.
10929 * font.c (font_close_object): Now static.
10930 * font.h (font_close_object): Remove.
10931 * fontset.c (FONTSET_OBJLIST): Remove.
10932 (free_realized_fontset) #if-0 the body, which does nothing.
10933 (face_suitable_for_char_p): #if-0, as it's never called.
10934 * fontset.h (face_suitable_for_char_p): Remove decl.
10935 * xfaces.c (face_at_string_position):
10936 Use FACE_SUITABLE_FOR_ASCII_CHAR_P, not FACE_SUITABLE_FOR_CHAR_P,
10937 since 0 is always ASCII.
10938
10939 * fns.c (weak_hash_tables): Now static.
10940
10941 * fileio.c: Make symbols static if they're not exported.
10942 (auto_saving, auto_save_mode_bits, auto_save_error_occurred):
10943 (Vwrite_region_annotation_buffers): Now static.
10944
10945 * eval.c: Make symbols static if they're not exported.
10946 (backtrace_list, lisp_eval_depth, when_entered_debugger): Now static.
10947 * lisp.h (backtrace_list): Remove decl.
10948
10949 * emacs.c: Make symbols static if they're not exported.
10950 (malloc_state_ptr, malloc_using_checking, syms_of_emacs):
10951 (fatal_error_code, fatal_error_signal_hook, standard_args):
10952 Now static.
10953 (fatal_error_signal): Now static, unless FLOAT_CATCH_SIGKILL.
10954 (DEFINE_DUMMY_FUNCTION): Mark function as externally visible.
10955 (__CTOR_LIST__, __DTOR_LIST__): Now externally visible.
10956 * lisp.h (fatal_error_signal_hook): Remove decl.
10957 (fatal_error_signal): Declare only if FLOAT_CATCH_SIGKILL.
10958
10959 * editfns.c: Move a (normally-unused) function to its only use.
10960 * editfns.c, lisp.h (get_operating_system_release): Remove.
10961 * process.c (init_process) [DARWIN_OS]: Do it inline, as it is not
10962 worth the hassle of breaking this out.
10963
10964 * xterm.c: Make symbols static if they're not exported.
10965 (x_raise_frame, x_lower_frame, x_wm_set_window_state):
10966 (x_wm_set_icon_pixmap, x_initialize, XTread_socket_fake_io_error):
10967 (x_destroy_window, x_delete_display):
10968 Now static.
10969 (x_dispatch_event): Now static if ! (USE_MOTIF || USE_X_TOOLKIT).
10970 (x_mouse_leave): Remove; unused.
10971 * xterm.h (x_display_info_for_name, x_raise_frame, x_lower_frame):
10972 (x_destroy_window, x_wm_set_window_state, x_wm_set_icon_pixmap):
10973 (x_delete_display, x_initialize, x_set_border_pixel, x_screen_planes):
10974 Remove decls.
10975 (x_mouse_leave): Declare only if WINDOWSNT.
10976 (x_dispatch_event): Declare only if USE_MOTIF or USE_X_TOOLKIT.
10977 (xic_create_fontsetname): Declare only if HAVE_X_WINDOWS &&
10978 USE_X_TOOLKIT.
10979
10980 * ftxfont.c: Make symbols static if they're not exported.
10981 (ftxfont_driver): Export only if !defined HAVE_XFT && def8ined
10982 HAVE_FREETYPE.
10983 * font.h (ftxfont_driver): Likewise.
10984
10985 * xfns.c: Make symbols static if they're not exported.
10986 (x_last_font_name, x_display_info_for_name):
10987 (x_set_foreground_color, x_set_background_color, x_set_mouse_color):
10988 (x_set_cursor_color, x_set_border_pixel, x_set_border_color):
10989 (x_set_cursor_type, x_set_icon_type, x_set_icon_name):
10990 (x_set_scroll_bar_foreground, x_set_scroll_bar_background):
10991 (x_explicitly_set_name, x_set_title, xic_defaut_fontset, tip_timer):
10992 (last_show_tip_args): Now static.
10993 (xic_defaut_fontset, xic_create_fontsetname): Define only if
10994 defined HAVE_X_WINDOWS && defined USE_X_TOOLKIT
10995 (x_screen_planes): Remove; unused.
10996 * dispextern.h (x_screen_planes): Remove decl.
10997
10998 * dispnew.c: Make symbols static if they're not exported.
10999 * dispextern.h (redraw_garbaged_frames, scrolling):
11000 (increment_row_positions): Remove.
11001 * dispnew.c (new_glyph_matrix, increment_row_positions, scrolling):
11002 (delayed_size_change, glyph_matrix_count, glyph_pool_count):
11003 Now static.
11004 (redraw_garbaged_frames): Remove; unused.
11005
11006 * xfaces.c: Make symbols static if they're not exported.
11007 * dispextern.h (ascii_face_of_lisp_face, free_realized_face):
11008 Remove decls.
11009 * xterm.h (defined_color): Remove decls.
11010 (x_free_dpy_colors): Declare only if USE_X_TOOLKIT.
11011 * xfaces.c (tty_suppress_bold_inverse_default_colors_p):
11012 (menu_face_changed_default, defined_color, free_realized_face):
11013 (x_free_dpy_colors): Define only if USE_X_TOOLKIT.
11014 (ascii_face_of_lisp_face): Remove; unused.
11015
11016 * xdisp.c: Make symbols static if they're not exported.
11017 * dispextern.h (scratch_glyph_row, window_box_edges):
11018 (glyph_to_pixel_coords, set_cursor_from_row):
11019 (get_next_display_element, set_iterator_to_next):
11020 (highlight_trailing_whitespace, frame_to_window_pixel_xy):
11021 (show_mouse_face): Remove decls
11022 * frame.h (message_buf_print): Likewise.
11023 * lisp.h (pop_message, set_message, check_point_in_composition):
11024 Likewise.
11025 * xterm.h (set_vertical_scroll_bar): Likewise.
11026 * xdisp.c (list_of_error, Vmessage_stack, line_number_displayed):
11027 (message_buf_print, scratch_glyph_row, displayed_buffer):
11028 (set_iterator_to_next, pop_message, set_message, set_cursor_from_row):
11029 (get_next_display_element, show_mouse_face, window_box_edges):
11030 (frame_to_window_pixel_xy, check_point_in_composition):
11031 (set_vertical_scroll_bar, highlight_trailing_whitespace): Now static.
11032 (glyph_to_pixel_coords): Remove; unused.
11033
11034 * dired.c (file_name_completion): Now static.
11035
11036 * dbusbind.c (xd_in_read_queued_messages): Now static.
11037
11038 * lisp.h (circular_list_error, FOREACH): Remove; unused.
11039 * data.c (circular_list_error): Remove.
11040
11041 * commands.h (last_point_position, last_point_position_buffer):
11042 (last_point_position_window): Remove decls.
11043 * keyboard.c: Make these variables static.
11044
11045 * coding.h (coding, code_convert_region, encode_coding_gap):
11046 Remove decls.
11047 * coding.c (Vsjis_coding_system, Vbig5_coding_system):
11048 (iso_code_class, detect_coding, code_convert_region): Now static.
11049 (encode_coding_gap): Remove; unused.
11050
11051 * chartab.c (chartab_chars, chartab_bits): Now static.
11052
11053 * charset.h (charset_iso_8859_1): Remove decl.
11054 * charset.c (charset_iso_8859_1, charset_emacs, map_charset_for_dump):
11055 Now static.
11056
11057 * ccl.h (check_ccl_update, Vccl_program_table): Remove decls.
11058 * ccl.c (Vccl_program_table): Now static.
11059 (check_ccl_update): Remove; unused.
11060
11061 * category.c (SET_CATEGORY_SET, set_category_set): Move here.
11062 * category.h: ... from here.
11063 * category.c (check_category_table, set_category_set): Now static.
11064
11065 * casetab.c (Vascii_upcase_table, Vascii_eqv_table): Now static.
11066 * lisp.h: Remove these decls.
11067
11068 * buffer.c (buffer_count): Remove unused var.
11069
11070 * bidi.c (bidi_dump_cached_states): Mark as externally visible,
11071 so that it's not optimized away.
11072 (bidi_ignore_explicit_marks_for_paragraph_level): Likewise.
11073 * dispextern.h (bidi_dump_cached_states): Remove, since it's
11074 exported only to the debugger.
11075
11076 * atimer.c (alarm_signal_handler, run_all_atimers): Now static.
11077 * atimer.h (run_all_atimers): Remove; not exported.
11078
11079 font.c: Make copy_font_spec and merge_font_spec ordinary C functions.
11080 * font.c (copy_font_spec): Rename from Fcopy_font_spec, since it
11081 was inaccessible from Lisp.
11082 (merge_font_spec): Likewise, renaming from Fmerge_font_spec.
11083 * font.c, font.h, fontset.c, xfaces.c, xfont.c: Change all uses.
11084
11085 alloc.c: Import and export fewer symbols, and remove unused items.
11086 * lisp.h (suppress_checking, die): Declare only if ENABLE_CHECKING
11087 is defined.
11088 (suppress_checking): Add EXTERNALLY_VISIBLE attribute, so that
11089 it's not optimized away by whole-program optimization.
11090 (message_enable_multibyte, free_misc): Remove.
11091 (catchlist, handlerlist, mark_backtrace):
11092 Declare only if BYTE_MARK_STACK.
11093 (mark_byte_stack): Likewise, fixing a ifdef-vs-if typo.
11094 * alloc.c (pure): Export only if VIRT_ADDR_VARIES is defined.
11095 (message_enable_multibyte): Remove decl.
11096 (free_misc, interval_free_list, float_block, float_block_index):
11097 (n_float_blocks, float_free_list, cons_block, cons_block_index):
11098 (cons_free_list, last_marked_index):
11099 Now static.
11100 (suppress_checking, die): Define only if ENABLE_CHECKING is defined.
11101 * eval.c (catchlist, handlerlist): Export only if BYTE_MARK_STACK.
11102 (mark_backtrace): Define only if BYTE_MARK_STACK.
11103 * xdisp.c (message_enable_multibyte): Now static.
11104
11105 Declare Lisp_Object Q* variables to be 'static' if not exported.
11106 This makes it easier for human readers (and static analyzers)
11107 to see whether these variables are used from other modules.
11108 * alloc.c, buffer.c, bytecode.c, callint.c, casetab.c, category.c:
11109 * ccl.c, character.c, charset.c, cmds.c, coding.c, composite.c:
11110 * data.c, dbusbind.c, dired.c, editfns.c, eval.c, fileio.c, fns.c:
11111 * font.c, frame.c, fringe.c, ftfont.c, image.c, keyboard.c, keymap.c:
11112 * lread.c, macros.c, minibuf.c, print.c, process.c, search.c:
11113 * sound.c, syntax.c, textprop.c, window.c, xdisp.c, xfaces.c, xfns.c:
11114 * xmenu.c, xselect.c:
11115 Declare Q* vars static if they are not used in other modules.
11116 * ccl.h, character.h, charset.h, coding.h, composite.h, font.h:
11117 * frame.h, intervals.h, keyboard.h, lisp.h, process.h, syntax.h:
11118 Remove decls of unexported vars.
11119 * keyboard.h (EVENT_HEAD_UNMODIFIED): Remove now-unused macro.
11120
11121 * lisp.h (DEFINE_FUNC): Make sname 'static'.
11122
11123 Make Emacs functions such as Fatom 'static' by default.
11124 This makes it easier for human readers (and static analyzers)
11125 to see whether these functions can be called from other modules.
11126 DEFUN now defines a static function. To make the function external
11127 so that it can be used in other C modules, use the new macro DEFUE.
11128 * lisp.h (Funibyte_char_to_multibyte, Fsyntax_table_p):
11129 (Finit_image_library):
11130 (Feval_region, Fbacktrace, Ffetch_bytecode, Fswitch_to_buffer):
11131 (Ffile_executable_p, Fmake_symbolic_link, Fcommand_execute):
11132 (Fget_process, Fdocumentation_property, Fbyte_code, Ffile_attributes):
11133 Remove decls, since these functions are now static.
11134 (Funintern, Fget_internal_run_time): New decls, since these functions
11135 were already external.
11136
11137 * alloc.c, buffer.c, callint.c, callproc.c, casefiddle.c, casetab.c:
11138 * ccl.c, character.c, chartab.c, cmds.c, coding.c, data.c, dispnew.c:
11139 * doc.c, editfns.c, emacs.c, eval.c, fileio.c, filelock.c, floatfns.c:
11140 * fns.c, font.c, fontset.c, frame.c, image.c, indent.c:
11141 * keyboard.c, keymap.c, lread.c:
11142 * macros.c, marker.c, menu.c, minibuf.c, print.c, process.c, search.c:
11143 * syntax.c, term.c, terminal.c, textprop.c, undo.c:
11144 * window.c, xdisp.c, xfaces.c, xfns.c, xmenu.c, xsettings.c:
11145 Mark functions with DEFUE instead of DEFUN,
11146 if they are used in other modules.
11147 * buffer.c (Fset_buffer_major_mode, Fdelete_overlay): New forward
11148 decls for now-static functions.
11149 * buffer.h (Fdelete_overlay): Remove decl.
11150 * callproc.c (Fgetenv_internal): Mark as internal.
11151 * composite.c (Fremove_list_of_text_properties): Remove decl.
11152 (Fcomposition_get_gstring): New forward static decl.
11153 * composite.h (Fcomposite_get_gstring): Remove decl.
11154 * dired.c (Ffile_attributes): New forward static decl.
11155 * doc.c (Fdocumntation_property): New forward static decl.
11156 * eval.c (Ffetch_bytecode): New forward static decl.
11157 (Funintern): Remove extern decl; now in .h file where it belongs.
11158 * fileio.c (Fmake_symbolic_link): New forward static decl.
11159 * image.c (Finit_image_library): New forward static decl.
11160 * insdel.c (Fcombine_after_change_execute): Make forward decl static.
11161 * intervals.h (Fprevious_property_change):
11162 (Fremove_list_of_text_properties): Remove decls.
11163 * keyboard.c (Fthis_command_keys): Remove decl.
11164 (Fcommand_execute): New forward static decl.
11165 * keymap.c (Flookup_key): New forward static decl.
11166 (Fcopy_keymap): Now static.
11167 * keymap.h (Flookup_key): Remove decl.
11168 * process.c (Fget_process): New forward static decl.
11169 (Fprocess_datagram_address): Mark as internal.
11170 * syntax.c (Fsyntax_table_p): New forward static decl.
11171 (skip_chars): Remove duplicate decl.
11172 * textprop.c (Fprevious_property_change): New forward static decl.
11173 * window.c (Fset_window_fringes, Fset_window_scroll_bars):
11174 Now internal.
11175 (Fset_window_margins, Fset_window_vscroll): New forward static decls.
11176 * window.h (Fset_window_vscroll, Fset_window_margins): Remove decls.
11177
11178 * editfns.c (Fformat): Remove unreachable code.
11179
11180 2011-04-14 Andreas Schwab <schwab@linux-m68k.org>
11181
11182 * fileio.c (Finsert_file_contents): Fix typo in 2005-05-13
11183 change. (Bug#8496)
11184
11185 2011-04-13 Eli Zaretskii <eliz@gnu.org>
11186
11187 * xdisp.c (handle_invisible_prop): Don't call bidi_paragraph_init
11188 when at ZV. (Bug#8487)
11189
11190 2011-04-12 Andreas Schwab <schwab@linux-m68k.org>
11191
11192 * charset.c (Fclear_charset_maps): Use xfree instead of free.
11193 (Bug#8437)
11194 * keyboard.c (parse_tool_bar_item): Likewise.
11195 * sound.c (sound_cleanup, alsa_close): Likewise.
11196 * termcap.c (tgetent): Likewise.
11197 * xfns.c (x_default_font_parameter): Likewise.
11198 * xsettings.c (read_and_apply_settings): Likewise.
11199
11200 * alloc.c (overrun_check_malloc, overrun_check_realloc)
11201 (overrun_check_free): Protoize.
11202
11203 2011-04-12 Paul Eggert <eggert@cs.ucla.edu>
11204
11205 * sysdep.c (emacs_read, emacs_write): Check for negative sizes
11206 since callers should never pass a negative size.
11207 Change the signature to match that of plain 'read' and 'write'; see
11208 <http://lists.gnu.org/archive/html/emacs-devel/2011-04/msg00397.html>.
11209 * lisp.h: Update prototypes of emacs_write and emacs_read.
11210
11211 2011-04-11 Eli Zaretskii <eliz@gnu.org>
11212
11213 * xdisp.c (redisplay_window): Don't try to determine the character
11214 position of the scroll margin if the window start point w->startp
11215 is outside the buffer's accessible region. (Bug#8468)
11216
11217 2011-04-10 Eli Zaretskii <eliz@gnu.org>
11218
11219 Fix write-region and its subroutines for buffers > 2GB.
11220 * fileio.c (a_write, e_write): Modify declaration of arguments and
11221 local variables to support buffers larger than 2GB.
11222 (Fcopy_file): Use EMACS_INT for return value of emacs_read.
11223
11224 * sysdep.c (emacs_write, emacs_read): Use ssize_t for last
11225 argument, local variables, and return value.
11226
11227 * lisp.h: Update prototypes of emacs_write and emacs_read.
11228
11229 * sound.c (vox_write): Use ssize_t for return value of emacs_write.
11230
11231 2011-04-10 Paul Eggert <eggert@cs.ucla.edu>
11232
11233 * xdisp.c (vmessage): Use memchr, not strnlen, which some hosts lack.
11234
11235 Fix more problems found by GCC 4.6.0's static checks.
11236
11237 * xdisp.c (vmessage): Use a better test for character truncation.
11238
11239 * charset.c (load_charset_map): <, not <=, for optimization,
11240 and to avoid potential problems with integer overflow.
11241 * chartab.c (sub_char_table_set_range, char_table_set_range): Likewise.
11242 * casetab.c (set_identity, shuffle): Likewise.
11243 * editfns.c (Fformat): Likewise.
11244 * syntax.c (skip_chars): Likewise.
11245
11246 * xmenu.c (set_frame_menubar): Allocate smaller local vectors.
11247 This also lets GCC 4.6.0 generate slightly better loop code.
11248
11249 * callint.c (Fcall_interactively): <, not <=, for optimization.
11250 (Fcall_interactively): Count the number of arguments produced,
11251 not the number of arguments given. This is simpler and lets GCC
11252 4.6.0 generate slightly better code.
11253
11254 * ftfont.c: Distingish more carefully between FcChar8 and char.
11255 The previous code passed unsigned char * to a functions like
11256 strlen and xstrcasecmp that expect char *, which does not
11257 conform to the C standard.
11258 (get_adstyle_property, ftfont_pattern_entity): Use FcChar8 for
11259 arguments to FcPatternGetString, and explicitly cast FcChar8 * to
11260 char * when the C standard requires it.
11261
11262 * keyboard.c (read_char): Remove unused var.
11263
11264 * eval.c: Port to Windows vsnprintf (Bug#8435).
11265 Include <limits.h>.
11266 (SIZE_MAX): Define if the headers do not.
11267 (verror): Do not give up if vsnprintf returns a negative count.
11268 Instead, grow the buffer. This ports to Windows vsnprintf, which
11269 does not conform to C99. Problem reported by Eli Zaretskii.
11270 Also, simplify the allocation scheme, by avoiding the need for
11271 calling realloc, and removing the ALLOCATED variable.
11272
11273 * eval.c (verror): Initial buffer size is 4000 (not 200) bytes.
11274
11275 Remove invocations of doprnt, as Emacs now uses vsnprintf.
11276 But keep the doprint source code for now, as we might revamp it
11277 and use it again (Bug#8435).
11278 * lisp.h (doprnt): Remove.
11279 * Makefile.in (base_obj): Remove doprnt.o.
11280 * deps.mk (doprnt.o): Remove.
11281
11282 error: Print 32- and 64-bit integers portably (Bug#8435).
11283 Without this change, on typical 64-bit hosts error ("...%d...", N)
11284 was used to print both 32- and 64-bit integers N, which relied on
11285 undefined behavior.
11286 * lisp.h, m/amdx86-64.h, m/ia64.h, m/ibms390x.h (pEd): New macro.
11287 * lisp.h (error, verror): Mark as printf-like functions.
11288 * eval.c (verror): Use vsnprintf, not doprnt, to do the real work.
11289 Report overflow in size calculations when allocating printf buffer.
11290 Do not truncate output string at its first null byte.
11291 * xdisp.c (vmessage): Use vsnprintf, not doprnt, to do the real work.
11292 Truncate the output at a character boundary, since vsnprintf does not
11293 do that.
11294 * charset.c (check_iso_charset_parameter): Convert internal
11295 character to string before calling 'error', since %c now has the
11296 printf meaning.
11297 * coding.c (Fdecode_sjis_char, Fdecode_big5_char): Avoid int
11298 overflow when computing char to be passed to 'error'. Do not
11299 pass Lisp_Object to 'error'; pass the integer instead.
11300 * nsfns.m (Fns_do_applescript): Use int, not long, since it's
11301 formatted with plain %d.
11302
11303 * eval.c (internal_lisp_condition_case): Don't pass spurious arg.
11304
11305 * keyboard.c (access_keymap_keyremap): Print func name, not garbage.
11306
11307 * coding.c (Fdecode_sjis_char): Don't assume CODE fits in int.
11308
11309 * xterm.c (x_catch_errors): Remove duplicate declaration.
11310
11311 * term.c (maybe_fatal): Mark its 3rd arg as a printf format, too.
11312
11313 * xdisp.c, lisp.h (message_nolog): Remove; unused.
11314
11315 2011-04-10 Jim Meyering <meyering@redhat.com>
11316
11317 use ssize_t and size_t for read- and write-like emacs_gnutls_* functions
11318 * gnutls.c (emacs_gnutls_read): Adjust signature to be more read-like:
11319 return ssize_t not "int", and use size_t as the buffer length.
11320 (emacs_gnutls_write): Likewise, and make the buffer pointer "const".
11321 * gnutls.h: Update declarations.
11322 * process.c (read_process_output): Use ssize_t, to match.
11323 (send_process): Likewise.
11324
11325 2011-04-09 Chong Yidong <cyd@stupidchicken.com>
11326
11327 * image.c (Fimagemagick_types): Doc fix, and comment cleanup.
11328
11329 2011-04-09 Chong Yidong <cyd@stupidchicken.com>
11330
11331 * ftfont.c (get_adstyle_property, ftfont_pattern_entity):
11332 Use unsigned char, to match FcChar8 type definition.
11333
11334 * xterm.c (handle_one_xevent):
11335 * xmenu.c (create_and_show_popup_menu):
11336 * xselect.c (x_decline_selection_request)
11337 (x_reply_selection_request): Avoid type-punned deref of X events.
11338
11339 2011-04-09 Eli Zaretskii <eliz@gnu.org>
11340
11341 Fix some uses of `int' instead of EMACS_INT.
11342 * search.c (string_match_1, fast_string_match)
11343 (fast_c_string_match_ignore_case, fast_string_match_ignore_case)
11344 (scan_buffer, find_next_newline_no_quit)
11345 (find_before_next_newline, search_command, Freplace_match)
11346 (Fmatch_data): Make some `int' variables be EMACS_INT.
11347
11348 * xdisp.c (display_count_lines): 3rd argument and return value now
11349 EMACS_INT. All callers changed.
11350 (pint2hrstr): Last argument is now EMACS_INT.
11351
11352 * coding.c (detect_coding_utf_8, detect_coding_emacs_mule)
11353 (detect_coding_iso_2022, detect_coding_sjis, detect_coding_big5)
11354 (detect_coding_ccl, detect_coding_charset, decode_coding_utf_8)
11355 (decode_coding_utf_16, decode_coding_emacs_mule)
11356 (decode_coding_iso_2022, decode_coding_sjis, decode_coding_big5)
11357 (decode_coding_ccl, decode_coding_charset)
11358 <consumed_chars, consumed_chars_base>: Declare EMACS_INT.
11359 (decode_coding_iso_2022, decode_coding_emacs_mule)
11360 (decode_coding_sjis, decode_coding_big5, decode_coding_charset)
11361 <char_offset, last_offset>: Declare EMACS_INT.
11362 (encode_coding_utf_8, encode_coding_utf_16)
11363 (encode_coding_emacs_mule, encode_invocation_designation)
11364 (encode_designation_at_bol, encode_coding_iso_2022)
11365 (encode_coding_sjis, encode_coding_big5, encode_coding_ccl)
11366 (encode_coding_raw_text, encode_coding_charset) <produced_chars>:
11367 Declare EMACS_INT.
11368 (ASSURE_DESTINATION): Declare more_bytes EMACS_INT.
11369 (encode_invocation_designation): Last argument P_NCHARS is now
11370 EMACS_INT.
11371 (decode_eol): Declare pos_byte, pos, and pos_end EMACS_INT.
11372 (produce_chars): from_nchars and to_nchars are now EMACS_INT.
11373
11374 * coding.h (struct coding_system) <head_ascii>: Declare EMACS_INT.
11375 All users changed.
11376
11377 * ccl.c (Fccl_execute_on_string): Declare some variables
11378 EMACS_INT.
11379
11380 2011-04-08 Samuel Thibault <sthibault@debian.org> (tiny change)
11381
11382 * term.c (init_tty): Fix incorrect ifdef placement (Bug#8450).
11383
11384 2011-03-19 Christoph Scholtes <cschol2112@googlemail.com>
11385
11386 * process.c (Fformat_network_address): Doc fix.
11387
11388 2011-04-08 T.V. Raman <tv.raman.tv@gmail.com> (tiny change)
11389
11390 * xml.c (parse_region): Avoid creating spurious whitespace nodes.
11391
11392 2011-04-08 Chong Yidong <cyd@stupidchicken.com>
11393
11394 * keyboard.c (read_char): Call Lisp function help-form-show,
11395 instead of using internal_with_output_to_temp_buffer.
11396 (Qhelp_form_show): New var.
11397 (syms_of_keyboard): Use DEFSYM macro.
11398
11399 * print.c (internal_with_output_to_temp_buffer): Function deleted.
11400
11401 * lisp.h (internal_with_output_to_temp_buffer): Remove prototype.
11402
11403 2011-04-06 Chong Yidong <cyd@stupidchicken.com>
11404
11405 * process.c (Flist_processes): Remove to Lisp.
11406 (list_processes_1): Delete.
11407
11408 2011-04-06 Eli Zaretskii <eliz@gnu.org>
11409
11410 * msdos.c (careadlinkat, careadlinkatcwd): MS-DOS replacements.
11411
11412 * w32.c (careadlinkat, careadlinkatcwd): New always-fail stubs.
11413
11414 2011-04-06 Paul Eggert <eggert@cs.ucla.edu>
11415
11416 Fix more problems found by GCC 4.6.0's static checks.
11417
11418 * xmenu.c (Fx_popup_dialog): Don't assume string is free of formats.
11419
11420 * menu.c (Fx_popup_menu): Don't assume error_name lacks printf formats.
11421
11422 * lisp.h (message, message_nolog, fatal): Mark as printf-like.
11423
11424 * xdisp.c (vmessage): Mark as a printf-like function.
11425
11426 * term.c (vfatal, maybe_fatal): Mark as printf-like functions.
11427
11428 * sound.c (sound_warning): Don't crash if arg contains a printf format.
11429
11430 * image.c (tiff_error_handler, tiff_warning_handler): Mark as
11431 printf-like functions.
11432 (tiff_load): Add casts to remove these marks before passing them
11433 to system-supplied API.
11434
11435 * eval.c (Fsignal): Remove excess argument to 'fatal'.
11436
11437 * coding.c (EMIT_ONE_BYTE, EMIT_TWO_BYTES): Use unsigned, not int.
11438 This avoids several warnings with gcc -Wstrict-overflow.
11439 (DECODE_COMPOSITION_RULE): If the rule is invalid, goto invalid_code
11440 directly, rather than having caller test rule sign. This avoids
11441 some unnecessary tests.
11442 * composite.h (COMPOSITION_ENCODE_RULE_VALID): New macro.
11443 (COMPOSITION_ENCODE_RULE): Arguments now must be valid. This
11444 affects only one use, in DECODE_COMPOSITION_RULE, which is changed.
11445
11446 * xfont.c (xfont_text_extents): Remove var that was set but not used.
11447 (xfont_open): Avoid unnecessary tests.
11448
11449 * composite.c (composition_gstring_put_cache): Use unsigned integer.
11450
11451 * composite.h, composite.c (composition_gstring_put_cache):
11452 Use EMACS_INT, not int, for length.
11453
11454 * composite.h (COMPOSITION_DECODE_REFS): New macro,
11455 breaking out part of COMPOSITION_DECODE_RULE.
11456 (COMPOSITION_DECODE_RULE): Use it.
11457 * composite.c (get_composition_id): Remove unused local vars,
11458 by using the new macro.
11459
11460 * textprop.c (set_text_properties_1): Change while to do-while,
11461 since the condition is always true at first.
11462
11463 * intervals.c (graft_intervals_into_buffer): Mark var as used.
11464 (interval_deletion_adjustment): Return unsigned value.
11465 All uses changed.
11466
11467 * process.c (list_processes_1, create_pty, read_process_output):
11468 (exec_sentinel): Remove vars that were set but not used.
11469 (create_pty): Remove unnecessary "volatile"s.
11470 (Fnetwork_interface_info): Avoid possibility of int overflow.
11471 (read_process_output): Do adaptive read buffering even if carryover.
11472 (read_process_output): Simplify nbytes computation if buffered.
11473
11474 * bytecode.c (exec_byte_code): Rename local to avoid shadowing.
11475
11476 * syntax.c (scan_words): Remove var that was set but not used.
11477 (update_syntax_table): Use unsigned instead of int.
11478
11479 * lread.c (lisp_file_lexically_bound_p): Use ints rather than endptrs.
11480 (lisp_file_lexically_bound_p, read1): Use unsigned instead of int.
11481 (safe_to_load_p): Make the end-of-loop test the inverse of the in-loop.
11482
11483 * print.c (print_error_message): Avoid int overflow.
11484
11485 * font.c (font_list_entities): Redo for clarity,
11486 so that reader need not know FONT_DPI_INDEX + 1 == FONT_SPACING_INDEX.
11487
11488 * font.c (font_find_for_lface, Ffont_get_glyphs): Remove unused vars.
11489 (font_score): Avoid potential overflow in diff calculation.
11490
11491 * fns.c (substring_both): Remove var that is set but not used.
11492 (sxhash): Redo loop for clarity and to avoid wraparound warning.
11493
11494 * eval.c (funcall_lambda): Rename local to avoid shadowing.
11495
11496 * alloc.c (mark_object_loop_halt, mark_object): Use size_t, not int.
11497 Otherwise, GCC 4.6.0 optimizes the loop check away since the check
11498 can always succeed if overflow has undefined behavior.
11499
11500 * search.c (boyer_moore, wordify): Remove vars set but not used.
11501 (wordify): Omit three unnecessary tests.
11502
11503 * indent.c (MULTIBYTE_BYTES_WIDTH): Don't compute wide_column.
11504 All callers changed. This avoids the need for an unused var.
11505
11506 * casefiddle.c (casify_region): Remove var that is set but not used.
11507
11508 * dired.c (file_name_completion): Remove var that is set but not used.
11509
11510 * fileio.c (Finsert_file_contents): Make EOF condition clearer.
11511
11512 * fileio.c (Finsert_file_contents): Avoid signed integer overflow.
11513 (Finsert_file_contents): Remove unnecessary code checking fd.
11514
11515 * minibuf.c (read_minibuf_noninteractive): Use size_t for sizes.
11516 Check for integer overflow on size calculations.
11517
11518 * buffer.c (Fprevious_overlay_change): Remove var that is set
11519 but not used.
11520
11521 * keyboard.c (menu_bar_items, read_char_minibuf_menu_prompt):
11522 Remove vars that are set but not used.
11523 (timer_check_2): Don't assume timer-list and idle-timer-list are lists.
11524 (timer_check_2): Mark vars as initialized.
11525
11526 * gtkutil.c (xg_get_file_with_chooser): Mark var as initialized.
11527
11528 * image.c (lookup_image): Remove var that is set but not used.
11529 (xbm_load): Use parse_p, for gcc -Werror=unused-but-set-variable.
11530
11531 * fontset.c (Finternal_char_font, Ffontset_info): Remove vars
11532 that are set but not used.
11533
11534 * xfns.c (make_invisible_cursor): Don't return garbage
11535 if XCreateBitmapFromData fails (Bug#8410).
11536
11537 * xselect.c (x_get_local_selection, x_handle_property_notify):
11538 Remove vars that are set but not used.
11539
11540 * xfns.c (x_create_tip_frame): Remove var that is set but not used.
11541 (make_invisible_cursor): Initialize a possibly-uninitialized variable.
11542
11543 * xterm.c (x_scroll_bar_to_input_event) [!USE_GTK]:
11544 Remove var that is set but not used.
11545 (scroll_bar_windows_size): Now size_t, not int.
11546 (x_send_scroll_bar_event): Use size_t, not int, for sizes.
11547 Check for overflow.
11548
11549 * xfaces.c (realize_named_face): Remove vars that are set but not used.
11550 (map_tty_color) [!defined MSDOS]: Likewise.
11551
11552 * term.c (tty_write_glyphs): Use size_t; this avoids overflow warning.
11553
11554 * coding.c: Remove vars that are set but not used.
11555 (DECODE_COMPOSITION_RULE): Remove 2nd arg, which is unused.
11556 All callers changed.
11557 (decode_coding_utf_8, decode_coding_utf_16 decode_coding_emacs_mule):
11558 (decode_coding_iso_2022, encode_coding_sjis, encode_coding_big5):
11559 (decode_coding_charset): Remove vars that are set but not used.
11560
11561 * bytecode.c (Fbyte_code) [!defined BYTE_CODE_SAFE]: Remove var
11562 that is set but not used.
11563
11564 * print.c (print_object): Remove var that is set but not used.
11565
11566 Replace 2 copies of readlink code with 1 gnulib version (Bug#8401).
11567 The gnulib version avoids calling malloc in the usual case,
11568 and on 64-bit hosts doesn't have some arbitrary 32-bit limits.
11569 * fileio.c (Ffile_symlink_p): Use emacs_readlink.
11570 * filelock.c (current_lock_owner): Likewise.
11571 * lisp.h (READLINK_BUFSIZE, emacs_readlink): New function.
11572 * sysdep.c: Include allocator.h, careadlinkat.h.
11573 (emacs_no_realloc_allocator): New static constant.
11574 (emacs_readlink): New function.
11575 * deps.mk (sysdep.o): Depend on ../lib/allocator.h and on
11576 ../lib/careadlinkat.h.
11577
11578 2011-04-04 Stefan Monnier <monnier@iro.umontreal.ca>
11579
11580 * keyboard.c (safe_run_hook_funcall): Fix last change (don't stop at the
11581 first non-nil return value).
11582
11583 2011-04-03 Jan Djärv <jan.h.d@swipnet.se>
11584
11585 * nsterm.m (ns_update_auto_hide_menu_bar): Define MAC_OS_X_VERSION_10_6
11586 if not defined (Bug#8403).
11587
11588 2011-04-02 Juanma Barranquero <lekktu@gmail.com>
11589
11590 * xdisp.c (display_count_lines): Remove parameter `start',
11591 unused since 1998-01-01T02:27:27Z!rms@gnu.org. All callers changed.
11592 (get_char_face_and_encoding): Remove parameter `multibyte_p',
11593 unused since 2008-05-14T01:40:23Z!handa@m17n.org. All callers changed.
11594 (fill_stretch_glyph_string): Remove parameters `row' and `area',
11595 unused at least since Kim's GUI unification at 2003-03-16T20:45:46Z!storm@cua.dk
11596 and thereabouts. All callers changed.
11597 (get_per_char_metric): Remove parameter `f', unused since
11598 2008-05-14T01:40:23Z!handa@m17n.org. All callers changed.
11599
11600 2011-04-02 Jim Meyering <meyering@redhat.com>
11601
11602 do not dereference NULL upon failed strdup
11603 * nsfont.m (ns_descriptor_to_entity): Use xstrdup, not strdup.
11604 (ns_get_family): Likewise.
11605
11606 2011-04-02 Juanma Barranquero <lekktu@gmail.com>
11607
11608 * eval.c (unwind_to_catch) [DEBUG_GCPRO]: Remove redundant assignment.
11609
11610 2011-04-02 Jan Djärv <jan.h.d@swipnet.se>
11611
11612 * nsterm.m (ns_update_auto_hide_menu_bar): Only for OSX 10.6 or
11613 later (Bug#8403).
11614
11615 2011-04-01 Stefan Monnier <monnier@iro.umontreal.ca>
11616
11617 Add lexical binding.
11618
11619 * window.c (Ftemp_output_buffer_show): New fun.
11620 (Fsave_window_excursion):
11621 * print.c (Fwith_output_to_temp_buffer): Move to subr.el.
11622
11623 * lread.c (lisp_file_lexically_bound_p): New function.
11624 (Fload): Bind Qlexical_binding.
11625 (readevalloop): Remove `evalfun' arg.
11626 Bind Qinternal_interpreter_environment.
11627 (Feval_buffer): Bind Qlexical_binding.
11628 (defvar_int, defvar_bool, defvar_lisp_nopro, defvar_kboard):
11629 Mark as dynamic.
11630 (syms_of_lread): Declare `lexical-binding'.
11631
11632 * lisp.h (struct Lisp_Symbol): New field `declared_special'.
11633
11634 * keyboard.c (eval_dyn): New fun.
11635 (menu_item_eval_property): Use it.
11636
11637 * image.c (parse_image_spec): Use Ffunctionp.
11638
11639 * fns.c (concat, mapcar1): Accept byte-code-functions.
11640
11641 * eval.c (Fsetq): Handle lexical vars.
11642 (Fdefun, Fdefmacro, Ffunction): Make closures when needed.
11643 (Fdefconst, Fdefvaralias, Fdefvar): Mark as dynamic.
11644 (FletX, Flet): Obey lexical binding.
11645 (Fcommandp): Handle closures.
11646 (Feval): New `lexical' arg.
11647 (eval_sub): New function extracted from Feval. Use it almost
11648 everywhere where Feval was used. Look up vars in lexical env.
11649 Handle closures.
11650 (Ffunctionp): Move from subr.el.
11651 (Ffuncall): Handle closures.
11652 (apply_lambda): Remove `eval_flags'.
11653 (funcall_lambda): Handle closures and new byte-code-functions.
11654 (Fspecial_variable_p): New function.
11655 (syms_of_eval): Initialize the Vinternal_interpreter_environment var,
11656 but without exporting it to Lisp.
11657
11658 * doc.c (Fdocumentation, store_function_docstring):
11659 * data.c (Finteractive_form): Handle closures.
11660
11661 * callint.c (Fcall_interactively): Preserve lexical-binding mode for
11662 interactive spec.
11663
11664 * bytecode.c (Bstack_ref, Bstack_set, Bstack_set2, BdiscardN):
11665 New byte-codes.
11666 (exec_byte_code): New function extracted from Fbyte_code to handle new
11667 calling convention for byte-code-functions. Add new byte-codes.
11668
11669 * buffer.c (defvar_per_buffer): Set new `declared_special' field.
11670
11671 * alloc.c (Fmake_symbol): Init new `declared_special' field.
11672
11673 2011-03-31 Juanma Barranquero <lekktu@gmail.com>
11674
11675 * xdisp.c (redisplay_internal): Fix prototype.
11676
11677 2011-03-31 Eli Zaretskii <eliz@gnu.org>
11678
11679 * xdisp.c (SCROLL_LIMIT): New macro.
11680 (try_scrolling): Use it when setting scroll_limit.
11681 Limit scrolling to 100 screen lines.
11682 (redisplay_window): Even when falling back on "recentering",
11683 position point in the window according to scroll-conservatively,
11684 scroll-margin, and scroll-*-aggressively variables. (Bug#6671)
11685
11686 (try_scrolling): When point is above the window, allow searching
11687 as far as scroll_max, or one screenful, to compute vertical
11688 distance from PT to the scroll margin position. This prevents
11689 try_scrolling from unnecessarily failing when
11690 scroll-conservatively is set to a value slightly larger than the
11691 window height. Clean up the case of PT below the margin at bottom
11692 of window: scroll_max can no longer be INT_MAX. When aggressive
11693 scrolling is in use, don't let point enter the opposite scroll
11694 margin as result of the scroll.
11695 (syms_of_xdisp) <scroll-conservatively>: Document the
11696 threshold of 100 lines for never-recentering scrolling.
11697
11698 2011-03-31 Juanma Barranquero <lekktu@gmail.com>
11699
11700 * dispextern.h (move_it_by_lines):
11701 * xdisp.c (move_it_by_lines): Remove parameter `need_y_p', unused
11702 since 2000-12-29T14:24:09Z!gerd@gnu.org. All callers changed.
11703 (message_log_check_duplicate): Remove parameters `prev_bol' and
11704 `this_bol', unused since 1998-01-01T02:27:27Z!rms@gnu.org. All callers changed.
11705 (redisplay_internal): Remove parameter `preserve_echo_area',
11706 unused since 1999-07-21T21:43:52Z!gerd@gnu.org. All callers changed.
11707
11708 * indent.c (Fvertical_motion):
11709 * window.c (window_scroll_pixel_based, Frecenter):
11710 Don't pass `need_y_p' to `move_it_by_lines'.
11711
11712 2011-03-30 Stefan Monnier <monnier@iro.umontreal.ca>
11713
11714 * eval.c (struct backtrace): Don't cheat with negative numbers, but do
11715 steal a few bits to be more compact.
11716 (interactive_p, Fbacktrace, Fbacktrace_frame, mark_backtrace):
11717 Remove unneeded casts.
11718
11719 * bytecode.c (Fbyte_code): CAR and CDR can GC.
11720
11721 2011-03-30 Zachary Kanfer <zkanfer@gmail.com> (tiny change)
11722
11723 * keyboard.c (Fexecute_extended_command): Do log the "suggest key
11724 binding" message (bug#7967).
11725
11726 2011-03-30 Paul Eggert <eggert@cs.ucla.edu>
11727
11728 Fix more problems found by GCC 4.6.0's static checks.
11729
11730 * unexelf.c (unexec) [! (defined _SYSTYPE_SYSV || defined __sgi)]:
11731 Remove unused local var.
11732
11733 * editfns.c (Fmessage_box): Remove unused local var.
11734
11735 * xdisp.c (try_window_reusing_current_matrix, x_produce_glyphs):
11736 (note_mode_line_or_margin_highlight, note_mouse_highlight):
11737 Omit unused local vars.
11738 * window.c (shrink_windows): Omit unused local var.
11739 * menu.c (digest_single_submenu): Omit unused local var.
11740 * dispnew.c (update_window) [PERIODIC_PREEMPTION_CHECKING]:
11741 Omit unused local var.
11742
11743 * keyboard.c (parse_modifiers_uncached, parse_modifiers):
11744 Don't assume string length fits in int.
11745 (keyremap_step, read_key_sequence): Use size_t for sizes.
11746 (read_key_sequence): Don't check last_real_key_start redundantly.
11747
11748 * callproc.c (Fcall_process, Fcall_process_region): Use SAFE_ALLOCA
11749 instead of alloca (Bug#8344).
11750
11751 * eval.c (Fbacktrace): Don't assume nargs fits in int.
11752 (Fbacktrace_frame): Don't assume nframes fits in int.
11753
11754 * syntax.c (scan_sexps_forward): Avoid pointer wraparound.
11755
11756 * xterm.c (x_make_frame_visible, same_x_server): Redo to avoid overflow
11757 concerns.
11758
11759 * term.c (produce_glyphless_glyph): Remove unnecessary test.
11760
11761 * cm.c (calccost): Turn while-do into do-while, for clarity.
11762
11763 * keyboard.c (syms_of_keyboard): Use the same style as later
11764 in this function when indexing through an array. This also
11765 works around GCC bug 48267.
11766
11767 * image.c (tiff_load): Fix off-by-one image count (Bug#8336).
11768
11769 * xselect.c (x_check_property_data): Return correct size (Bug#8335).
11770
11771 * chartab.c (sub_char_table_ref_and_range): Redo for slight
11772 efficiency gain, and to bypass a gcc -Wstrict-overflow warning.
11773
11774 * keyboard.c, keyboard.h (num_input_events): Now size_t.
11775 This avoids undefined behavior on integer overflow, and is a bit
11776 more convenient anyway since it is compared to a size_t variable.
11777
11778 Variadic C functions now count arguments with size_t, not int.
11779 This avoids an unnecessary limitation on 64-bit machines, which
11780 caused (substring ...) to crash on large vectors (Bug#8344).
11781 * lisp.h (struct Lisp_Subr.function.aMANY): Now takes size_t, not int.
11782 (DEFUN_ARGS_MANY, internal_condition_case_n, safe_call): Likewise.
11783 All variadic functions and their callers changed accordingly.
11784 (struct gcpro.nvars): Now size_t, not int. All uses changed.
11785 * data.c (arith_driver, float_arith_driver): Likewise.
11786 * editfns.c (general_insert_function): Likewise.
11787 * eval.c (struct backtrace.nargs, interactive_p)
11788 (internal_condition_case_n, run_hook_with_args, apply_lambda)
11789 (funcall_lambda, mark_backtrace): Likewise.
11790 * fns.c (concat): Likewise.
11791 * frame.c (x_set_frame_parameters): Likewise.
11792 * fns.c (get_key_arg): Now accepts and returns size_t, and returns
11793 0 if not found, not -1. All callers changed.
11794
11795 * alloc.c (garbage_collect): Don't assume stack size fits in int.
11796 (stack_copy_size): Now size_t, not int.
11797 (stack_copy, stack_copy_size): Define only if MAX_SAVE_STACK > 0.
11798
11799 2011-03-28 Juanma Barranquero <lekktu@gmail.com>
11800
11801 * coding.c (encode_designation_at_bol): Remove parameter `charbuf_end',
11802 unused since 2002-03-01T01:17:24Z!handa@m17n.org and 2008-02-01T16:01:31Z!miles@gnu.org.
11803 All callers changed.
11804
11805 * lisp.h (multibyte_char_to_unibyte):
11806 * character.c (multibyte_char_to_unibyte): Remove parameter `rev_tbl',
11807 unused since 2002-03-01T01:16:34Z!handa@m17n.org and 2008-02-01T16:01:31Z!miles@gnu.org.
11808 * character.h (CHAR_TO_BYTE8):
11809 * cmds.c (internal_self_insert):
11810 * editfns.c (general_insert_function):
11811 * keymap.c (push_key_description):
11812 * search.c (Freplace_match):
11813 * xdisp.c (message_dolog, set_message_1): All callers changed.
11814
11815 2011-03-28 Stefan Monnier <monnier@iro.umontreal.ca>
11816
11817 * keyboard.c (safe_run_hook_funcall): New function.
11818 (safe_run_hooks_1, safe_run_hooks_error, safe_run_hooks): On error,
11819 don't set the hook to nil, but remove the offending function instead.
11820 (Qcommand_hook_internal): Remove, unused.
11821 (syms_of_keyboard): Don't initialize Qcommand_hook_internal nor define
11822 Vcommand_hook_internal.
11823
11824 * eval.c (enum run_hooks_condition): Remove.
11825 (funcall_nil, funcall_not): New functions.
11826 (run_hook_with_args): Call each function through a `funcall' argument.
11827 Remove `cond' argument, now redundant.
11828 (Frun_hooks, Frun_hook_with_args, Frun_hook_with_args_until_success)
11829 (Frun_hook_with_args_until_failure): Adjust accordingly.
11830 (run_hook_wrapped_funcall, Frun_hook_wrapped): New functions.
11831
11832 2011-03-28 Juanma Barranquero <lekktu@gmail.com>
11833
11834 * dispextern.h (string_buffer_position): Remove declaration.
11835
11836 * print.c (strout): Remove parameter `multibyte', unused since
11837 1999-08-21T19:30:21Z!gerd@gnu.org. All callers changed.
11838
11839 * search.c (boyer_moore): Remove parameters `len', `pos' and `lim',
11840 never used since function introduction in 1998-02-08T21:33:56Z!rms@gnu.org.
11841 All callers changed.
11842
11843 * w32.c (_wsa_errlist): Use braces for struct initializers.
11844
11845 * xdisp.c (string_buffer_position_lim): Remove parameter `w',
11846 never used since function introduction in 2001-03-09T18:41:50Z!gerd@gnu.org.
11847 All callers changed.
11848 (string_buffer_position): Likewise. Also, make static (it's never
11849 used outside xdisp.c).
11850 (cursor_row_p): Remove parameter `w', unused since
11851 2000-10-17T16:08:57Z!gerd@gnu.org. All callers changed.
11852 (decode_mode_spec): Remove parameter `precision', introduced during
11853 Gerd Moellmann's rewrite at 1999-07-21T21:43:52Z!gerd@gnu.org, but never used.
11854 All callers changed.
11855
11856 2011-03-27 Jan Djärv <jan.h.d@swipnet.se>
11857
11858 * nsterm.m (syms_of_nsterm): Use doc: for ns-auto-hide-menu-bar.
11859
11860 2011-03-27 Anders Lindgren <andlind@gmail.com>
11861
11862 * nsterm.m (ns_menu_bar_is_hidden): New variable.
11863 (ns_constrain_all_frames, ns_menu_bar_should_be_hidden)
11864 (ns_update_auto_hide_menu_bar): New functions.
11865 (ns_update_begin): Call ns_update_auto_hide_menu_bar.
11866 (applicationDidBecomeActive): Call ns_update_auto_hide_menu_bar and
11867 ns_constrain_all_frames.
11868 (constrainFrameRect): Return at once if ns_menu_bar_should_be_hidden.
11869 (syms_of_nsterm): DEFVAR ns-auto-hide-menu-bar, init to Qnil.
11870
11871 2011-03-27 Jan Djärv <jan.h.d@swipnet.se>
11872
11873 * nsmenu.m (runDialogAt): Remove argument to timer_check.
11874
11875 2011-03-27 Glenn Morris <rgm@gnu.org>
11876
11877 * syssignal.h: Replace RETSIGTYPE with void.
11878 * atimer.c, data.c, dispnew.c, emacs.c, floatfns.c, keyboard.c:
11879 * keyboard.h, lisp.h, process.c, sysdep.c, xterm.c:
11880 Replace SIGTYPE with void everywhere.
11881 * s/usg5-4-common.h (SIGTYPE): Remove definition.
11882 * s/template.h (SIGTYPE): Remove commented out definition.
11883
11884 2011-03-26 Eli Zaretskii <eliz@gnu.org>
11885
11886 * xdisp.c (redisplay_window): Don't check buffer's clip_changed
11887 flag as a prerequisite for invoking try_scrolling. (Bug#6671)
11888
11889 2011-03-26 Juanma Barranquero <lekktu@gmail.com>
11890
11891 * w32.c (read_unc_volume): Use parameter `henum', instead of
11892 global variable `wget_enum_handle'.
11893
11894 * keymap.c (describe_vector): Remove parameters `indices' and
11895 `char_table_depth', unused since 2002-03-01T01:43:26Z!handa@m17n.org.
11896 (describe_map, Fdescribe_vector): Adjust calls to `describe_vector'.
11897
11898 * keyboard.h (timer_check, show_help_echo): Remove unused parameters.
11899
11900 * keyboard.c (timer_check): Remove parameter `do_it_now',
11901 unused since 1996-04-12T06:01:29Z!rms@gnu.org.
11902 (show_help_echo): Remove parameter `ok_to_overwrite_keystroke_echo',
11903 unused since 2008-04-19T19:30:53Z!monnier@iro.umontreal.ca.
11904
11905 * keyboard.c (read_char):
11906 * w32menu.c (w32_menu_display_help):
11907 * xmenu.c (show_help_event, menu_help_callback):
11908 Adjust calls to `show_help_echo'.
11909
11910 * gtkutil.c (xg_maybe_add_timer):
11911 * keyboard.c (readable_events):
11912 * process.c (wait_reading_process_output):
11913 * xmenu.c (x_menu_wait_for_event): Adjust calls to `timer_check'.
11914
11915 * insdel.c (adjust_markers_gap_motion):
11916 Remove; no-op since 1998-01-02T21:29:48Z!rms@gnu.org.
11917 (gap_left, gap_right): Don't call it.
11918
11919 2011-03-25 Chong Yidong <cyd@stupidchicken.com>
11920
11921 * xdisp.c (handle_fontified_prop): Discard changes to clip_changed
11922 incurred during fontification.
11923
11924 2011-03-25 Juanma Barranquero <lekktu@gmail.com>
11925
11926 * buffer.c (defvar_per_buffer): Remove unused parameter `doc'.
11927 (DEFVAR_PER_BUFFER): Don't pass it.
11928
11929 * dispnew.c (row_equal_p, add_row_entry): Remove unused parameter `w'.
11930 (scrolling_window): Don't pass it.
11931
11932 2011-03-25 Juanma Barranquero <lekktu@gmail.com>
11933
11934 * dispextern.h (glyph_matric): Use #if GLYPH_DEBUG, not #ifdef.
11935
11936 * fileio.c (check_executable) [DOS_NT]: Remove unused variables `len'
11937 and `suffix'.
11938 (Fset_file_selinux_context) [HAVE_LIBSELINUX]: Move here declaration
11939 of variables specific to SELinux and computation of `encoded_absname'.
11940
11941 * image.c (XPutPixel): Remove unused variable `height'.
11942
11943 * keyboard.c (make_lispy_event): Remove unused variable `hpos'.
11944
11945 * unexw32.c (get_section_info): Remove unused variable `section'.
11946
11947 * w32.c (stat): Remove unused variables `drive_root' and `devtype'.
11948 (system_process_attributes): Remove unused variable `sess'.
11949 (sys_read): Remove unused variable `err'.
11950
11951 * w32fns.c (top): Wrap variables with #if GLYPH_DEBUG, not #ifdef.
11952 (w32_wnd_proc): Remove unused variable `isdead'.
11953 (unwind_create_frame): Use #if GLYPH_DEBUG, not #ifdef.
11954 (Fx_server_max_request_size): Remove unused variable `dpyinfo'.
11955 (x_create_tip_frame): Remove unused variable `tem'.
11956
11957 * w32inevt.c (w32_console_read_socket):
11958 Remove unused variable `no_events'.
11959
11960 * w32term.c (x_draw_composite_glyph_string_foreground):
11961 Remove unused variable `width'.
11962
11963 2011-03-24 Juanma Barranquero <lekktu@gmail.com>
11964
11965 * w32term.c (x_set_glyph_string_clipping):
11966 Don't pass uninitialized region to CombineRgn.
11967
11968 2011-03-23 Juanma Barranquero <lekktu@gmail.com>
11969
11970 * w32fns.c (x_set_menu_bar_lines): Remove unused variable `olines'.
11971 (w32_wnd_proc): Pass NULL to Windows API, not uninitialized buffer.
11972 (Fx_close_connection): Remove unused variable `i'.
11973
11974 * w32font.c (w32font_draw): Return number of glyphs.
11975 (w32font_open_internal): Remove unused variable `i'.
11976 (w32font_driver): Add missing initializer.
11977
11978 * w32menu.c (utf8to16): Remove unused variable `utf16'.
11979 (fill_in_menu): Remove unused variable `items_added'.
11980
11981 * w32term.c (last_mouse_press_frame): Remove static global variable.
11982 (w32_clip_to_row): Remove unused variable `f'.
11983 (x_delete_terminal): Remove unused variable `i'.
11984
11985 * w32uniscribe.c (uniscribe_shape): Remove unused variable `nclusters'.
11986 (NOTHING): Remove unused static global variable.
11987 (uniscribe_check_otf): Remove unused variable `table'.
11988 (uniscribe_font_driver): Add missing initializers.
11989
11990 2011-03-23 Julien Danjou <julien@danjou.info>
11991
11992 * term.c (Fsuspend_tty, Fresume_tty):
11993 * minibuf.c (read_minibuf, run_exit_minibuf_hook):
11994 * window.c (temp_output_buffer_show):
11995 * insdel.c (signal_before_change):
11996 * frame.c (Fhandle_switch_frame):
11997 * fileio.c (Fdo_auto_save):
11998 * emacs.c (Fkill_emacs):
11999 * editfns.c (save_excursion_restore):
12000 * cmds.c (internal_self_insert):
12001 * callint.c (Fcall_interactively):
12002 * buffer.c (Fkill_all_local_variables):
12003 * keyboard.c (Fcommand_execute, Fsuspend_emacs, safe_run_hooks_1):
12004 Use Frun_hooks.
12005 (command_loop_1): Use Frun_hooks. Call safe_run_hooks
12006 unconditionally since it does the check itself.
12007
12008 2011-03-23 Paul Eggert <eggert@cs.ucla.edu>
12009
12010 Fix more problems found by GCC 4.5.2's static checks.
12011
12012 * coding.c (encode_coding_raw_text): Avoid unnecessary test
12013 the first time through the loop, since we know p0 < p1 then.
12014 This also avoids a gcc -Wstrict-overflow warning.
12015
12016 * lisp.h (SAFE_ALLOCA, SAFE_ALLOCA_LISP): Avoid 'int' overflow
12017 leading to a memory leak, possible in functions like
12018 load_charset_map_from_file that can allocate an unbounded number
12019 of objects (Bug#8318).
12020
12021 * xmenu.c (set_frame_menubar): Use EMACS_UINT, not int, for indexes
12022 that could (at least in theory) be that large.
12023
12024 * xdisp.c (message_log_check_duplicate): Return unsigned long, not int.
12025 This is less likely to overflow, and avoids undefined behavior if
12026 overflow does occur. All callers changed. Use strtoul to scan
12027 for the unsigned long integer.
12028 (pint2hrstr): Simplify and tune code slightly.
12029 This also avoids a (bogus) GCC warning with gcc -Wstrict-overflow.
12030
12031 * scroll.c (do_scrolling): Work around GCC bug 48228.
12032 See <http://gcc.gnu.org/bugzilla/show_bug.cgi?id=48228>.
12033
12034 * frame.c (Fmodify_frame_parameters): Simplify loop counter.
12035 This also avoids a warning with gcc -Wstrict-overflow.
12036 (validate_x_resource_name): Simplify count usage.
12037 This also avoids a warning with gcc -Wstrict-overflow.
12038
12039 * fileio.c (Fcopy_file): Report error if fchown or fchmod
12040 fail (Bug#8306).
12041
12042 * emacs.c (Fdaemon_initialized): Do not ignore I/O errors (Bug#8303).
12043
12044 * process.c (Fmake_network_process): Use socklen_t, not int,
12045 where POSIX says socklen_t is required in portable programs.
12046 This fixes a porting bug on hosts like 64-bit HP-UX, where
12047 socklen_t is wider than int (Bug#8277).
12048 (Fmake_network_process, server_accept_connection):
12049 (wait_reading_process_output, read_process_output):
12050 Likewise.
12051
12052 * process.c: Rename or move locals to avoid shadowing.
12053 (list_processes_1, Fmake_network_process):
12054 (read_process_output_error_handler, exec_sentinel_error_handler):
12055 Rename or move locals.
12056 (Fmake_network_process): Define label "retry_connect" only if needed.
12057 (Fnetwork_interface_info): Fix pointer signedness.
12058 (process_send_signal): Add cast to avoid pointer signedness problem.
12059 (FIRST_PROC_DESC, IF_NON_BLOCKING_CONNECT): Remove unused macros.
12060 (create_process): Use 'volatile' to avoid vfork clobbering (Bug#8298).
12061
12062 Make tparam.h and terminfo.c consistent.
12063 * cm.c (tputs, tgoto, BC, UP): Remove extern decls.
12064 Include tparam.h instead, since it declares them.
12065 * cm.h (PC): Remove extern decl; tparam.h now does this.
12066 * deps.mk (cm.o, terminfo.o): Depend on tparam.h.
12067 * terminfo.c: Include tparam.h, to check interfaces.
12068 (tparm): Make 1st arg a const pointer in decl. Put it at top level.
12069 (tparam): Adjust signature to match interface in tparam.h;
12070 this removes some undefined behavior. Check that outstring and len
12071 are zero, which they always are with Emacs.
12072 * tparam.h (PC, BC, UP): New extern decls.
12073
12074 * xftfont.c (xftfont_shape): Now static, and defined only if needed.
12075 (xftfont_open): Rename locals to avoid shadowing.
12076
12077 * ftfont.c (ftfont_resolve_generic_family): Fix pointer signedness.
12078 (ftfont_otf_capability, ftfont_shape): Omit decls if not needed.
12079 (OTF_TAG_SYM): Omit macro if not needed.
12080 (ftfont_list): Remove unused local.
12081 (get_adstyle_property, ftfont_pattern_entity):
12082 (ftfont_lookup_cache, ftfont_open, ftfont_anchor_point):
12083 Rename locals to avoid shadowing.
12084
12085 * xfont.c (xfont_list_family): Mark var as initialized.
12086
12087 * xml.c (make_dom): Now static.
12088
12089 * composite.c (composition_compute_stop_pos): Rename local to
12090 avoid shadowing.
12091 (composition_reseat_it): Remove unused locals.
12092 (find_automatic_composition, composition_adjust_point): Likewise.
12093 (composition_update_it): Mark var as initialized.
12094 (find_automatic_composition): Mark vars as initialized,
12095 with a FIXME (Bug#8290).
12096
12097 character.h: Rename locals to avoid shadowing.
12098 * character.h (PREV_CHAR_BOUNDARY, FETCH_STRING_CHAR_ADVANCE):
12099 (FETCH_STRING_CHAR_AS_MULTIBYTE_ADVANCE, FETCH_CHAR_ADVANCE):
12100 (FETCH_CHAR_ADVANCE_NO_CHECK, INC_POS, DEC_POS, BUF_INC_POS):
12101 (BUF_DEC_POS): Be more systematic about renaming local temporaries
12102 to avoid shadowing.
12103
12104 * textprop.c (property_change_between_p): Remove; unused.
12105
12106 * intervals.c (interval_start_pos): Now static.
12107
12108 * intervals.h (CHECK_TOTAL_LENGTH): Avoid empty "else".
12109
12110 * atimer.c (start_atimer, append_atimer_lists, set_alarm):
12111 Rename locals to avoid shadowing.
12112
12113 * sound.c (wav_play, au_play, Fplay_sound_internal):
12114 Fix pointer signedness.
12115 (alsa_choose_format): Remove unused local var.
12116 (wav_play): Initialize a variable to 0, to prevent undefined
12117 behavior (Bug#8278).
12118
12119 * region-cache.c (insert_cache_boundary): Redo var to avoid shadowing.
12120
12121 * region-cache.h (pp_cache): New decl, for gcc -Wmissing-prototypes.
12122
12123 * callproc.c (Fcall_process): Use 'volatile' to avoid vfork
12124 clobbering (Bug#8298).
12125 * sysdep.c (sys_subshell): Likewise.
12126 Previously, the sys_subshell 'volatile' was incorrectly IF_LINTted out.
12127
12128 * lisp.h (child_setup): Now NO_RETURN unless DOS_NT.
12129 This should get cleaned up, so that child_setup has the
12130 same signature on all platforms.
12131
12132 * callproc.c (call_process_cleanup): Now static.
12133 (relocate_fd): Rename locals to avoid shadowing.
12134
12135 2011-03-22 Chong Yidong <cyd@stupidchicken.com>
12136
12137 * xterm.c (x_clear_frame): Remove XClearWindow call. This appears
12138 not to be necessary, and produces flickering.
12139
12140 2011-03-20 Glenn Morris <rgm@gnu.org>
12141
12142 * config.in: Remove file.
12143
12144 2011-03-20 Juanma Barranquero <lekktu@gmail.com>
12145
12146 * minibuf.c (Vcompleting_read_function): Don't declare, global variables
12147 are now in src/globals.h.
12148 (syms_of_minibuf): Remove spurious & from previous change.
12149
12150 2011-03-20 Leo Liu <sdl.web@gmail.com>
12151
12152 * minibuf.c (completing-read-function): New variable.
12153 (completing-read-default): Rename from completing-read.
12154 (completing-read): Call completing-read-function.
12155
12156 2011-03-19 Juanma Barranquero <lekktu@gmail.com>
12157
12158 * xfaces.c (Fx_load_color_file):
12159 Read color file from absolute filename (bug#8250).
12160
12161 2011-03-19 Juanma Barranquero <lekktu@gmail.com>
12162
12163 * makefile.w32-in: Update dependencies.
12164
12165 2011-03-17 Eli Zaretskii <eliz@gnu.org>
12166
12167 * makefile.w32-in ($(BLD)/unexw32.$(O)): Depend on $(SRC)/unexec.h.
12168
12169 2011-03-17 Paul Eggert <eggert@cs.ucla.edu>
12170
12171 Fix more problems found by GCC 4.5.2's static checks.
12172
12173 * process.c (make_serial_process_unwind, send_process_trap):
12174 (sigchld_handler): Now static.
12175
12176 * process.c (allocate_pty): Let PTY_ITERATION declare iteration vars.
12177 That way, the code declares only the vars that it needs.
12178 * s/aix4-2.h (PTY_ITERATION): Declare iteration vars.
12179 * s/cygwin.h (PTY_ITERATION): Likewise.
12180 * s/darwin.h (PTY_ITERATION): Likewise.
12181 * s/gnu-linux.h (PTY_ITERATION): Likewise.
12182
12183 * s/irix6-5.h (PTY_OPEN): Declare stb, to loosen coupling.
12184 * process.c (allocate_pty): Don't declare stb unless it's needed.
12185
12186 * bytecode.c (MAYBE_GC): Rewrite so as not to use empty "else".
12187 (CONSTANTLIM): Remove; unused.
12188 (METER_CODE, Bscan_buffer, Bread_char, Bset_mark):
12189 Define only if needed.
12190
12191 * unexelf.c (unexec): Name an expression,
12192 to avoid gcc -Wbad-function-cast warning.
12193 Use a different way to cause a compilation error if anyone uses
12194 n rather than nn, a way that does not involve shadowing.
12195 (ELF_BSS_SECTION_NAME, OLD_PROGRAM_H): Remove; unused.
12196
12197 * deps.mk (unexalpha.o): Remove; unused.
12198
12199 New file unexec.h, the (simple) interface for unexec (Bug#8267).
12200 * unexec.h: New file.
12201 * deps.mk (emacs.o, unexaix.o, unexcw.o, unexcoff.o, unexelf.o):
12202 (unexhp9k800.o, unexmacosx.o, unexsol.o, unexw32.o):
12203 Depend on unexec.h.
12204 * emacs.c [!defined CANNOT_DUMP]: Include unexec.h.
12205 * unexaix.c, unexcoff.c, unexcw.c, unexelf.c, unexhp9k800.c:
12206 * unexmacosx.c, unexsol.c, unexw32.c: Include unexec.h.
12207 Change as necessary to match prototype in unexec.h.
12208
12209 * syntax.c (Fforward_comment, scan_lists): Rename locals to avoid
12210 shadowing.
12211 (back_comment, skip_chars): Mark vars as initialized.
12212
12213 * character.h (FETCH_STRING_CHAR_ADVANCE_NO_CHECK, BUF_INC_POS):
12214 Rename locals to avoid shadowing.
12215
12216 * lread.c (read1): Rewrite so as not to use empty "else".
12217 (Fload, readevalloop, read1): Rename locals to avoid shadowing.
12218
12219 * print.c (Fredirect_debugging_output): Fix pointer signedess.
12220
12221 * lisp.h (debug_output_compilation_hack): Add decl here, to avoid
12222 warning when compiling print.c.
12223
12224 * font.c (font_unparse_fcname): Abort in an "impossible" situation
12225 instead of using an uninitialized var.
12226 (font_sort_entities): Mark var as initialized.
12227
12228 * character.h (FETCH_CHAR_ADVANCE): Rename locals to avoid shadowing.
12229
12230 * font.c (font_unparse_xlfd): Don't mix pointers to variables with
12231 pointers to constants.
12232 (font_parse_fcname): Remove unused vars.
12233 (font_delete_unmatched): Now static.
12234 (font_get_spec): Remove; unused.
12235 (font_style_to_value, font_prop_validate_style, font_unparse_fcname):
12236 (font_update_drivers, Ffont_get_glyphs, font_add_log):
12237 Rename or move locals to avoid shadowing.
12238
12239 * fns.c (require_nesting_list, require_unwind): Now static.
12240 (Ffillarray): Rename locals to avoid shadowing.
12241
12242 * floatfns.c (domain_error2): Define only if needed.
12243 (Ffrexp, Fldexp): Rename locals to avoid shadowing.
12244
12245 * alloc.c (mark_backtrace): Move decl from here ...
12246 * lisp.h: ... to here, so that it can be checked.
12247
12248 * eval.c (call_debugger, do_debug_on_call, grow_specpdl): Now static.
12249 (Fdefvar): Rewrite so as not to use empty "else".
12250 (lisp_indirect_variable): Name an expression,
12251 to avoid gcc -Wbad-function-cast warning.
12252 (Fdefvar): Rename locals to avoid shadowing.
12253
12254 * callint.c (quotify_arg, quotify_args): Now static.
12255 (Fcall_interactively): Rename locals to avoid shadowing.
12256 Use const pointer when appropriate.
12257
12258 * lisp.h (get_system_name, get_operating_system_release):
12259 Move decls here, to check interfaces.
12260 * process.c (get_operating_system_release): Move decl to lisp.h.
12261 * xrdb.c (get_system_name): Likewise.
12262 * editfns.c (init_editfns, Fuser_login_name, Fuser_uid):
12263 (Fuser_real_uid, Fuser_full_name): Remove unnecessary casts,
12264 some of which prompt warnings from gcc -Wbad-function-cast.
12265 (Fformat_time_string, Fencode_time, Finsert_char):
12266 (Ftranslate_region_internal, Fformat):
12267 Rename or remove local vars to avoid shadowing.
12268 (Ftranslate_region_internal): Mark var as initialized.
12269
12270 * doc.c (Fdocumentation, Fsnarf_documentation): Move locals to
12271 avoid shadowing.
12272
12273 * lisp.h (eassert): Check that the argument compiles, even if
12274 ENABLE_CHECKING is not defined.
12275
12276 * data.c (Findirect_variable): Name an expression, to avoid
12277 gcc -Wbad-function-cast warning.
12278 (default_value, arithcompare, arith_driver, arith_error): Now static.
12279 (store_symval_forwarding): Rename local to avoid shadowing.
12280 (Fmake_variable_buffer_local, Fmake_local_variable):
12281 Mark variables as initialized.
12282 (do_blv_forwarding, do_symval_forwarding): Remove; unused.
12283
12284 * alloc.c (check_cons_list): Do not define unless GC_CHECK_CONS_LIST.
12285 (Fmake_vector, Fvector, Fmake_byte_code, Fgarbage_collect):
12286 Rename locals to avoid shadowing.
12287 (mark_stack): Move local variables into the #ifdef region where
12288 they're used.
12289 (BLOCK_INPUT_ALLOC, UNBLOCK_INPUT_ALLOC): Define only if
12290 ! defined SYSTEM_MALLOC && ! defined SYNC_INPUT, as they are not
12291 needed otherwise.
12292 (CHECK_ALLOCATED): Define only if GC_CHECK_MARKED_OBJECTS.
12293 (GC_STRING_CHARS): Remove; not used.
12294 (Fmemory_limit): Cast sbrk's returned value to char *.
12295
12296 * lisp.h (check_cons_list): Declare if GC_CHECK_CONS_LIST; this
12297 avoids undefined behavior in theory.
12298
12299 * regex.c (IF_LINT): Add defn, for benefit of ../lib-src.
12300
12301 Use functions, not macros, for up- and down-casing (Bug#8254).
12302 * buffer.h (DOWNCASE_TABLE, UPCASE_TABLE, DOWNCASE, UPPERCASEP):
12303 (NOCASEP, LOWERCASEP, UPCASE, UPCASE1): Remove. All callers changed
12304 to use the following functions instead of these macros.
12305 (downcase): Adjust to lack of DOWNCASE_TABLE. Return int, not
12306 EMACS_INT, since callers assume the returned value fits in int.
12307 (upcase1): Likewise, for UPCASE_TABLE.
12308 (uppercasep, lowercasep, upcase): New static inline functions.
12309 * editfns.c (Fchar_equal): Remove no-longer-needed workaround for
12310 the race-condition problem in the old DOWNCASE.
12311
12312 * regex.c (CHARSET_LOOKUP_RANGE_TABLE_RAW, POP_FAILURE_REG_OR_COUNT):
12313 Rename locals to avoid shadowing.
12314 (regex_compile, re_match_2_internal): Move locals to avoid shadowing.
12315 (regex_compile, re_search_2, re_match_2_internal):
12316 Remove unused local vars.
12317 (FREE_VAR): Rewrite so as not to use empty "else",
12318 which gcc can warn about.
12319 (regex_compile, re_match_2_internal): Mark locals as initialized.
12320 (RETALLOC_IF): Define only if needed.
12321 (WORDCHAR_P): Likewise. This one is never needed, but is used
12322 only in a comment talking about a compiler bug, so put inside
12323 the #if 0 of that comment.
12324 (CHARSET_LOOKUP_BITMAP, FAIL_STACK_FULL, RESET_FAIL_STACK):
12325 (PUSH_FAILURE_ELT, BUF_PUSH_3, STOP_ADDR_VSTRING):
12326 Remove; unused.
12327
12328 * search.c (boyer_moore): Rename locals to avoid shadowing.
12329 * character.h (FETCH_STRING_CHAR_AS_MULTIBYTE_ADVANCE):
12330 (PREV_CHAR_BOUNDARY): Likewise.
12331
12332 * search.c (simple_search): Remove unused var.
12333
12334 * dired.c (compile_pattern): Move decl from here ...
12335 * lisp.h: ... to here, so that it can be checked.
12336 (struct re_registers): New forward decl.
12337
12338 * character.h (INC_POS, DEC_POS): Rename locals to avoid shadowing.
12339
12340 * indent.c (MULTIBYTE_BYTES_WIDTH): New args bytes, width.
12341 All uses changed.
12342 (MULTIBYTE_BYTES_WIDTH, scan_for_column, compute_motion):
12343 Rename locals to avoid shadowing.
12344 (Fvertical_motion): Mark locals as initialized.
12345
12346 * casefiddle.c (casify_object, casify_region): Now static.
12347 (casify_region): Mark local as initialized.
12348
12349 * cmds.c (internal_self_insert): Rename local to avoid shadowing.
12350
12351 * lisp.h (GCPRO2_VAR, GCPRO3_VAR, GCPRO4_VAR, GCPRO5_VAR, GCPRO6_VAR):
12352 New macros, so that the caller can use some names other than
12353 gcpro1, gcpro2, etc.
12354 (GCPRO2, GCPRO3, GCPRO4, GCPRO5, GCPRO6): Reimplement in terms
12355 of the new macros.
12356 (GCPRO1_VAR, UNGCPRO_VAR): Change the meaning of the second
12357 argument, for consistency with GCPRO2_VAR, etc: it is now the
12358 prefix of the variable, not the variable itself. All uses
12359 changed.
12360 * dired.c (directory_files_internal, file_name_completion):
12361 Rename locals to avoid shadowing.
12362
12363 Fix a race condition diagnosed by gcc -Wsequence-point (Bug#8254).
12364 An expression of the form (DOWNCASE (x) == DOWNCASE (y)), found in
12365 dired.c's scmp function, had undefined behavior.
12366 * lisp.h (DOWNCASE_TABLE, UPCASE_TABLE, DOWNCASE, UPPERCASEP):
12367 (NOCASEP, LOWERCASEP, UPCASE, UPCASE1): Move from here ...
12368 * buffer.h: ... to here, because these macros use current_buffer,
12369 and the new implementation with inline functions needs to have
12370 current_buffer in scope now, rather than later when the macros
12371 are used.
12372 (downcase, upcase1): New static inline functions.
12373 (DOWNCASE, UPCASE1): Reimplement using these functions.
12374 This avoids undefined behavior in expressions like
12375 DOWNCASE (x) == DOWNCASE (y), which previously suffered
12376 from race conditions in accessing the global variables
12377 case_temp1 and case_temp2.
12378 * casetab.c (case_temp1, case_temp2): Remove; no longer needed.
12379 * lisp.h (case_temp1, case_temp2): Remove their decls.
12380 * character.h (ASCII_CHAR_P): Move from here ...
12381 * lisp.h: ... to here, so that the inline functions mentioned
12382 above can use them.
12383
12384 * dired.c (directory_files_internal_unwind): Now static.
12385
12386 * fileio.c (file_name_as_directory, directory_file_name):
12387 (barf_or_query_if_file_exists, auto_save_error, auto_save_1):
12388 Now static.
12389 (file_name_as_directory): Use const pointers when appropriate.
12390 (Fexpand_file_name): Likewise. In particular, newdir might
12391 point at constant storage, so make it a const pointer.
12392 (Fmake_directory_internal, Fread_file_name): Remove unused vars.
12393 (Ffile_selinux_context, Fset_file_selinux_context): Fix pointer
12394 signedness issues.
12395 (Fset_file_times, Finsert_file_contents, auto_save_error):
12396 Rename locals to avoid shadowing.
12397
12398 * minibuf.c (choose_minibuf_frame_1): Now static.
12399 (Ftry_completion, Fall_completions): Rename or remove locals
12400 to avoid shadowing.
12401
12402 * marker.c (bytepos_to_charpos): Remove; unused.
12403
12404 * lisp.h (verify_bytepos, count_markers): New decls,
12405 so that gcc does not warn that these functions aren't declared.
12406
12407 * insdel.c (check_markers, make_gap_larger, make_gap_smaller):
12408 (reset_var_on_error, Fcombine_after_change_execute_1): Now static.
12409 (CHECK_MARKERS): Redo to avoid gcc -Wempty-body diagnostic.
12410 (copy_text): Remove unused local var.
12411
12412 * filelock.c (within_one_second): Now static.
12413 (lock_file_1): Rename local to avoid shadowing.
12414
12415 * buffer.c (fix_overlays_before): Mark locals as initialized.
12416 (fix_start_end_in_overlays): Likewise. This function should be
12417 simplified by using pointers-to-pointers, but that's a different
12418 matter.
12419 (switch_to_buffer_1): Now static.
12420 (Fkill_buffer, record_buffer, Fbury_buffer, Fset_buffer_multibyte):
12421 (report_overlay_modification): Rename locals to avoid shadowing.
12422
12423 * sysdep.c (system_process_attributes): Rename vars to avoid shadowing.
12424 Fix pointer signedness issue.
12425 (sys_subshell): Mark local as volatile if checking for lint,
12426 to suppress a gcc -Wclobbered warning that does not seem to be right.
12427 (MAXPATHLEN): Define only if needed.
12428
12429 * process.c (serial_open, serial_configure): Move decls from here ...
12430 * systty.h: ... to here, so that they can be checked.
12431
12432 * fns.c (get_random, seed_random): Move extern decls from here ...
12433 * lisp.h: ... to here, so that they can be checked.
12434
12435 * sysdep.c (reset_io): Now static.
12436 (wait_for_termination_signal): Remove; unused.
12437
12438 * keymap.c (keymap_parent, keymap_memberp, map_keymap_internal):
12439 (copy_keymap_item, append_key, push_text_char_description):
12440 Now static.
12441 (Fwhere_is_internal): Don't test CONSP (sequences) unnecessarily.
12442 (DENSE_TABLE_SIZE): Remove; unused.
12443 (get_keymap, access_keymap, Fdefine_key, Fwhere_is_internal):
12444 (describe_map_tree):
12445 Rename locals to avoid shadowing.
12446
12447 * keyboard.c: Declare functions static if they are not used elsewhere.
12448 (echo_char, echo_dash, cmd_error, top_level_2):
12449 (poll_for_input, handle_async_input): Now static.
12450 (read_char, kbd_buffer_get_event, make_lispy_position):
12451 (make_lispy_event, make_lispy_movement, apply_modifiers):
12452 (decode_keyboard_code, tty_read_avail_input, menu_bar_items):
12453 (parse_tool_bar_item, read_key_sequence, Fread_key_sequence):
12454 (Fread_key_sequence_vector): Rename locals to avoid shadowing.
12455 (read_key_sequence, read_char): Mark locals as initialized.
12456 (Fexit_recursive_edit, Fabort_recursive_edit): Mark with NO_RETURN.
12457
12458 * keyboard.h (make_ctrl_char): New decl.
12459 (mark_kboards): Move decl here ...
12460 * alloc.c (mark_kboards): ... from here.
12461
12462 * lisp.h (force_auto_save_soon): New decl.
12463
12464 * emacs.c (init_cmdargs): Rename local to avoid shadowing.
12465 (DEFINE_DUMMY_FUNCTION): New macro.
12466 (__do_global_ctors, __do_global_ctors_aux, __do_global_dtors, __main):
12467 Use it.
12468 (main): Add casts to avoid warnings
12469 if GCC considers string literals to be constants.
12470
12471 * lisp.h (fatal_error_signal): Add decl, since it's exported.
12472
12473 * dbusbind.c: Pointer signedness fixes.
12474 (xd_signature, xd_append_arg, xd_initialize):
12475 (Fdbus_call_method, Fdbus_call_method_asynchronously):
12476 (Fdbus_method_return_internal, Fdbus_method_error_internal):
12477 (Fdbus_send_signal, xd_read_message_1, Fdbus_register_service):
12478 (Fdbus_register_signal): Use SSDATA when the context wants char *.
12479
12480 * dbusbind.c (Fdbus_init_bus): Add cast to avoid warning
12481 if GCC considers string literals to be constants.
12482 (Fdbus_register_service, Fdbus_register_method): Remove unused vars.
12483
12484 2011-03-16 Stefan Monnier <monnier@iro.umontreal.ca>
12485
12486 * print.c (PRINT_CIRCLE_CANDIDATE_P): New macro.
12487 (print_preprocess, print_object): New macro to fix last change.
12488
12489 * print.c (print_preprocess): Don't forget font objects.
12490
12491 2011-03-16 Juanma Barranquero <lekktu@gmail.com>
12492
12493 * emacs.c (USAGE3): Doc fixes.
12494
12495 2011-03-15 Andreas Schwab <schwab@linux-m68k.org>
12496
12497 * coding.c (detect_coding_iso_2022): Reorganize code to clarify
12498 structure.
12499
12500 2011-03-14 Juanma Barranquero <lekktu@gmail.com>
12501
12502 * lisp.h (VWindow_system, Qfile_name_history):
12503 * keyboard.h (lispy_function_keys) [WINDOWSNT]:
12504 * w32term.h (w32_system_caret_hwnd, w32_system_caret_height)
12505 (w32_system_caret_x, w32_system_caret_y): Declare extern.
12506
12507 * w32select.c: Don't #include "keyboard.h".
12508 (run_protected): Add extern declaration for waiting_for_input.
12509
12510 * w32.c (Qlocal, noninteractive1, inhibit_window_system):
12511 * w32console.c (detect_input_pending, read_input_pending)
12512 (encode_terminal_code):
12513 * w32fns.c (quit_char, lispy_function_keys, Qtooltip)
12514 (w32_system_caret_hwnd, w32_system_caret_height, w32_system_caret_x)
12515 (w32_system_caret_y, Qfile_name_history):
12516 * w32font.c (w32font_driver, QCantialias, QCotf, QClang):
12517 * w32inevt.c (reinvoke_input_signal, lispy_function_keys):
12518 * w32menu.c (Qmenu_bar, QCtoggle, QCradio, Qoverriding_local_map)
12519 (Qoverriding_terminal_local_map, Qmenu_bar_update_hook):
12520 * w32proc.c (Qlocal, report_file_error):
12521 * w32term.c (Vwindow_system, updating_frame):
12522 * w32uniscribe.c (initialized, uniscribe_font_driver):
12523 Remove unneeded extern declarations.
12524
12525 2011-03-14 Chong Yidong <cyd@stupidchicken.com>
12526
12527 * buffer.c (Fmake_indirect_buffer): Fix incorrect assertions.
12528
12529 2011-03-13 Chong Yidong <cyd@stupidchicken.com>
12530
12531 * buffer.h (BUF_BEGV, BUF_BEGV_BYTE, BUF_ZV, BUF_ZV_BYTE, BUF_PT)
12532 (BUF_PT_BYTE): Rewrite to handle indirect buffers (Bug#8219).
12533 These macros can no longer be used for assignment.
12534
12535 * buffer.c (Fget_buffer_create, Fmake_indirect_buffer):
12536 Assign struct members directly, instead of using BUF_BEGV etc.
12537 (record_buffer_markers, fetch_buffer_markers): New functions for
12538 recording and fetching special buffer markers.
12539 (set_buffer_internal_1, set_buffer_temp): Use them.
12540
12541 * lread.c (unreadchar): Use SET_BUF_PT_BOTH.
12542
12543 * insdel.c (adjust_point): Use SET_BUF_PT_BOTH.
12544
12545 * intervals.c (temp_set_point_both): Use SET_BUF_PT_BOTH.
12546 (get_local_map): Use SET_BUF_BEGV_BOTH and SET_BUF_ZV_BOTH.
12547
12548 * xdisp.c (hscroll_window_tree):
12549 (reconsider_clip_changes): Use PT instead of BUF_PT.
12550
12551 2011-03-13 Eli Zaretskii <eliz@gnu.org>
12552
12553 * makefile.w32-in ($(BLD)/editfns.$(O)): Depend on
12554 $(EMACS_ROOT)/lib/intprops.h.
12555
12556 2011-03-13 Paul Eggert <eggert@cs.ucla.edu>
12557
12558 Fix more problems found by GCC 4.5.2's static checks.
12559
12560 * gtkutil.c (xg_get_pixbuf_from_pixmap): Add cast from char *
12561 to unsigned char * to avoid compiler diagnostic.
12562 (xg_free_frame_widgets): Make it clear that a local variable is
12563 needed only if USE_GTK_TOOLTIP.
12564 (gdk_window_get_screen): Make it clear that this macro is needed
12565 only if USE_GTK_TOOLTIP.
12566 (int_gtk_range_get_value): New function, which avoids a diagnostic
12567 from gcc -Wbad-function-cast.
12568 (xg_set_toolkit_scroll_bar_thumb): Use it.
12569 (xg_tool_bar_callback, xg_tool_item_stale_p): Rewrite to avoid
12570 diagnostic from gcc -Wbad-function-cast.
12571 (get_utf8_string, xg_get_file_with_chooser):
12572 Rename locals to avoid shadowing.
12573 (create_dialog): Move locals to avoid shadowing.
12574
12575 * xgselect.c (xg_select): Remove unused var.
12576
12577 * image.c (four_corners_best): Mark locals as initialized.
12578 (gif_load): Initialize transparent_p to zero (Bug#8238).
12579 Mark another local as initialized.
12580 (my_png_error, my_error_exit): Mark with NO_RETURN.
12581
12582 * image.c (clear_image_cache): Now static.
12583 (DIM, HAVE_STDLIB_H_1): Remove unused macros.
12584 (xpm_load): Redo to avoid "discards qualifiers" gcc warning.
12585 (x_edge_detection): Remove unnecessary cast that
12586 gcc -Wbad-function-cast diagnoses.
12587 (gif_load): Fix pointer signedness.
12588 (clear_image_cache, xbm_read_bitmap_data, x_detect_edges):
12589 (jpeg_load, gif_load): Rename locals to avoid shadowing.
12590
12591 2011-03-12 Paul Eggert <eggert@cs.ucla.edu>
12592
12593 Improve quality of tests for time stamp overflow.
12594 For example, without this patch (encode-time 0 0 0 1 1
12595 1152921504606846976) returns the obviously-bogus value (-948597
12596 62170) on my RHEL 5.5 x86-64 host. With the patch, it correctly
12597 reports time overflow. See
12598 <http://lists.gnu.org/archive/html/emacs-devel/2011-03/msg00470.html>.
12599 * deps.mk (editfns.o): Depend on ../lib/intprops.h.
12600 * editfns.c: Include limits.h and intprops.h.
12601 (TIME_T_MIN, TIME_T_MAX): New macros.
12602 (time_overflow): Move earlier, to before first use.
12603 (hi_time, lo_time): New functions, for an accurate test for
12604 out-of-range times.
12605 (Fcurrent_time, Fget_internal_run_time, make_time): Use them.
12606 (Fget_internal_run_time): Don't assume time_t fits in int.
12607 (make_time): Use list2 instead of Fcons twice.
12608 (Fdecode_time): More accurate test for out-of-range times.
12609 (check_tm_member): New function.
12610 (Fencode_time): Use it, to test for out-of-range times.
12611 (lisp_time_argument): Don't rely on undefined left-shift and
12612 right-shift behavior when checking for time stamp overflow.
12613
12614 * editfns.c (time_overflow): New function, refactoring common code.
12615 (Fformat_time_string, Fdecode_time, Fencode_time):
12616 (Fcurrent_time_string): Use it.
12617
12618 Move 'make_time' to be next to its inverse 'lisp_time_argument'.
12619 * dired.c (make_time): Move to ...
12620 * editfns.c (make_time): ... here.
12621 * systime.h: Note the move.
12622
12623 2011-03-12 YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
12624
12625 * fringe.c (update_window_fringes): Remove unused variables.
12626
12627 * unexmacosx.c (copy_data_segment): Also copy __got section.
12628 (Bug#8223)
12629
12630 2011-03-12 Eli Zaretskii <eliz@gnu.org>
12631
12632 * termcap.c [MSDOS]: Include "msdos.h".
12633 (find_capability, tgetnum, tgetflag, tgetstr, tputs, tgetent):
12634 Constify `char *' arguments and their references according to
12635 prototypes in tparam.h.
12636
12637 * deps.mk (termcap.o): Depend on tparam.h and msdos.h.
12638
12639 * msdos.c (XMenuAddPane): 3rd argument is `const char *' now.
12640 Adapt all references accordingly.
12641
12642 * msdos.h (XMenuAddPane): 3rd argument is `const char *' now.
12643
12644 2011-03-11 Tom Tromey <tromey@redhat.com>
12645
12646 * buffer.c (syms_of_buffer): Remove obsolete comment.
12647
12648 2011-03-11 Eli Zaretskii <eliz@gnu.org>
12649
12650 * termhooks.h (encode_terminal_code): Declare prototype.
12651
12652 * msdos.c (encode_terminal_code): Don't declare prototype.
12653
12654 * term.c (encode_terminal_code): Now external again, used by
12655 w32console.c and msdos.c.
12656
12657 * makefile.w32-in ($(BLD)/term.$(O), ($(BLD)/tparam.$(O)):
12658 Depend on $(SRC)/tparam.h, see 2011-03-11T07:24:21Z!eggert@cs.ucla.edu.
12659
12660 2011-03-11 Paul Eggert <eggert@cs.ucla.edu>
12661
12662 Fix some minor problems found by GCC 4.5.2's static checks.
12663
12664 * fringe.c (update_window_fringes): Mark locals as initialized
12665 (Bug#8227).
12666 (destroy_fringe_bitmap, init_fringe_bitmap): Now static.
12667
12668 * alloc.c (mark_fringe_data): Move decl from here ...
12669 * lisp.h (mark_fringe_data) [HAVE_WINDOW_SYSTEM]: ... to here,
12670 to check its interface.
12671 (init_fringe_once): Do not declare unless HAVE_WINDOW_SYSTEM.
12672
12673 * fontset.c (free_realized_fontset): Now static.
12674 (Fset_fontset_font): Rename local to avoid shadowing.
12675 (fontset_font): Mark local as initialized.
12676 (FONTSET_SPEC, FONTSET_REPERTORY, RFONT_DEF_REPERTORY): Remove; unused.
12677
12678 * xrdb.c: Include "xterm.h", to check x_load_resources's interface.
12679
12680 * xselect.c (x_disown_buffer_selections): Remove; not used.
12681 (TRACE3) [!defined TRACE_SELECTION]: Remove; not used.
12682 (x_own_selection, Fx_disown_selection_internal): Rename locals
12683 to avoid shadowing.
12684 (x_handle_dnd_message): Remove local to avoid shadowing.
12685
12686 * lisp.h (GCPRO1_VAR, UNGCPRO_VAR): New macros,
12687 so that the caller can use some name other than gcpro1.
12688 (GCPRO1, UNGCPRO): Reimplement in terms of the new macros.
12689 * xfns.c (Fx_create_frame, x_create_tip_frame, Fx_show_tip):
12690 (Fx_backspace_delete_keys_p):
12691 Use them to avoid shadowing, and rename vars to avoid shadowing.
12692 (x_decode_color, x_set_name, x_window): Now static.
12693 (Fx_create_frame): Add braces to silence GCC warning.
12694 (Fx_file_dialog, Fx_select_font): Fix pointer signedness.
12695 (x_real_positions, xg_set_icon_from_xpm_data, x_create_tip_frame):
12696 Remove unused locals.
12697 (Fx_create_frame, x_create_tip_frame, Fx_show_tip):
12698 (Fx_backspace_delete_keys_p): Rename locals to avoid shadowing.
12699 Some of these renamings use the new GCPRO1_VAR and UNGCPRO_VAR
12700 macros.
12701
12702 * xterm.h (x_mouse_leave): New decl.
12703
12704 * xterm.c (x_copy_dpy_color, x_focus_on_frame, x_unfocus_frame):
12705 Remove unused functions.
12706 (x_shift_glyphs_for_insert, XTflash, XTring_bell):
12707 (x_calc_absolute_position): Now static.
12708 (XTread_socket): Don't define label "out" unless it's used.
12709 Don't declare local "event" unless it's used.
12710 (x_iconify_frame, x_free_frame_resources): Don't declare locals
12711 unless they are used.
12712 (XEMBED_VERSION, xembed_set_info): Don't define unless needed.
12713 (x_fatal_error_signal): Remove; not used.
12714 (x_draw_image_foreground, redo_mouse_highlight, XTmouse_position):
12715 (x_scroll_bar_report_motion, handle_one_xevent, x_draw_bar_cursor):
12716 (x_error_catcher, x_connection_closed, x_error_handler):
12717 (x_error_quitter, xembed_send_message, x_iconify_frame):
12718 (my_log_handler): Rename locals to avoid shadowing.
12719 (x_delete_glyphs, x_ins_del_lines): Mark with NO_RETURN.
12720 (x_connection_closed): Tell GCC not to suggest NO_RETURN.
12721
12722 * xfaces.c (clear_face_cache, Fx_list_fonts, Fface_font):
12723 Rename or move locals to avoid shadowing.
12724 (tty_defined_color, merge_face_heights): Now static.
12725 (free_realized_faces_for_fontset): Remove; not used.
12726 (Fx_list_fonts): Mark variable that gcc -Wuninitialized
12727 does not deduce is never used uninitialized.
12728 (STRDUPA, LSTRDUPA, FONT_POINT_SIZE_QUANTUM): Remove; not used.
12729 (LFACEP): Define only if XASSERTS, as it's not needed otherwise.
12730
12731 * terminal.c (store_terminal_param): Now static.
12732
12733 * xmenu.c (menu_highlight_callback): Now static.
12734 (set_frame_menubar): Remove unused local.
12735 (xmenu_show): Rename parameter to avoid shadowing.
12736 (xmenu_show, xdialog_show, xmenu_show): Make local pointers "const"
12737 since they might point to immutable storage.
12738 (next_menubar_widget_id): Declare only if USE_X_TOOLKIT,
12739 since it's unused otherwise.
12740
12741 * xdisp.c (produce_glyphless_glyph): Initialize lower_xoff.
12742 Add a FIXME, since the code still doesn't look right. (Bug#8215)
12743 (Fcurrent_bidi_paragraph_direction): Simplify slightly; this
12744 avoids a gcc -Wuninitialized diagnostic.
12745 (display_line, BUILD_COMPOSITE_GLYPH_STRING, draw_glyphs):
12746 (note_mouse_highlight): Mark variables that gcc -Wuninitialized
12747 does not deduce are never used uninitialized.
12748
12749 * lisp.h (IF_LINT): New macro, copied from ../lib-src/emacsclient.c.
12750
12751 * xdisp.c (redisplay_window): Rename local to avoid shadowing.
12752 * window.c (window_loop, size_window):
12753 (run_window_configuration_change_hook, enlarge_window): Likewise.
12754
12755 * window.c (display_buffer): Now static.
12756 (size_window): Mark variables that gcc -Wuninitialized
12757 does not deduce are never used uninitialized.
12758 * window.h (check_all_windows): New decl, to forestall
12759 gcc -Wmissing-prototypes diagnostic.
12760 * dispextern.h (bidi_dump_cached_states): Likewise.
12761
12762 * charset.h (CHECK_CHARSET_GET_CHARSET): Rename locals to avoid
12763 shadowing.
12764 * charset.c (map_charset_for_dump, Fchar_charset): Likewise.
12765 Include <limits.h>.
12766 (Fsort_charsets): Redo min/max calculation to shorten the code a bit
12767 and to avoid gcc -Wuninitialized warning.
12768 (load_charset_map): Mark variables that gcc -Wuninitialized
12769 does not deduce are never used uninitialized.
12770 (load_charset): Abort instead of using uninitialized var (Bug#8229).
12771
12772 * coding.c (coding_set_source, coding_set_destination):
12773 Use "else { /* comment */ }" rather than "else /* comment */;"
12774 for clarity, and to avoid gcc -Wempty-body warning.
12775 (Fdefine_coding_system_internal): Don't redeclare 'i' inside
12776 a block, when the outer 'i' will do.
12777 (decode_coding_utf_8, decode_coding_utf_16, detect_coding_emacs_mule):
12778 (emacs_mule_char, decode_coding_emacs_mule, detect_coding_iso_2022):
12779 (decode_coding_iso_2022, decode_coding_sjis, decode_coding_big5):
12780 (decode_coding_raw_text, decode_coding_charset, get_translation_table):
12781 (Fdecode_sjis_char, Fdefine_coding_system_internal):
12782 Rename locals to avoid shadowing.
12783 * character.h (FETCH_STRING_CHAR_ADVANCE): Likewise.
12784 * coding.c (emacs_mule_char, encode_invocation_designation):
12785 Now static, since they're not used elsewhere.
12786 (decode_coding_iso_2022): Add "default: abort ();" as a safety check.
12787 (decode_coding_object, encode_coding_object, detect_coding_system):
12788 (decode_coding_emacs_mule): Mark variables that gcc
12789 -Wuninitialized does not deduce are never used uninitialized.
12790 (detect_coding_iso_2022): Initialize a local variable that might
12791 be used uninitialized. Leave a FIXME because it's not clear that
12792 this initialization is needed. (Bug#8211)
12793 (ISO_CODE_LF, ISO_CODE_CR, CODING_ISO_FLAG_EUC_TW_SHIFT):
12794 (ONE_MORE_BYTE_NO_CHECK, UTF_BOM, UTF_16_INVALID_P):
12795 (SHIFT_OUT_OK, ENCODE_CONTROL_SEQUENCE_INTRODUCER):
12796 (ENCODE_DIRECTION_R2L, ENCODE_DIRECTION_L2R):
12797 Remove unused macros.
12798
12799 * category.c (hash_get_category_set): Remove unused local var.
12800 (copy_category_table): Now static, since it's not used elsewhere.
12801 * character.c (string_count_byte8): Likewise.
12802
12803 * ccl.c (CCL_WRITE_STRING, CCL_ENCODE_CHAR, Fccl_execute_on_string):
12804 (Fregister_code_conversion_map): Rename locals to avoid shadowing.
12805
12806 * chartab.c (copy_sub_char_table): Now static, since it's not used
12807 elsewhere.
12808 (sub_char_table_ref_and_range, char_table_ref_and_range):
12809 Rename locals to avoid shadowing.
12810 (ASET_RANGE, GET_SUB_CHAR_TABLE): Remove unused macros.
12811
12812 * bidi.c (bidi_check_type): Now static, since it's not used elsewhere.
12813 (BIDI_BOB): Remove unused macro.
12814
12815 * cm.c (cmgoto): Mark variables that gcc -Wuninitialized does not
12816 deduce are never used uninitialized.
12817 * term.c (encode_terminal_code): Likewise.
12818
12819 * term.c (encode_terminal_code): Now static. Remove unused local.
12820
12821 * tparam.h: New file.
12822 * term.c, tparam.h: Include it.
12823 * deps.mk (term.o, tparam.o): Depend on tparam.h.
12824 * term.c (tputs, tgetent, tgetflag, tgetnum, tparam, tgetstr):
12825 Move these decls to tparam.h, and make them agree with what
12826 is actually in tparam.c. The previous trick of using incompatible
12827 decls in different modules does not conform to the C standard.
12828 All callers of tparam changed to use tparam's actual API.
12829 * tparam.c (tparam1, tparam, tgoto):
12830 Use const pointers where appropriate.
12831
12832 * cm.c (calccost, cmgoto): Use const pointers where appropriate.
12833 * cm.h (struct cm): Likewise.
12834 * dispextern.h (do_line_insertion_deletion_costs): Likewise.
12835 * scroll.c (ins_del_costs, do_line_insertion_deletion_costs): Likewise.
12836 * term.c (tty_ins_del_lines, calculate_costs, struct fkey_table):
12837 (term_get_fkeys_1, append_glyphless_glyph, produce_glyphless_glyph):
12838 (turn_on_face, init_tty): Likewise.
12839 * termchar.h (struct tty_display_info): Likewise.
12840
12841 * term.c (term_mouse_position): Rename local to avoid shadowing.
12842
12843 * alloc.c (mark_ttys): Move decl from here ...
12844 * lisp.h (mark_ttys): ... to here, so that it's checked against defn.
12845
12846 2011-03-11 Andreas Schwab <schwab@linux-m68k.org>
12847
12848 * .gdbinit (pwinx, xbuffer): Fix access to buffer name.
12849
12850 2011-03-09 Juanma Barranquero <lekktu@gmail.com>
12851
12852 * search.c (compile_pattern_1): Remove argument regp, unused since
12853 revid:rms@gnu.org-19941211082627-3x1g1wyqkjmwloig.
12854 (compile_pattern): Don't pass it.
12855
12856 2011-03-08 Jan Djärv <jan.h.d@swipnet.se>
12857
12858 * xterm.h (DEFAULT_GDK_DISPLAY): New define.
12859 (GDK_WINDOW_XID, gtk_widget_get_preferred_size): New defines
12860 for ! HAVE_GTK3.
12861 (GTK_WIDGET_TO_X_WIN): Use GDK_WINDOW_XID.
12862
12863 * xmenu.c (menu_position_func): Call gtk_widget_get_preferred_size.
12864
12865 * gtkutil.c: Include gtkx.h if HAVE_GTK3. If ! HAVE_GTK3, define
12866 gdk_window_get_screen, gdk_window_get_geometry,
12867 gdk_x11_window_lookup_for_display and GDK_KEY_g.
12868 (xg_set_screen): Use DEFAULT_GDK_DISPLAY.
12869 (xg_get_pixbuf_from_pixmap): New function.
12870 (xg_get_pixbuf_from_pix_and_mask): Change parameters from GdkPixmap
12871 to Pixmap, take frame as parameter, remove GdkColormap parameter.
12872 Call xg_get_pixbuf_from_pixmap instead of
12873 gdk_pixbuf_get_from_drawable.
12874 (xg_get_image_for_pixmap): Do not make GdkPixmaps, call
12875 xg_get_pixbuf_from_pix_and_mask with Pixmap parameters instead.
12876 (xg_check_special_colors): Use GtkStyleContext and its functions
12877 for HAVE_GTK3.
12878 (xg_prepare_tooltip, xg_hide_tooltip): Call gdk_window_get_screen.
12879 (xg_prepare_tooltip, create_dialog, menubar_map_cb)
12880 (xg_update_frame_menubar, xg_tool_bar_detach_callback)
12881 (xg_tool_bar_attach_callback, xg_update_tool_bar_sizes):
12882 Call gtk_widget_get_preferred_size.
12883 (xg_frame_resized): gdk_window_get_geometry only takes 5
12884 parameters.
12885 (xg_win_to_widget, xg_event_is_for_menubar):
12886 Call gdk_x11_window_lookup_for_display.
12887 (xg_set_widget_bg): New function.
12888 (delete_cb): New function.
12889 (xg_create_frame_widgets): Connect delete-event to delete_cb.
12890 Call xg_set_widget_bg. Only set background pixmap for ! HAVE_GTK3
12891 (xg_set_background_color): Call xg_set_widget_bg.
12892 (xg_set_frame_icon): Call xg_get_pixbuf_from_pix_and_mask.
12893 (xg_create_scroll_bar): vadj is a GtkAdjustment for HAVE_GTK3.
12894 Only call gtk_range_set_update_policy if ! HAVE_GTK3.
12895 (xg_make_tool_item): Only connect xg_tool_bar_item_expose_callback
12896 if ! HAVE_GTK3.
12897 (update_frame_tool_bar): Call gtk_widget_hide.
12898 (xg_initialize): Use GDK_KEY_g.
12899
12900 * xsmfns.c (gdk_set_sm_client_id): Define to gdk_set_sm_client_id
12901 if ! HAVE_GTK3
12902 (x_session_initialize): Call gdk_x11_set_sm_client_id.
12903
12904 * xterm.c (XFillRectangle): Use cairo routines for HAVE_GTK3.
12905 (x_term_init): Disable Xinput(2) with GDK_CORE_DEVICE_EVENTS.
12906 Load ~/emacs.d/gtkrc only for ! HAVE_GTK3.
12907
12908 2011-03-08 Juanma Barranquero <lekktu@gmail.com>
12909
12910 * w32xfns.c (select_palette): Check success of RealizePalette against
12911 GDI_ERROR, not zero.
12912
12913 See ChangeLog.11 for earlier changes.
12914
12915 ;; Local Variables:
12916 ;; coding: utf-8
12917 ;; End:
12918
12919 Copyright (C) 2011-2012 Free Software Foundation, Inc.
12920
12921 This file is part of GNU Emacs.
12922
12923 GNU Emacs is free software: you can redistribute it and/or modify
12924 it under the terms of the GNU General Public License as published by
12925 the Free Software Foundation, either version 3 of the License, or
12926 (at your option) any later version.
12927
12928 GNU Emacs is distributed in the hope that it will be useful,
12929 but WITHOUT ANY WARRANTY; without even the implied warranty of
12930 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12931 GNU General Public License for more details.
12932
12933 You should have received a copy of the GNU General Public License
12934 along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>.