Commit | Line | Data |
---|---|---|
40f18bf3 JD |
1 | 2013-12-08 Jan Djärv <jan.h.d@swipnet.se> |
2 | ||
b3e42b70 JD |
3 | * nsterm.m (updateFrameSize:): Fix GNUStep toolbar not updating. |
4 | ||
40f18bf3 JD |
5 | * emacs.c (main): Call fixup_locale a second time for GNUStep. |
6 | ||
acfe4602 MR |
7 | 2013-12-08 Martin Rudalics <rudalics@gmx.at> |
8 | ||
9 | * frame.c (x_set_font): Mark frame as garbaged (Bug#16028). | |
10 | ||
95b3d095 PE |
11 | 2013-12-08 Paul Eggert <eggert@cs.ucla.edu> |
12 | ||
e9551b12 PE |
13 | Use libcrypto's checksum implementations if available, for speed. |
14 | * Makefile.in (LIB_CRYPTO): New macro. | |
15 | (LIBES): Use it. | |
16 | ||
95b3d095 PE |
17 | * frame.h (SET_FRAME_VISIBLE): Now an inline function. |
18 | The macro didn't conform to C99 due to type mismatch, | |
19 | which caused compilation failure with Sun C 5.12, | |
20 | and it was confusing anyway. Include window.h to declare | |
21 | redisplay_other_windows. | |
22 | ||
0d9cba29 SM |
23 | 2013-12-08 Stefan Monnier <monnier@iro.umontreal.ca> |
24 | ||
25 | * window.c (set_window_buffer): Update mode line (bug#16084). | |
26 | ||
67840e66 PE |
27 | 2013-12-07 Paul Eggert <eggert@cs.ucla.edu> |
28 | ||
29 | Fix minor problems found by static checking. | |
30 | * keyboard.c (poll_for_input_1, input_polling_used): | |
31 | Define only if HAVE_NTGUI. | |
32 | * xmenu.c (popup_activate_callback): Omit unnecessary | |
33 | check against USE_X_TOOLKIT, which must be defined here anyway. | |
34 | * xterm.c, xterm.h (x_dispatch_event) [! (USE_X_TOOLKIT || USE_MOTIF)]: | |
35 | Now static. | |
36 | ||
947003b5 MR |
37 | 2013-12-07 Martin Rudalics <rudalics@gmx.at> |
38 | ||
39 | * w32term.c (w32_read_socket): Fix int/Lisp_Object type mixup. | |
40 | ||
7def8cbd JD |
41 | 2013-12-07 Jan Djärv <jan.h.d@swipnet.se> |
42 | ||
c4142a83 JD |
43 | * gtkutil.c (tb_size_cb): Call xg_height_or_width_changed. |
44 | ||
1bb2debd JD |
45 | * nsterm.m (x_set_window_size): Remove fprintf. |
46 | (init): Define always. Set applicationDidFinishLaunchingCalled | |
47 | for GNUStep. | |
0d9cba29 SM |
48 | (applicationDidFinishLaunching:): |
49 | Set applicationDidFinishLaunchingCalled. | |
1bb2debd JD |
50 | (applicationDidBecomeActive:): Call applicationDidFinishLaunching if |
51 | not called. | |
52 | ||
53 | * nsterm.h (EmacsApp): Add applicationDidFinishLaunchingCalled. | |
54 | ||
fa6fa1a1 | 55 | Pixel resize changes for NS (Bug#16049). |
7def8cbd JD |
56 | * nsterm.m (x_set_window_size): Change parameters rows/cols to |
57 | height/width. row/cols are locals. | |
58 | Pass pixelwise to check_frame_size. Don't set FRAME_PIXEL_WIDTH/HEIGHT. | |
59 | (updateFrameSize:): Remove gsextra. Adjust for pixelwise resize. | |
60 | (windowWillResize): Remove gsextra. Calculate extra as in | |
61 | updateFrameSize. | |
0d9cba29 SM |
62 | (x_new_font): Don't change frame size if fullscreen. |
63 | Change size pixelwise. | |
7def8cbd JD |
64 | |
65 | * nsfns.m (Fx_create_frame): Call change_frame_size twice as per | |
66 | comment in xfns.c. Change to pixelwise call. | |
67 | ||
6d6aa291 EZ |
68 | 2013-12-06 Eli Zaretskii <eliz@gnu.org> |
69 | ||
70 | * buffer.c (Fset_buffer_multibyte): Invalidate buffer caches. | |
71 | (Bug#16070) | |
72 | ||
64ed4306 DA |
73 | 2013-12-06 Dmitry Antipov <dmantipov@yandex.ru> |
74 | ||
75 | * xterm.c (input_signal_count): Remove. | |
76 | (x_dispatch_event): Define unconditionally. | |
77 | (x_make_frame_visible): Process X events until the frame | |
78 | is really visible (Bug#16027). | |
79 | * xterm.h (x_dispatch_event): Declare unconditionally. | |
80 | ||
c619527c JD |
81 | 2013-12-05 Jan Djärv <jan.h.d@swipnet.se> |
82 | ||
83 | * nsfns.m (ns_frame_parm_handlers): Add right/bottom_divider_width. | |
84 | ||
85 | * nsterm.m (x_set_window_size): Handle pixelwise. | |
86 | ||
8bea269d MR |
87 | 2013-12-05 Martin Rudalics <rudalics@gmx.at> |
88 | ||
89 | * w32term.c (x_new_font): | |
90 | * xterm.c (x_new_font): Calculate new frame size from new font | |
91 | size (Bug#16028). | |
92 | ||
22800ae9 SM |
93 | 2013-12-04 Stefan Monnier <monnier@iro.umontreal.ca> |
94 | ||
105324ce SM |
95 | * lisp.h (FOR_EACH_TAIL): New macro. |
96 | * fns.c (Fdelq): Use it to avoid inf-loops; remove QUIT. | |
97 | ||
22800ae9 SM |
98 | * window.c (select_window): Call second wset_redisplay before we change |
99 | selected_window (bug#16034). | |
100 | ||
c521fe29 PE |
101 | 2013-12-04 Paul Eggert <eggert@cs.ucla.edu> |
102 | ||
103 | * bidi.c (LRM_CHAR, RLM_CHAR): Remove; no longer used. | |
104 | ||
913250cf EZ |
105 | 2013-12-04 Eli Zaretskii <eliz@gnu.org> |
106 | ||
107 | * w32xfns.c: Include window.h, to avoid a compiler warning. | |
108 | ||
5961ad6c SM |
109 | 2013-12-04 Stefan Monnier <monnier@iro.umontreal.ca> |
110 | ||
111 | * window.c (window_scroll): Mark window for redisplay (bug#16034). | |
112 | (scroll_command, Fscroll_other_window): Don't cause redisplay now that | |
113 | window_scroll takes care of it. | |
114 | (Fset_window_point, Fdelete_other_windows_internal) | |
115 | (set_window_buffer, Fwindow_resize_apply, resize_frame_windows) | |
116 | (Fsplit_window_internal, Fdelete_window_internal) | |
117 | (Fresize_mini_window_internal, Fset_window_configuration) | |
118 | (apply_window_adjustment): Use fset_redisplay and wset_redisplay to | |
119 | cause redisplay instead of forcing a complete redisplay. | |
120 | * xdisp.c (wset_redisplay): Don't set windows_or_buffers_changed if | |
121 | we're only affecting the selected_window. | |
122 | ||
ad826124 EZ |
123 | 2013-12-04 Eli Zaretskii <eliz@gnu.org> |
124 | ||
125 | * bidi.c (bidi_get_type, bidi_get_category): Handle the isolate | |
126 | directional control characters. Update type and category | |
127 | determination according to the UBA from Unicode v6.3. | |
128 | (bidi_category_t): New category EXPLICIT_FORMATTING. | |
129 | ||
130 | * dispextern.h (bidi_type_t): Update to include new bidirectional | |
131 | properties introduced with Unicode v6.3. (Bug#16043) | |
132 | ||
2db4a1b6 MR |
133 | 2013-12-04 Martin Rudalics <rudalics@gmx.at> |
134 | ||
135 | * xterm.c (XTflash): Fix coordinate of bottom area to flash | |
136 | (Bug#16044). | |
137 | ||
a378aa9d DA |
138 | 2013-12-04 Dmitry Antipov <dmantipov@yandex.ru> |
139 | ||
140 | * font.c (font_list_entities): Remove dummy assignment. | |
141 | * font.h (struct font) [HAVE_WINDOW_SYSTEM]: Group members which are | |
142 | used on graphic displays only. Remove unused 'font_encoder' member. | |
a84c9950 | 143 | (struct font_bitmap): Remove unused 'extra' member. |
a378aa9d | 144 | * nsfont.m (nsfont_open): |
a84c9950 DA |
145 | * w32font.c (w32font_open_internal): |
146 | * ftfont.c (ftfont_get_bitmap): Adjust users. | |
a378aa9d | 147 | |
2654ac09 PE |
148 | 2013-12-03 Paul Eggert <eggert@cs.ucla.edu> |
149 | ||
5df474aa PE |
150 | Use bool for boolean. |
151 | * tparam.c (tparam1): | |
152 | * undo.c (record_point, record_property_change): | |
153 | Use bool for boolean, for local vars that are always true or false. | |
154 | ||
2654ac09 PE |
155 | Minor integer overflow fixes (Bug#16033). |
156 | * window.c (Fset_window_new_pixel): Don't let new_pixel go negative. | |
157 | This improves on the previous fix to this function. | |
158 | (window_resize_check): When summing up pixel counts, don't rely on | |
159 | undefined behavior if the sum overflows. | |
160 | ||
7303a0ae MR |
161 | 2013-12-03 Martin Rudalics <rudalics@gmx.at> |
162 | ||
163 | * window.c (Fset_window_new_pixel): Don't choke at negative | |
164 | argument value (Bug#16033). | |
165 | ||
166 | * xfns.c (Fx_create_frame): Add another call to change_frame_size | |
167 | to avoid crash in window_box_height. | |
168 | ||
169 | * gtkutil.h: Fix external declaration of xg_frame_set_char_size. | |
170 | * gtkutil.c (xg_frame_set_char_size, style_changed_cb): Fix size | |
171 | calculation. | |
172 | * xterm.c (x_set_window_size): Fix size calculation (Bug#16013). | |
173 | ||
25636e13 PE |
174 | 2013-12-03 Paul Eggert <eggert@cs.ucla.edu> |
175 | ||
176 | Minor integer overflow fixes. | |
177 | * window.c (Fset_window_new_pixel, grow_mini_window): | |
178 | * xdisp.c (Fwindow_text_pixel_size): | |
179 | Avoid undefined behavior on signed integer overflow. | |
180 | * xfns.c (x_set_mouse_color): | |
181 | Check that drag shape fits in 'unsigned', since that's what X wants. | |
182 | ||
21bf394d EZ |
183 | 2013-12-02 Eli Zaretskii <eliz@gnu.org> |
184 | ||
185 | Improve reporting of fatal exception on MS-Windows. | |
186 | * w32fns.c (my_exception_handler): New function. | |
187 | (globals_of_w32fns): Set it up as the unhandled exception | |
188 | handler. Initialize exception code and address to zeros. | |
189 | (emacs_abort): If the exception code and address are available, | |
190 | print them at the beginning of the backtrace. Fix the format of | |
191 | printing addresses (was producing 0x0x12345678 on XP). | |
192 | (Bug#15994) | |
193 | ||
f345395c HE |
194 | 2013-12-02 Helmut Eller <eller.helmut@gmail.com> |
195 | ||
196 | * eval.c (Fbacktrace__locals): New function. | |
197 | (syms_of_eval): Defsubr it. | |
198 | ||
dacc9715 DA |
199 | 2013-12-02 Dmitry Antipov <dmantipov@yandex.ru> |
200 | ||
201 | * font.h (FONT_WIDTH, FONT_HEIGHT, FONT_BASE, FONT_DESCENT): | |
202 | Define here to unify between... | |
203 | * nsterm.h, w32term.h, xterm.h: ...port-specific headers. | |
204 | * w32term.h (CHECK_W32_FRAME): Remove unused macro. | |
205 | ||
e0e0af3b YM |
206 | 2013-12-02 YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp> |
207 | ||
208 | * xterm.h (struct scroll_bar): Remove member `fringe_extended_p'. | |
209 | ||
210 | * xterm.c (x_draw_fringe_bitmap, x_scroll_run): Remove code for | |
211 | fringe background extension. | |
212 | (x_scroll_bar_create): Remove variables `sb_left' and `sb_width', | |
213 | because they are now always the same as `left' and `width', | |
214 | respectively. Remove code for the case that `width' and | |
215 | `sb_width' are different. | |
216 | ||
75b09539 PE |
217 | 2013-12-01 Paul Eggert <eggert@cs.ucla.edu> |
218 | ||
219 | Fix minor problems found by static checking. | |
220 | * dispextern.h, xdisp.c (x_draw_bottom_divider): Now static. | |
221 | * frame.c (set_frame_param) [!HAVE_NTGUI]: Remove. | |
222 | * xdisp.c (Ftool_bar_height) [USE_GTK || HAVE_NS]: Now const function. | |
223 | ||
5f9aee6f LMI |
224 | 2013-12-01 Lars Magne Ingebrigtsen <larsi@gnus.org> |
225 | ||
226 | * image.c (imagemagick_compute_animated_image): Don't crash if we | |
227 | have an animation with different-sized images (bug#15313). | |
228 | ||
90caab3f MR |
229 | 2013-11-30 Martin Rudalics <rudalics@gmx.at> |
230 | ||
231 | Remove some unused items introduced during pixelwise change. | |
232 | * window.c (window_resize_total_check): Remove unused function. | |
233 | * xdisp.c (remember_mouse_glyph): Remove unused label. | |
234 | (Ftool_bar_height): Move declaration inside #if. | |
235 | * xterm.c (x_set_window_size): Don't use r and c. | |
236 | ||
6ae87264 JB |
237 | 2013-11-30 Juanma Barranquero <lekktu@gmail.com> |
238 | ||
239 | * xdisp.c (Fwindow_text_pixel_size): Remove unused variables | |
240 | `value' and `endp'. | |
241 | ||
242 | * window.c (Fset_window_configuration): Comment out unused variables. | |
243 | ||
244 | * w32term.c (w32_read_socket): Remove unused variable `buf'. | |
245 | ||
f80e1bb6 JD |
246 | 2013-11-30 Jan Djärv <jan.h.d@swipnet.se> |
247 | ||
eb6f376d JD |
248 | * xdisp.c (redisplay_internal): unrequest_sigio => request_sigio. |
249 | ||
8e2d7ef2 JD |
250 | * xfaces.c (NEAR_SAME_COLOR_THRESHOLD): Move inside HAVE_WINDOW_SYSTEM. |
251 | ||
252 | * gnutls.c (gnutls_audit_log_function): Only declare and define if | |
253 | HAVE_GNUTLS3 (Bug#16001). | |
254 | ||
f80e1bb6 JD |
255 | * xdisp.c (redisplay_internal): Call request_sigio at end_of_redisplay |
256 | if interrupts are deferred (Bug#15801). | |
257 | ||
10634b40 | 258 | 2013-11-30 Martin Rudalics <rudalics@gmx.at> |
880e6158 MR |
259 | |
260 | Support resizing frames and windows pixelwise. | |
261 | * dispextern.h (enum window_part): Add ON_SCROLL_BAR, | |
262 | ON_RIGHT_DIVIDER and ON_BOTTOM_DIVIDER. | |
263 | (struct glyph_matrix): Replace window_left_col and | |
264 | window_top_line by window_pixel_left and window_pixel_top. | |
0d9cba29 SM |
265 | (WINDOW_WANTS_MODELINE_P, WINDOW_WANTS_HEADER_LINE_P): |
266 | Minor rewrite. | |
880e6158 MR |
267 | (enum face_id): Add WINDOW_DIVIDER_FACE_ID. |
268 | (draw_window_divider, move_it_to, x_draw_right_divider) | |
269 | (x_draw_bottom_divider, change_frame_size): Add or fix | |
270 | declarations. | |
271 | * dispnew.c (change_frame_size_1): Change prototype. | |
272 | (adjust_glyph_matrix, required_matrix_width) | |
273 | (adjust_frame_glyphs_for_window_redisplay): Use pixel | |
274 | values instead of lines and columns. | |
275 | (marginal_area_string): Use WINDOW_FRINGES_WIDTH instead of | |
276 | WINDOW_TOTAL_FRINGE_WIDTH. | |
277 | (handle_window_change_signal, do_pending_window_change) | |
278 | (init_display): Adjusts calls of change_frame_size. | |
279 | (change_frame_size, change_frame_size_1): Handle pixelwise | |
280 | changes. | |
0d9cba29 SM |
281 | * frame.c (Qright_divider_width, Qbottom_divider_width): |
282 | New Lisp objects. | |
880e6158 MR |
283 | (set_menu_bar_lines_1, set_menu_bar_lines, make_frame) |
284 | (make_terminal_frame, Fmake_terminal_frame, Fframe_parameters) | |
285 | (x_set_internal_border_width, x_set_vertical_scroll_bars) | |
286 | (x_set_scroll_bar_width, x_figure_window_size): Handle pixel | |
287 | values. | |
288 | (set_frame_param): New function. | |
289 | (Fframe_text_cols, Fframe_text_lines, Fframe_total_cols) | |
290 | (Fframe_text_width, Fframe_text_height, Fscroll_bar_width) | |
291 | (Ffringe_width, Fborder_width, Fright_divider_width) | |
292 | (Fbottom_divider_width): New functions, defsubr them. | |
0d9cba29 SM |
293 | (Fset_frame_height, Fset_frame_width, Fset_frame_size): |
294 | New argument pixelwise. | |
880e6158 MR |
295 | (struct frame_parm_table): New members Qright_divider_width and |
296 | Qbottom_divider_width. | |
297 | (x_set_frame_parameters): Handle parameters for pixelwise sizes. | |
298 | (x_report_frame_params): Handle Qright_divider_width and | |
299 | Qbottom_divider_width. | |
0d9cba29 SM |
300 | (x_set_right_divider_width, x_set_bottom_divider_width): |
301 | New functions. | |
880e6158 MR |
302 | (frame_resize_pixelwise): New option. |
303 | * frame.h (struct frame): Add tool_bar_height, menu_bar_height, | |
304 | new_pixelwise, right_divider_width and bottom_divider_width; | |
305 | remove total_lines; rename text_lines, text_cols, new_text_lines | |
306 | and new_text_cols to text_height, text_width, new_height and | |
307 | new_width respectively. | |
308 | (FRAME_LINES, FRAME_COLS): Rename to FRAME_TEXT_HEIGHT and | |
309 | FRAME_TEXT_WIDTH respectively. | |
310 | (FRAME_MENU_BAR_HEIGHT, FRAME_TOOL_BAR_HEIGHT) | |
311 | (FRAME_RIGHT_DIVIDER_WIDTH, FRAME_BOTTOM_DIVIDER_WIDTH) | |
0d9cba29 SM |
312 | (FRAME_TEXT_TO_PIXEL_WIDTH, FRAME_PIXEL_TO_TEXT_WIDTH): |
313 | New macros. | |
880e6158 MR |
314 | (FRAME_TOP_MARGIN_HEIGHT, FRAME_LEFT_SCROLL_BAR_AREA_WIDTH) |
315 | (FRAME_RIGHT_SCROLL_BAR_AREA_WIDTH, FRAME_SCROLL_BAR_AREA_WIDTH) | |
316 | (SET_FRAME_COLS, SET_FRAME_WIDTH, SET_FRAME_HEIGHT) | |
317 | (FRAME_TEXT_COLS_TO_PIXEL_WIDTH, FRAME_PIXEL_WIDTH_TO_TEXT_COLS) | |
318 | (FRAME_TEXT_COLS_TO_PIXEL_WIDTH): Rewrite macros. | |
319 | (FRAME_TOTAL_COLS_ARG): Remove macro. | |
320 | * fringe.c (draw_fringe_bitmap_1): Handle right divder. | |
321 | * gtkutil.c (xg_frame_resized, xg_frame_set_char_size) | |
322 | (x_wm_set_size_hint): Handle frame pixel sizes. | |
0d9cba29 SM |
323 | * indent.c (compute_motion, Fcompute_motion): |
324 | Call window_body_width instead of window_body_cols. | |
880e6158 MR |
325 | * keyboard.c (Qright_divider, Qbottom_divider): New symbols. |
326 | (make_lispy_position): Handle right and bottom dividers. | |
327 | (Fsuspend_emacs): Pixelize call of change_frame_size. | |
328 | * keyboard.h: Extern Qright_divider, Qbottom_divider. | |
329 | * lisp.h: Extern set_frame_param. | |
330 | * nsfns.m (x_set_tool_bar_lines): Pixelize call of | |
331 | x_set_window_size. | |
0d9cba29 SM |
332 | (Fx_create_frame): Add entry for vertical_drag_cursor. |
333 | Pixelize call of change_frame_size. | |
880e6158 MR |
334 | * nsterm.h (struct ns_output): Add vertical_drag_cursor. |
335 | * nsterm.m (ns_update_window_end): Optionally draw right | |
336 | divider. | |
0d9cba29 SM |
337 | (x_set_window_size): Add argument pixelwise. |
338 | Call check_frame_size and change_frame_size with pixelwise zero. | |
880e6158 MR |
339 | (ns_draw_window_divider): New function. |
340 | (ns_redisplay_interface): Add ns_draw_window_divider. | |
341 | (updateFrameSize:): Call change_frame_size with pixelwise zero. | |
342 | (x_new_font): Call x_set_window_size with pixelwise zero. | |
343 | * print.c (print_object): For a window print its sequence | |
344 | number again. | |
345 | * term.c (Fresume_tty): Pixelize call of change_frame_size. | |
346 | * w32fns.c (x_set_mouse_color): Handle vertical drag cursor. | |
347 | (x_set_menu_bar_lines, x_set_tool_bar_lines): Calculate pixelwise. | |
348 | (w32_createwindow): Use scroll bar area width. | |
0d9cba29 SM |
349 | (w32_wnd_proc): Handle bottom divider width. |
350 | For WM_WINDOWPOSCHANGING return zero if we resize pixelwise. | |
351 | (Fx_create_frame): Default divider width parameters. | |
352 | Caclulate sizes pixelwise. Add vertical drag cursor support. | |
353 | (x_create_tip_frame): Default divider widths to zero. | |
354 | Pixelize call to change_frame_size. | |
880e6158 MR |
355 | (Fx_show_tip): Add handling of divider widths. Pixelize window |
356 | position and sizes. | |
357 | (Fw32_frame_rect): New function. | |
358 | (frame_parm_handler w32_frame_parm_handlers): Add divider | |
359 | widths. | |
360 | (Vx_window_vertical_drag_shape): Add variable. | |
361 | * w32inevt.c (resize_event, maybe_generate_resize_event): | |
362 | Pixelize change_frame_size calls. | |
363 | * w32menu.c (set_frame_menubar): Pixelize x_set_window_size | |
364 | call. | |
365 | * w32term.c (w32_draw_window_divider): New function. | |
366 | (x_update_window_end): Handle right divider. | |
367 | (w32_draw_fringe_bitmap, x_scroll_run) | |
368 | (w32_set_vertical_scroll_bar): Pixelize scrollbar widths. | |
0d9cba29 SM |
369 | (w32_read_socket): Handle SIZE_MAXIMIZED separately. |
370 | Calculate new frame sizes pixelwise. | |
880e6158 MR |
371 | (x_new_font): Pixelize call to x_set_window_size. |
372 | (x_check_fullscreen): Pixelize call to change_frame_size. | |
373 | (x_set_window_size_1, x_set_window_size): New argument | |
374 | pixelwise. Calculate pixelwise. | |
375 | (x_wm_set_size_hint): Use scroll bar area width. | |
376 | (w32_redisplay_interface): Add w32_draw_window_divider. | |
377 | * w32term.h (struct w32_output): Add vertical drag cursor. | |
378 | * widget.c (set_frame_size, update_wm_hints) | |
379 | (EmacsFrameResize, EmacsFrameSetValues): Pixelize calls of | |
380 | change_frame_size. | |
381 | (EmacsFrameSetCharSize): Pixelize call of x_set_window_size. | |
382 | * window.c (sequence_number): Restore. | |
383 | (Fwindow_pixel_width, Fwindow_pixel_height) | |
384 | (Fwindow_mode_line_height, Fwindow_header_line_height) | |
385 | (window_pixel_to_total, Frun_window_scroll_functions) | |
386 | (Fset_window_new_pixel, window_resize_apply_total) | |
387 | (Fwindow_resize_apply_total): New functions. | |
388 | (window_body_height, window_body_width): Rename from | |
0d9cba29 SM |
389 | window_body_lines. New argument PIXELWISE. |
390 | Calculate pixelwise. | |
880e6158 MR |
391 | (Fwindow_body_height, Fwindow_body_width): New argument |
392 | PIXELWISE. | |
393 | (coordinates_in_window, window_relative_x_coord): Use window's | |
394 | pixel width instead of total width. | |
395 | (replace_window, recombine_windows): Initialize pixel values. | |
396 | (resize_root_window, resize_frame_windows, grow_mini_window) | |
0d9cba29 SM |
397 | (shrink_mini_window): New argument PIXELWISE. |
398 | Calculate pixelwise. | |
880e6158 MR |
399 | (Fdelete_other_windows_internal, adjust_window_margins) |
400 | (window_resize_check, window_resize_apply) | |
401 | (Fdelete_window_internal, Fresize_mini_window_internal) | |
402 | (Fwindow_text_width, Fwindow_text_height): Calculate pixelwise. | |
403 | (check_frame_size): Rename arguments. New argument PIXELWISE. | |
404 | Calculate pixelwise. | |
405 | (set_window_buffer): Make samebuf bool. Run configuration change | |
406 | hook only if buffer changed. | |
407 | (Fset_window_buffer): Rewrite doc-string. | |
408 | (make_window): Initialize new_pixel slot. | |
409 | (Fwindow_resize_apply): Check pixel size of root window. | |
410 | (Fsplit_window_internal): Call 2nd argument pixel_size. | |
411 | Calculate pixelwise. | |
412 | (Fscroll_left, Fscroll_right): Call window_body_width instead of | |
413 | window_body_cols. | |
414 | (save_window_data): New slots frame_text_width, | |
415 | frame_text_height, frame_menu_bar_height, frame_tool_bar_height. | |
416 | (saved_window): New slots pixel_left, pixel_top, pixel_height, | |
417 | pixel_width. | |
418 | (Fcurrent_window_configuration, Fset_window_configuration) | |
419 | (save_window_save, compare_window_configurations): Handle new | |
420 | slots in save_window_data and saved_window. | |
421 | (Fset_window_scroll_bars): Fix doc-string. | |
422 | (window_resize_pixelwise): New variable. | |
0d9cba29 SM |
423 | (coordinates_in_window, Fcoordinates_in_window_p): |
424 | Handle dividers. | |
880e6158 | 425 | (make_parent_window): Adjust sequence_number. |
0d9cba29 SM |
426 | (Fwindow_right_divider_width, Fwindow_bottom_divider_width): |
427 | New functions. | |
880e6158 MR |
428 | * window.h (struct window): New members new_pixel, pixel_left, |
429 | pixel_top, pixel_width, pixel_height. Restore sequence_number. | |
430 | (wset_new_pixel): New function. | |
431 | (WINDOW_PIXEL_WIDTH, WINDOW_PIXEL_HEIGHT) | |
432 | (MIN_SAFE_WINDOW_PIXEL_WIDTH, MIN_SAFE_WINDOW_PIXEL_HEIGHT) | |
433 | (WINDOW_LEFT_PIXEL_EDGE, WINDOW_RIGHT_PIXEL_EDGE) | |
434 | (WINDOW_TOP_PIXEL_EDGE, WINDOW_BOTTOM_PIXEL_EDGE) | |
435 | (WINDOW_BOTTOMMOST_P, WINDOW_BOX_LEFT_PIXEL_EDGE) | |
436 | (WINDOW_BOX_RIGHT_PIXEL_EDGE, WINDOW_MARGINS_COLS) | |
437 | (WINDOW_MARGINS_WIDTH, WINDOW_RIGHT_DIVIDER_WIDTH) | |
438 | (WINDOW_BOTTOM_DIVIDER_WIDTH): New macros. | |
439 | (WINDOW_TOTAL_FRINGE_WIDTH): Rename to WINDOW_FRINGES_WIDTH. | |
440 | (WINDOW_TOTAL_WIDTH, WINDOW_TOTAL_HEIGHT): Remove macros. | |
441 | (WINDOW_RIGHT_EDGE_X, WINDOW_LEFT_EDGE_X, WINDOW_TOP_EDGE_Y) | |
442 | (WINDOW_BOTTOM_EDGE_Y, WINDOW_FULL_WIDTH_P, WINDOW_LEFTMOST_P) | |
443 | (WINDOW_RIGHTMOST_P, WINDOW_BOX_LEFT_EDGE_X) | |
444 | (WINDOW_BOX_RIGHT_EDGE_X, WINDOW_FRINGE_COLS) | |
445 | (WINDOW_BOX_HEIGHT_NO_MODE_LINE, WINDOW_BOX_TEXT_HEIGHT): | |
446 | Rewrite. | |
447 | (resize_frame_windows, grow_mini_window, shrink_mini_window) | |
448 | (window_body_width, check_frame_size): Adapt external declarations. | |
449 | * xdisp.c (last_max_ascent): New integer. | |
450 | (window_text_bottom_y): Handle bottom divider. | |
451 | (window_box_width, window_box_height): Calculate pixelwise. | |
452 | (get_glyph_string_clip_rects): Handle right divider. | |
453 | (remember_mouse_glyph): When windows are resized pixelwise | |
454 | proceed with width and height set to 1. | |
455 | (init_iterator): Use WINDOW_PIXEL_WIDTH instead of | |
456 | WINDOW_TOTAL_WIDTH. | |
457 | (move_it_to): Calculate and return maximum x position | |
458 | encountered. | |
459 | (Fwindow_text_pixel_size): New function. | |
460 | (resize_mini_window, update_tool_bar): Calculate pixelwise. | |
0d9cba29 SM |
461 | (tool_bar_lines_needed): Rename to tool_bar_height. |
462 | Calculate pixelwise. | |
463 | (Ftool_bar_lines_needed): Rename to Ftool_bar_height. | |
464 | Calculate pixelwise. | |
880e6158 MR |
465 | (redisplay_tool_bar): Calculate pixelwise. |
466 | (redisplay_window): Calculate pixelwise. Handle dividers. | |
467 | (draw_glyphs, x_clear_end_of_line, note_mouse_highlight) | |
468 | (x_draw_vertical_border): Handle dividers. | |
469 | (define_frame_cursor1): Handle vertical drag cursor. | |
470 | (x_draw_right_divider, x_draw_bottom_divider): New functions. | |
471 | (expose_window): Calculate pixelwise. Handle dividers. | |
472 | (init_xdisp): Initialize pixel values. | |
473 | * xfaces.c (Qwindow_divider): New face. | |
474 | (realize_basic_faces): Realize it. | |
475 | * xfns.c (x_set_mouse_color): Handle vertical_drag_cursor. | |
476 | (x_set_menu_bar_lines, x_set_tool_bar_lines): Calculate pixelwise. | |
477 | (x_set_scroll_bar_default_width): Default actual width to 16. | |
478 | (Fx_create_frame): Set sizes pixelwise. | |
0d9cba29 SM |
479 | (x_create_tip_frame): Default divider widths to zero. |
480 | Pixelize call of change_frame_size. | |
880e6158 MR |
481 | (Fx_show_tip): Handle divider widths. Initial pixel position |
482 | and sizes. | |
483 | (frame_parm_handler x_frame_parm_handlers): Add divider widths. | |
484 | (Vx_window_vertical_drag_shape): New option. | |
485 | * xmenu.c (free_frame_menubar): Pixelize call of | |
486 | x_set_window_size. | |
487 | * xterm.c (x_draw_window_divider): New function. | |
488 | (x_update_window_end): Optionally draw right divider. | |
489 | (x_draw_fringe_bitmap, x_scroll_run, x_scroll_bar_create) | |
490 | (XTset_vertical_scroll_bar): Use scroll bar pixel width. | |
491 | (handle_one_xevent, x_new_font): Calculate pixelwise. | |
492 | (x_set_window_size_1, x_set_window_size): New argument | |
493 | pixelwise. Calculate pixelwise. | |
494 | (x_wm_set_size_hint): Pixelize call of check_frame_size. | |
495 | (struct x_redisplay_interface): Add x_draw_window_divider. | |
496 | * xterm.h (struct x_output): Add vertical_drag_cursor. | |
497 | ||
44ad1cf7 SM |
498 | 2013-11-30 Stefan Monnier <monnier@iro.umontreal.ca> |
499 | ||
500 | * xdisp.c (redisplay_internal): Don't call set_window_update_flags. | |
501 | Set invisible frames's `redisplay' when a full redisplay is requested. | |
502 | (redisplay_window): Set must_be_updated_p instead (bug#15999). | |
503 | (redisplay_mode_lines): Don't set must_be_updated_p any more. | |
504 | (display_mode_lines): Set it here instead. | |
505 | ||
506 | * dispnew.c (set_window_update_flags): Remove `b' argument; make static. | |
507 | ||
508 | * dispextern.h (set_window_update_flags): Remove. | |
509 | ||
da048127 SM |
510 | 2013-11-29 Stefan Monnier <monnier@iro.umontreal.ca> |
511 | ||
9f4ffeee SM |
512 | * fns.c (internal_equal): Add a hash_table argument to handle cycles. |
513 | ||
a8253776 SM |
514 | * xdisp.c (REDISPLAY_SOME_P): New macro. |
515 | (redisplay_internal): Use it (bug#15999). | |
516 | (prepare_menu_bars, redisplay_window): Use it as well. | |
517 | ||
4e36a6a6 | 518 | * lisp.mk (lisp): Add electric.elc and uniquify.elc. |
da048127 | 519 | |
579ca67b TS |
520 | 2013-11-29 Tom Seddon <emacs@tomseddon.plus.com> (tiny change) |
521 | ||
522 | * w32font.c (g_b_init_get_char_width_32_w): New static var. | |
523 | (globals_of_w32font): Zero it out. | |
524 | (GetCharWidth32W_Proc): New function pointer. | |
525 | (get_char_width_32_w): New function. | |
526 | (compute_metrics): If get_glyph_outline_w returns an error, try | |
527 | get_char_width_32_w before declaring a failure. This avoids | |
528 | punishing raster (a.k.a. "bitmap") fonts by slowing down | |
529 | redisplay. (Bug#6364). | |
b7f79a5c | 530 | |
da048127 SM |
531 | 2013-11-29 Eli Zaretskii <eliz@gnu.org> |
532 | ||
b7f79a5c EZ |
533 | * xdisp.c (clear_mouse_face): Don't invalidate the entire |
534 | mouse-highlight info, just signal frame_up_to_date_hook that mouse | |
535 | highlight needs to be redisplayed. (Bug#15913) | |
536 | ||
49faeaaf PE |
537 | 2013-11-29 Paul Eggert <eggert@cs.ucla.edu> |
538 | ||
539 | Fix minor problems found by static checking. | |
540 | * buffer.h (struct buffer_text, struct buffer): | |
541 | * frame.h (struct frame): | |
542 | * window.h (struct window): | |
543 | Avoid 'bool foo : 1;', as it's not portable to pre-C99 compilers, | |
544 | as described in ../lib/stdbool.in.h. Use 'unsigned foo : 1;' instead. | |
545 | * menu.c (syms_of_menu): Define x-popup-dialog, removing a | |
546 | no-longer-valid use of HAVE_MENUS. | |
547 | * xdisp.c (propagate_buffer_redisplay): Now static. | |
548 | ||
ef869611 SM |
549 | 2013-11-29 Stefan Monnier <monnier@iro.umontreal.ca> |
550 | ||
7cdf484b SM |
551 | * xmenu.c (Fmenu_or_popup_active_p): |
552 | * window.c (Fset_window_configuration): | |
553 | * menu.c (Fx_popup_menu, Fx_popup_dialog): | |
554 | * keyboard.c (record_menu_key, read_char_x_menu_prompt): | |
555 | * fns.c (Fyes_or_no_p): | |
556 | * editfns.c (Fmessage_box, Fmessage_or_box): | |
557 | * alloc.c (make_save_ptr_ptr): | |
558 | * xdisp.c, w32menu.c, term.c, xterm.h, xterm.c: Remove HAVE_MENUS. | |
559 | ||
ef869611 SM |
560 | * window.c (Fset_window_configuration): Move select_window later. |
561 | ||
655ab9a3 SM |
562 | 2013-11-28 Stefan Monnier <monnier@iro.umontreal.ca> |
563 | ||
564 | Refine redisplay optimizations to only redisplay *some* frames/windows | |
565 | rather than all of them. | |
566 | * xdisp.c (REDISPLAY_SOME): New constant. | |
567 | (redisplay_other_windows, wset_redisplay, fset_redisplay) | |
568 | (bset_redisplay, bset_update_mode_line): New functions. | |
569 | (message_dolog): Use bset_redisplay. | |
570 | (clear_garbaged_frames): Use fset_redisplay. | |
571 | (echo_area_display): Use wset_redisplay. | |
572 | (buffer_shared_and_changed): Remove. | |
573 | (prepare_menu_bars): Call Vpre_redisplay_function before updating | |
574 | frame titles. Compute the actual set of windows redisplayed. | |
575 | Don't update frame titles and menu bars for frames that don't need to | |
576 | be redisplayed. | |
577 | (propagate_buffer_redisplay): New function. | |
578 | (AINC): New macro. | |
579 | (redisplay_internal): Use it. Be more selective in the set of windows | |
580 | we redisplay. Propagate windows_or_buffers_changed to | |
581 | update_mode_lines a bit later to simplify the code. | |
582 | (mark_window_display_accurate_1): Reset window and buffer's | |
583 | `redisplay' flag. | |
584 | (redisplay_window): Do nothing if neither the window nor the buffer nor | |
585 | the frame needs redisplay. | |
586 | * window.h (struct window): Add `redisplay' field. | |
587 | (wset_redisplay, fset_redisplay, bset_redisplay, bset_update_mode_line) | |
588 | (redisplay_other_windows, window_list): New declarations. | |
589 | * window.c (select_window, Fset_window_start): Use wset_redisplay. | |
590 | (window_list): Not static any more. | |
591 | (grow_mini_window, shrink_mini_window): Use fset_redisplay. | |
592 | * minibuf.c (read_minibuf_unwind): Don't redisplay everything. | |
593 | * insdel.c (prepare_to_modify_buffer_1): Use bset_redisplay. | |
594 | * frame.c (Fmake_frame_visible): Don't redisplay everything. | |
595 | * frame.h (struct frame): Add `redisplay' field. | |
596 | Move `external_menu_bar' bitfield next to other bit-fields. | |
597 | (SET_FRAME_GARBAGED): Use fset_redisplay. | |
598 | (SET_FRAME_VISIBLE): Don't garbage the frame; | |
599 | Use redisplay_other_windows. | |
600 | * buffer.h (struct buffer): Add `redisplay' field. | |
601 | * buffer.c (Fforce_mode_line_update): Pay attention to the `all' flag. | |
602 | (modify_overlay): Use bset_redisplay. | |
603 | * alloc.c (gc_sweep): Don't unmark strings while sweeping symbols. | |
604 | ||
9c099ca7 EZ |
605 | 2013-11-28 Eli Zaretskii <eliz@gnu.org> |
606 | ||
607 | Support w32 file notifications in batch mode. | |
608 | * w32proc.c (sys_select): Don't wait on interrupt_handle if it is | |
609 | invalid (which happens in batch mode). If non-interactive, call | |
610 | handle_file_notifications to store file notification events in the | |
611 | input queue. (Bug#15933) | |
612 | ||
655ab9a3 | 613 | * w32notify.c (send_notifications): Handle FRAME_INITIAL frames as well. |
9c099ca7 | 614 | |
655ab9a3 | 615 | * w32inevt.c (handle_file_notifications): Now external, not static. |
9c099ca7 EZ |
616 | |
617 | * w32term.h (handle_file_notifications): Provide prototype. | |
618 | ||
619 | * emacs.c (main) [HAVE_W32NOTIFY]: When non-interactive, call | |
620 | init_crit, since init_display, which does that otherwise, is not | |
621 | called. | |
622 | ||
7e3bf78c GM |
623 | 2013-11-27 Glenn Morris <rgm@gnu.org> |
624 | ||
625 | * Makefile.in ($(lispsource)/international/charprop.el): New. | |
626 | (emacs$(EXEEXT)): Depend on charprop.el. | |
627 | ||
fb6a5d68 EZ |
628 | 2013-11-27 Eli Zaretskii <eliz@gnu.org> |
629 | ||
de1e0d91 EZ |
630 | * fileio.c (Finsert_file_contents): Invalidate buffer caches when |
631 | deleting portions of the buffer under non-nil REPLACE argument. | |
632 | (Bug#15973) | |
633 | ||
fb6a5d68 EZ |
634 | * w32notify.c (Fw32notify_add_watch): If the argument FILE is a |
635 | directory, watch it and not its parent. | |
636 | (add_watch): Allow empty string in FILE. | |
637 | ||
72fdd473 MR |
638 | 2013-11-27 Martin Rudalics <rudalics@gmx.at> |
639 | ||
640 | * window.c (Fset_window_start, window_resize_apply) | |
641 | (window_scroll): Reset window_end_valid (Bug#15957). | |
642 | ||
cb6c95a3 GM |
643 | 2013-11-27 Glenn Morris <rgm@gnu.org> |
644 | ||
645 | * Makefile.in (leimdir): Now in lisp source directory. | |
646 | ($(leimdir)/leim-list.el): Just use ../leim . | |
647 | * epaths.in (PATH_DUMPLOADSEARCH): | |
648 | * lread.c (load_path_default): | |
649 | * nsterm.m (ns_load_path): No more leim directory. | |
650 | ||
ed87760c AS |
651 | 2013-11-26 Andreas Schwab <schwab@suse.de> |
652 | ||
653 | * .gdbinit (xgettype): Add cast. | |
654 | ||
624780f0 GM |
655 | 2013-11-26 Glenn Morris <rgm@gnu.org> |
656 | ||
657 | Preload leim-list.el. | |
658 | * epaths.in (PATH_DUMPLOADSEARCH): Add leim/. | |
659 | * callproc.c (init_callproc): Don't assume PATH_DUMPLOADSEARCH | |
660 | is a single directory. | |
661 | ||
4aaf6b61 PE |
662 | 2013-11-25 Paul Eggert <eggert@cs.ucla.edu> |
663 | ||
3f73284a PE |
664 | bool-vector-subsetp is now the normal direction (Bug#15912). |
665 | * data.c (Fbool_vector_subsetp): Test whether the first argument | |
666 | is a subset of the second one, not the reverse. Add doc string. | |
667 | ||
4aaf6b61 PE |
668 | Fix minor problems found by static checking. |
669 | * lread.c (load_path_default): Now static. | |
670 | * textprop.c (text_property_stickiness): Be consistent about the | |
671 | test used when deciding whether to consider the previous character. | |
672 | This simplifies the code a bit. | |
673 | ||
511fa0d3 SM |
674 | 2013-11-25 Stefan Monnier <monnier@iro.umontreal.ca> |
675 | ||
a5fa8eb4 SM |
676 | * textprop.c (text_property_stickiness): Fix front-stickiness at BOB. |
677 | ||
511fa0d3 SM |
678 | * frame.c (Fhandle_focus_in, Fhandle_focus_out): Move to frame.el. |
679 | (syms_of_frame): Don't defsubr them. | |
680 | ||
97bacf8c GM |
681 | 2013-11-25 Glenn Morris <rgm@gnu.org> |
682 | ||
310294a3 GM |
683 | * lread.c (load_path_default): Change the sense of the argument. |
684 | (init_lread): When EMACSLOADPATH is set, do not ignore changes | |
685 | from dump_path. When it is not, avoid checking dump_path twice. | |
686 | ||
97bacf8c GM |
687 | * lread.c (init_lread): Fix 2013-11-23 goof that was checking |
688 | uninstalled dump_path against installed Vload_path. (Bug#15964) | |
689 | ||
450533b0 SM |
690 | 2013-11-24 Stefan Monnier <monnier@iro.umontreal.ca> |
691 | ||
740bcff0 SM |
692 | Export get_pos_property to Elisp. |
693 | * editfns.c (Fget_pos_property): Rename from get_pos_property. | |
694 | (syms_of_editfns): Export it to Elisp. | |
695 | ||
450533b0 SM |
696 | * data.c (Fmake_variable_buffer_local): Mention `permanent-local'. |
697 | ||
1db72ad3 RF |
698 | 2013-11-23 Romain Francoise <romain@orebokech.com> |
699 | ||
700 | * fileio.c (init_fileio): Move `write_region_inhibit_fsync' | |
701 | initialization here ... | |
702 | (syms_of_fileio): ... from here. | |
703 | ||
2c98e669 SM |
704 | 2013-11-23 Stefan Monnier <monnier@iro.umontreal.ca> |
705 | ||
706 | * lread.c (init_lread): Fix int/Lisp_Object mixup. | |
707 | Please use --enable-check-lisp-object-type. | |
708 | ||
50dca5df GM |
709 | 2013-11-23 Glenn Morris <rgm@gnu.org> |
710 | ||
711 | * process.c (get_process): Explicit error for dead buffers. | |
712 | ||
d7aff0d6 GM |
713 | 2013-11-23 Andreas Schwab <schwab@linux-m68k.org> |
714 | ||
715 | * process.c (get_process): Check that OBJ is a live buffer. (Bug#15923) | |
716 | ||
17e0445b GM |
717 | 2013-11-23 Glenn Morris <rgm@gnu.org> |
718 | ||
719 | Empty elements in EMACSLOADPATH stand for the default. (Bug#12100) | |
720 | * lread.c (load_path_check): Take path to check as argument. | |
721 | (load_path_default): New, split from init_lread. | |
722 | (init_lread): Move calc of default load-path to load_path_default. | |
723 | Empty elements in EMACSLOADPATH now stand for the default. | |
724 | (load-path): Doc fix. | |
725 | * emacs.c (decode_env_path): Add option to treat empty elements | |
726 | as nil rather than ".". | |
727 | * callproc.c (init_callproc_1, init_callproc): | |
728 | * image.c (Vx_bitmap_file_path): | |
729 | * lisp.h (decode_env_path): | |
730 | * lread.c (Vsource_directory): | |
731 | Update for new argument spec of decode_env_path. | |
732 | ||
cd88d682 EZ |
733 | 2013-11-22 Eli Zaretskii <eliz@gnu.org> |
734 | ||
735 | * bidi.c (bidi_find_paragraph_start): Limit the returned positions | |
736 | to BEGV_BYTE..ZV_BYTE range. (Bug#15951) | |
737 | ||
75360f19 PE |
738 | 2013-11-21 Paul Eggert <eggert@cs.ucla.edu> |
739 | ||
7e8ed4f7 PE |
740 | Fix some dependency problems that cause unnecessary recompiles. |
741 | Problem reported by RMS in | |
742 | <http://lists.gnu.org/archive/html/emacs-devel/2013-11/msg00421.html>. | |
743 | * Makefile.in (OLDXMENU_TARGET, OLDXMENU, OLDXMENU_DEPS) | |
744 | (really-lwlib, really-oldXMenu, stamp-oldxmenu) | |
745 | (../src/$(OLDXMENU), $(OLDXMENU)): Remove. | |
7e8ed4f7 PE |
746 | (temacs$(EXEEXT)): Depend on $(LIBXMENU), not stamp-oldxmenu. |
747 | ($(lwlibdir)/liblw.a, $(oldXMenudir)/libXMenu11.a, FORCE): New targets. | |
748 | (boostrap-clean): No need to remove stamp-oldxmenu. | |
749 | ||
75360f19 PE |
750 | Fix recently introduced bool vector overrun. |
751 | This was due to an optimization that went awry. | |
752 | Reported by Glenn Morris in | |
753 | <http://lists.gnu.org/archive/html/emacs-devel/2013-11/msg00622.html>. | |
754 | * alloc.c (make_uninit_bool_vector): Don't allocate a dummy word | |
755 | for empty vectors, undoing the 2013-11-18 change. | |
756 | * data.c (bool_vector_binop_driver): Rely on this. | |
757 | Fix bug that occasionally overran the destination. | |
758 | * lisp.h (struct Lisp_Bool_vector): Document this. | |
759 | ||
f03f7d3d JD |
760 | 2013-11-20 Jan Djärv <jan.h.d@swipnet.se> |
761 | ||
cab0d91d JD |
762 | * nsterm.m (init, run, stop:): Enable again. stop calls super stop |
763 | to handle dialogs. | |
764 | ||
f03f7d3d JD |
765 | * nsterm.m (init, run, stop:): Comment out for now, does not work |
766 | with dialogs. | |
767 | ||
12455b2f PE |
768 | 2013-11-19 Paul Eggert <eggert@cs.ucla.edu> |
769 | ||
770 | * charset.c (syms_of_charset): Don't read past end of string. | |
771 | ||
8d1c3af9 GM |
772 | 2013-11-19 Glenn Morris <rgm@gnu.org> |
773 | ||
774 | * frame.c (Fhandle_focus_in, Fhandle_focus_out): Doc fixes. | |
775 | ||
8e015705 BJ |
776 | 2013-11-19 Brian Jenkins <brian@brianjenkins.org> (tiny change) |
777 | ||
778 | Add hooks to run on gaining/losing focus. (Bug#15029) | |
779 | * frame.c (Qfocus_in_hook, Qfocus_out_hook): New static lisp objects. | |
780 | (Fhandle_focus_in, Fhandle_focus_out): Run focus hooks. | |
781 | (syms_of_frame): Add focus-in-hook, focus-out-hook. | |
782 | ||
87d86601 PE |
783 | 2013-11-18 Paul Eggert <eggert@cs.ucla.edu> |
784 | ||
23e79746 PE |
785 | * data.c (bool_vector_binop_driver): Rename locals for sanity's sake. |
786 | The old names predated the API change that put destination at end. | |
787 | ||
ec2c4ee6 PE |
788 | Improve API of recently-added bool vector functions (Bug#15912). |
789 | The old API had (bool-vector-count-matches A B) | |
790 | and (bool-vector-count-matches-at A B I), which gave the | |
791 | misleading impression that the two functions were variants, one | |
792 | with a location I. The new API has (bool-vector-count-population A) | |
793 | and (bool-vector-count-consecutive A B I) to make the distinction | |
794 | clearer. The first function no longer has a B argument, since the | |
795 | caller can easily determine the number of nils if the length and | |
796 | number of ts is known. | |
797 | * data.c (Fbool_vector_count_population): Rename from | |
798 | bool_vector_count_matches, and accept just 1 argument. | |
799 | (Fbool_vector_count_consecutive): Rename from | |
800 | Fbool_vector_count_matches_at. | |
801 | ||
87d86601 PE |
802 | Always allocate at least one bits_word per bool vector. |
803 | See Daniel Colascione in: | |
804 | http://lists.gnu.org/archive/html/emacs-devel/2013-11/msg00518.html | |
805 | * alloc.c (make_uninit_bool_vector): Always allocate at least one word. | |
806 | * data.c (bool_vector_binop_driver): Rely on this. Tune. | |
807 | * lisp.h (struct Lisp_Bool_vector): Document this. | |
808 | ||
37c790b3 EZ |
809 | 2013-11-18 Eli Zaretskii <eliz@gnu.org> |
810 | ||
811 | * insdel.c (invalidate_buffer_caches): New function, consolidated | |
812 | from part of prepare_to_modify_buffer. | |
813 | (insert_from_gap, prepare_to_modify_buffer): | |
655ab9a3 SM |
814 | * coding.c (code_convert_region, code_convert_string): |
815 | Call invalidate_buffer_caches. (Bug#15841) | |
37c790b3 EZ |
816 | |
817 | * lisp.h (invalidate_buffer_caches): Add prototype. | |
818 | ||
96e78d1f EZ |
819 | 2013-11-17 Eli Zaretskii <eliz@gnu.org> |
820 | ||
821 | * w32term.c (x_update_window_end): Don't invalidate the entire | |
822 | mouse-highlight info, just signal frame_up_to_date_hook that mouse | |
823 | highlight needs to be redisplayed. (Bug#15913) | |
824 | ||
0f679e86 PE |
825 | 2013-11-17 Paul Eggert <eggert@cs.ucla.edu> |
826 | ||
827 | * lisp.h (DEBUGGER_SEES_C_MACROS): Remove. | |
828 | ||
3d6dec8d EZ |
829 | 2013-11-16 Eli Zaretskii <eliz@gnu.org> |
830 | ||
d17f4dba EZ |
831 | * doc.c (Fsubstitute_command_keys): Inhibit modification hooks |
832 | while we are using Vprin1_to_string_buffer. | |
833 | ||
3d6dec8d EZ |
834 | * keymap.c (describe_map): Don't crash if PT is 1 both before and |
835 | after inserting the description string. (Bug#15907) | |
836 | ||
2fcc742f PE |
837 | 2013-11-15 Paul Eggert <eggert@cs.ucla.edu> |
838 | ||
839 | * data.c: Work around bogus GCC diagnostic about shift count. | |
840 | Reported by Eli Zaretskii in | |
841 | <http://lists.gnu.org/archive/html/emacs-devel/2013-11/msg00489.html>. | |
842 | (pre_value): New function. | |
843 | (count_trailing_zero_bits): Use it. | |
844 | ||
73583a99 EZ |
845 | 2013-11-15 Eli Zaretskii <eliz@gnu.org> |
846 | ||
847 | * lisp.h (DEBUGGER_SEES_C_MACROS) [GCC < v3.5]: Pessimistically | |
848 | assume C macros are not supported even under -g3 in these old GCC | |
849 | versions. | |
850 | ||
a1f03e89 LL |
851 | 2013-11-15 Leo Liu <sdl.web@gmail.com> |
852 | ||
853 | * minibuf.c (Ftry_completion, Fall_completions) | |
854 | (Ftest_completion): Use FUNCTIONP. (Bug#15889) | |
855 | ||
1a191e5c PE |
856 | 2013-11-15 Paul Eggert <eggert@cs.ucla.edu> |
857 | ||
858 | * lisp.h (DEFINE_GDB_SYMBOL_BEGIN, DEFINE_GDB_SYMBOL_END): | |
859 | Define to empty if DEBUGGER_SEES_C_MACROS is defined. | |
860 | This avoids placing unnecessary constants into the Emacs code. | |
861 | ||
c9f63070 KI |
862 | 2013-11-14 Kazuhiro Ito <kzhr@d1.dion.ne.jp> (tiny change) |
863 | ||
864 | * keyboard.c (make_ctrl_char) [HAVE_NTGUI]: Now externally visible | |
865 | for Cygwin w32 build. | |
866 | ||
867 | * xdisp.c (erase_phys_cursor) [HAVE_NTGUI]: Now externally visible | |
868 | for Cygwin w32 build. (Bug#15892) | |
869 | ||
d672ac3c PE |
870 | 2013-11-14 Paul Eggert <eggert@cs.ucla.edu> |
871 | ||
2cf00efc PE |
872 | Simplify, port and tune bool vector implementation. |
873 | * alloc.c (bool_vector_exact_payload_bytes) | |
874 | (bool_vector_payload_bytes): Remove. | |
875 | (bool_vector_fill): Return its argument. | |
876 | * alloc.c (bool_vector_fill): | |
877 | * lread.c (read1): | |
878 | * print.c (print_object): | |
879 | Simplify by using bool_vector_bytes. | |
880 | * alloc.c (make_uninit_bool_vector): | |
881 | New function, broken out from Fmake_bool_vector. | |
882 | (Fmake_bool_vector): Use it. Use tail call. | |
883 | (make_uninit_bool_vector, vector_nbytes): Simplify size calculations. | |
884 | * data.c (BITS_PER_ULL): New constant. | |
885 | (ULLONG_MAX, count_one_bits_ll): Fall back on long counterparts | |
886 | if long long versions don't exist. | |
887 | (shift_right_ull): New function. | |
888 | (count_one_bits_word): New function, replacing popcount_bits_word | |
889 | macro. Don't assume that bits_word is no wider than long long. | |
890 | (count_one_bits_word, count_trailing_zero_bits): | |
891 | Don't assume that bits_word is no wider than long long. | |
892 | * data.c (bool_vector_binop_driver, bool_vector_not): | |
893 | * fns.c (Fcopy_sequence): | |
894 | * lread.c (read1): | |
895 | Create an uninitialized destination, to avoid needless work. | |
896 | (internal_equal): Simplify. | |
897 | (Ffillarray): Prefer tail call. | |
898 | * data.c (bool_vector_binop_driver): Don't assume bit vectors always | |
899 | contain at least one word. | |
900 | (bits_word_to_host_endian): Prefer if to #if. Don't assume | |
901 | chars are narrower than ints. | |
902 | * data.c (Fbool_vector_count_matches, Fbool_vector_count_matches_at): | |
903 | * fns.c (Fcopy_sequence): | |
904 | Simplify and tune. | |
905 | * lisp.h (bits_word, BITS_WORD_MAX, BITS_PER_BITS_WORD): | |
906 | Don't try to port to hosts where bits_word values have holes; the | |
907 | code wouldn't work there anyway. Verify this assumption, though. | |
908 | (bool_vector_bytes): New function. | |
909 | (make_uninit_bool_vector): New decl. | |
910 | (bool_vector_fill): Now returns Lisp_Object. | |
911 | ||
d672ac3c PE |
912 | * xfns.c (xic_create_fontsetname): |
913 | * xrdb.c (gethomedir): Prefer tail calls. | |
914 | ||
bd7cd30a PE |
915 | 2013-11-12 Paul Eggert <eggert@cs.ucla.edu> |
916 | ||
b3671617 PE |
917 | * xterm.c (syms_of_xterm): staticpro Qmodifier_value, Qalt, Qhyper, |
918 | Qmeta, and Qsuper. This is safer, and it's what w32fns.c does. | |
e3ac17b6 | 919 | |
bd7cd30a PE |
920 | * buffer.c (Fforce_mode_line_update): Don't fall off end of function |
921 | that requires a return value. | |
922 | (Fset_buffer_modified_p): Take advantage of this change to do | |
923 | a tail call. | |
924 | ||
ecda65d4 SM |
925 | 2013-11-11 Stefan Monnier <monnier@iro.umontreal.ca> |
926 | ||
927 | * buffer.c (Frestore_buffer_modified_p): Sync it with | |
928 | Fset_buffer_modified_p. | |
929 | (Fforce_mode_line_update): New function, moved from subr.el. | |
930 | (Fset_buffer_modified_p): Use them. | |
931 | (syms_of_buffer): Defsubr Fforce_mode_line_update. | |
932 | ||
5389db9e PE |
933 | 2013-11-11 Paul Eggert <eggert@cs.ucla.edu> |
934 | ||
935 | * search.c (find_newline): Rewrite to prefer offsets to pointers. | |
936 | This avoids undefined behavior when subtracting pointers into | |
937 | different aways. On my platform it also makes the code a tad | |
938 | smaller and presumably faster. | |
939 | ||
7818df11 SM |
940 | 2013-11-11 Stefan Monnier <monnier@iro.umontreal.ca> |
941 | ||
942 | * keyboard.c (command_loop_1): Use region-extract-function. | |
943 | * insdel.c (Qregion_extract_function): Not static any more (can we | |
944 | stop pretending that these vars can benefit from being marked static?). | |
945 | ||
85f37d10 EZ |
946 | 2013-11-09 Eli Zaretskii <eliz@gnu.org> |
947 | ||
948 | * search.c (find_newline): If buffer text is relocated during the | |
949 | "dumb loop", adjust C pointers into buffer text to follow suit. | |
950 | (Bug#15841) | |
951 | ||
0449d6cd | 952 | 2013-11-09 Łukasz Stelmach <stlman@poczta.fm> (tiny change) |
b24ac90f JD |
953 | |
954 | * gtkutil.c (xg_check_special_colors): Use rgb: instead of rgbi: | |
955 | for conversion (Bug#15837). | |
956 | ||
addccbd0 EZ |
957 | 2013-11-09 Eli Zaretskii <eliz@gnu.org> |
958 | ||
959 | * fileio.c (Finsert_file_contents): Invalidate the newline cache | |
960 | for the entire range of inserted characters. (Bug#15841) | |
961 | ||
5b97b4c0 JD |
962 | 2013-11-08 Jan Djärv <jan.h.d@swipnet.se> |
963 | ||
964 | * xfaces.c (lface_fully_specified_p): Let distant-foreground be | |
965 | unspecified. | |
966 | (realize_default_face): Remove assignment to distant-foreground if | |
967 | unspecified (Bug#15815). | |
968 | ||
080db47f EZ |
969 | 2013-11-08 Eli Zaretskii <eliz@gnu.org> |
970 | ||
971 | * xdisp.c (message_dolog): Make sure the *Messages* buffer has its | |
972 | cache-long-scans disabled, since we don't want to call | |
973 | prepare_to_modify_buffer (in insert_1_both) for each message we | |
974 | display. | |
975 | ||
976 | * buffer.h (bset_cache_long_scans): New INLINE function, moved | |
977 | from buffer.c. Improve commentary to the buffer field setter | |
978 | functions. | |
979 | ||
980 | * buffer.c (bset_cache_long_scans): Static function deleted. | |
981 | Improve commentary to the buffer field setter functions. | |
982 | (init_buffer_once): Default for cache-long-scans changed to t. | |
983 | (Bug#15797) | |
984 | ||
7f1913b2 PE |
985 | 2013-11-08 Paul Eggert <eggert@cs.ucla.edu> |
986 | ||
220a304a PE |
987 | * gmalloc.c (special_realloc, calloc, mallochook): Use tail calls. |
988 | ||
7f1913b2 PE |
989 | * chartab.c (make_sub_char_table): Fix size typo (Bug#15825). |
990 | This bug was introduced in my 2013-06-21 change, and caused | |
991 | struct Lisp_Sub_Char_Table objects to be given too many slots, | |
992 | which broke 'make -C admin/unidata'. | |
993 | ||
5ee29210 JD |
994 | 2013-11-07 Jan Djärv <jan.h.d@swipnet.se> |
995 | ||
996 | Import changes from mac-port 4.5. | |
997 | * macfont.m (mac_font_copy_default_descriptors_for_language) | |
998 | (mac_font_copy_default_name_for_charset_and_languages): Declare. | |
999 | (cf_charset_table): big-5-0 has uniquifier 0x4EDC. | |
1000 | (macfont_language_default_font_names): New. | |
1001 | (macfont_list): Rearrange language/charset code. | |
1002 | (macfont_close): Don't check for macfont_info->cache. | |
1003 | (mac_ctfont_create_preferred_family_for_attributes): New font | |
1004 | selection code, call | |
1005 | mac_font_copy_default_name_for_charset_and_languages. | |
1006 | (mac_font_copy_default_descriptors_for_language) | |
1007 | (mac_font_copy_default_name_for_charset_and_languages): New functions. | |
1008 | ||
1009 | * macfont.h (kCTVersionNumber10_9): Define if not defined. | |
1010 | ||
aea07e2c PE |
1011 | 2013-11-07 Paul Eggert <eggert@cs.ucla.edu> |
1012 | ||
1013 | Port to C11 aligned_alloc, and fix some integer overflows. | |
1014 | * alloc.c (USE_ALIGNED_ALLOC): New symbol. | |
1015 | (USE_POSIX_MEMALIGN): Remove. All uses replaced with USE_ALIGNED_ALLOC, | |
1016 | and use of posix_memalign replaced with aligned_alloc. | |
1017 | (aligned_alloc): New function, defined or declared as needed. | |
1018 | * conf_post.h (HAVE_POSIX_MEMALIGN) [DARWIN_OS]: | |
1019 | Don't undef; configure.ac now does this. | |
1020 | * gmalloc.c (aligned_alloc) [MSDOS]: New decl. | |
1021 | (calloc, aligned_alloc): Check for integer overflow. | |
1022 | (aligned_alloc): Rename from memalign. All uses changed. | |
1023 | (memalign): New function, an alias for aligned_alloc. | |
1024 | ||
e2e894cf SM |
1025 | 2013-11-06 Stefan Monnier <monnier@iro.umontreal.ca> |
1026 | ||
1027 | * xdisp.c (redisplay_internal): Fix typo in last change. | |
1028 | ||
a5d376b0 PE |
1029 | 2013-11-06 Paul Eggert <eggert@cs.ucla.edu> |
1030 | ||
1031 | * regex.c: Fix --enable-gcc-warning glitch with GCC 4.5.2. | |
1032 | ||
2ec9db5d SM |
1033 | 2013-11-06 Stefan Monnier <monnier@iro.umontreal.ca> |
1034 | ||
1035 | * xdisp.c (syms_of_xdisp): New vars redisplay--all-windows-cause and | |
1036 | redisplay--mode-lines-cause. | |
1037 | (redisplay_internal): Keep them uptodate. Remove redundant check of | |
1038 | buffer_shared_and_changed. | |
1039 | * *.[chm]: Number every assignment to update_mode_lines so we | |
1040 | can track why it is set. | |
1041 | ||
d7ac0815 EZ |
1042 | 2013-11-06 Eli Zaretskii <eliz@gnu.org> |
1043 | ||
1044 | * editfns.c (Fformat_time_string): Doc fix. (Bug#15816) | |
1045 | ||
94ae2ad4 SM |
1046 | 2013-11-06 Stefan Monnier <monnier@iro.umontreal.ca> |
1047 | ||
1048 | * *.[chm]: Number every assignment to windows_or_buffers_changed so we | |
1049 | can track why it is set. | |
1050 | ||
798aef02 PE |
1051 | 2013-11-06 Paul Eggert <eggert@cs.ucla.edu> |
1052 | ||
1053 | Integer-related fixes for term.c etc. | |
1054 | * dispextern.h (face_tty_specified_color): New function. | |
1055 | * term.c (turn_on_face): Don't rely on undefined behavior when | |
94ae2ad4 SM |
1056 | assigning an out-of-range value to 'long'. |
1057 | Simplify test for toggling highlight. | |
798aef02 PE |
1058 | (tty_capable_p): Omit last two (unused) args. All callers changed. |
1059 | * term.c (tty_capable_p, tty_menu_display, tty_menu_add_selection) | |
1060 | (read_menu_input, tty_menu_activate, tty_menu_show): | |
1061 | * xfaces.c (x_supports_face_attributes_p) | |
1062 | (tty_supports_face_attributes_p): | |
1063 | Use bool for boolean. All callers changed. | |
1064 | (tty_supports_face_attributes_p): Omit defaults for color indices; | |
1065 | no longer needed. Simplify tail call. | |
1066 | ||
9e6e9826 SM |
1067 | 2013-11-05 Stefan Monnier <monnier@iro.umontreal.ca> |
1068 | ||
1069 | * xdisp.c (prepare_menu_bars): Mark static. | |
1070 | * lisp.h (prepare_menu_bars): Don't declare. | |
1071 | * xselect.c (x_handle_selection_clear): | |
1072 | * callproc.c (call_process): Remove redundant call to prepare_menu_bars. | |
1073 | ||
7544a9d3 PE |
1074 | 2013-11-05 Paul Eggert <eggert@cs.ucla.edu> |
1075 | ||
1076 | * keyboard.c (Fcommand_error_default_function): Fix pointer signedness | |
1077 | glitch. Eliminate 'sz' prefix; Hungarian notation is not helpful here. | |
1078 | ||
2e670b95 SM |
1079 | 2013-11-05 Stefan Monnier <monnier@iro.umontreal.ca> |
1080 | ||
1081 | * keyboard.c (Fcommand_error_default_function): Rename from | |
1082 | Fdefault_error_output. | |
1083 | ||
2ea0d614 JC |
1084 | 2013-11-05 Jarek Czekalski <jarekczek@poczta.onet.pl> (tiny change) |
1085 | ||
2e670b95 SM |
1086 | * keyboard.c (Fdefault_error_output): New function, extracted from |
1087 | cmd_error_internal. | |
1088 | (syms_of_keyboard): Use it for Vcommand_error_function. | |
2ea0d614 | 1089 | |
70de5e86 SM |
1090 | 2013-11-05 Stefan Monnier <monnier@iro.umontreal.ca> |
1091 | ||
1092 | * eval.c (handlerlist_sentinel): New variable (bug#15802). | |
1093 | (init_eval): Use it to ensure handlerlist is non-NULL. | |
1094 | (unwind_to_catch): Make sure we never set handlerlist to NULL. | |
1095 | (Fsignal): Adjust NULLness test of handlerlist. | |
70de5e86 SM |
1096 | * lisp.h (PUSH_HANDLER): Assume handlerlist is non-NULL. |
1097 | ||
d57f4dde EZ |
1098 | 2013-11-05 Eli Zaretskii <eliz@gnu.org> |
1099 | ||
1100 | * callproc.c (call_process): Call prepare_to_modify_buffer before | |
1101 | decoding text read from the sub-process, as the decoded stuff will | |
1102 | be inserted into the buffer. This will invalidate the various | |
1103 | caches maintained for the buffer. (Bug#15148) | |
1104 | ||
29aa2b71 XF |
1105 | 2013-11-05 Xue Fuqiao <xfq.free@gmail.com> |
1106 | ||
1107 | * xdisp.c (syms_of_xdisp): Mention the active display table in doc | |
1108 | string of glyphless-char-display. | |
1109 | ||
ceb486d4 JD |
1110 | 2013-11-05 Jan Djärv <jan.h.d@swipnet.se> |
1111 | ||
1112 | * nsfns.m (ns_get_name_from_ioreg): New function. | |
1113 | (ns_screen_name): Don't use deprecated CGDisplayIOServicePort on | |
1114 | OSX >= 10.9. Use ns_get_name_from_ioreg. | |
1115 | ||
69369809 PE |
1116 | 2013-11-05 Paul Eggert <eggert@cs.ucla.edu> |
1117 | ||
df5b4930 PE |
1118 | Simplify and port recent bool vector changes. |
1119 | * alloc.c (ROUNDUP): Move here from lisp.h, since it's now used | |
1120 | only in this file. Use a more-efficient implementation if the | |
1121 | second argument is a power of 2. | |
1122 | (ALIGN): Rewrite in terms of ROUNDUP. Make it a function. | |
1123 | Remove no-longer-necessary compile-time checks. | |
1124 | (bool_vector_exact_payload_bytes): New function. | |
1125 | (bool_vector_payload_bytes): Remove 2nd arg; callers that need | |
1126 | exact payload changed to call the new function. Do not assume | |
1127 | that the arg or result fits in ptrdiff_t. | |
1128 | (bool_vector_fill): New function. | |
1129 | (Fmake_bool_vector): Use it. Don't assume bit counts fit | |
1130 | in ptrdiff_t. | |
1131 | (vroundup_ct): Don't assume arg fits in size_t. | |
1132 | * category.c (SET_CATEGORY_SET): Remove. All callers now just | |
1133 | invoke set_category_set. | |
1134 | (set_category_set): 2nd arg is now EMACS_INT and 3rd is now bool. | |
1135 | All callers changed. Use bool_vector_set. | |
1136 | * category.h (XCATEGORY_SET): Remove; no longer needed. | |
1137 | (CATEGORY_MEMBER): Now a function. Rewrite in terms of | |
1138 | bool_vector_bitref. | |
1139 | * data.c (Faref): Use bool_vector_ref. | |
1140 | (Faset): Use bool_vector_set. | |
1141 | (bits_word_to_host_endian): Don't assume you can shift by CHAR_BIT. | |
1142 | (Fbool_vector_not, Fbool_vector_count_matches) | |
1143 | (Fbool_vector_count_matches_at): Don't assume CHAR_BIT == 8. | |
1144 | * fns.c (concat): Use bool_vector_ref. | |
1145 | (Ffillarray): Use bool_vector_fill. | |
1146 | (mapcar1): Use bool_vector_ref. | |
1147 | (sxhash_bool_vector): Hash words, not bytes. | |
1148 | * lisp.h (BOOL_VECTOR_BITS_PER_CHAR): Now a macro as well as | |
1149 | a constant, since it's now used in #if. | |
1150 | (bits_word, BITS_WORD_MAX, BITS_PER_BITS_WORD): Fall back on | |
1151 | unsigned char on unusual architectures, so that we no longer | |
1152 | assume that the number of bits per bits_word is a power of two or | |
1153 | is a multiple of 8 or of CHAR_BIT. | |
1154 | (Qt): Add forward decl. | |
1155 | (struct Lisp_Bool_Vector): Don't assume EMACS_INT is aligned | |
1156 | at least as strictly as bits_word. | |
1157 | (bool_vector_data, bool_vector_uchar_data): New accessors. | |
1158 | All data structure accesses changed to use them. | |
1159 | (bool_vector_words, bool_vector_bitref, bool_vector_ref) | |
1160 | (bool_vector_set): New functions. | |
1161 | (bool_vector_fill): New decl. | |
1162 | (ROUNDUP): Move to alloc.c as described above. | |
1163 | ||
69369809 PE |
1164 | Fix recent gnutls changes. |
1165 | * gnutls.c (Fgnutls_boot): Don't assume C99. | |
1166 | * process.c (wait_reading_process_output): Fix typo in recent change. | |
1167 | ||
194b4d9f TZ |
1168 | 2013-11-05 Teodor Zlatanov <tzz@lifelogs.com> |
1169 | ||
1170 | * process.c (wait_reading_process_output, read_process_output) | |
1171 | (send_process): Check gnutls_state is not NULL. | |
1172 | ||
1173 | * gnutls.c (emacs_gnutls_handle_error): Adjust log level for EAGAIN. | |
1174 | (Fgnutls_boot): Set process gnutls_p later, after initialization. | |
1175 | ||
c8b09927 JD |
1176 | 2013-11-04 Jan Djärv <jan.h.d@swipnet.se> |
1177 | ||
1178 | * nsterm.m (init, run, stop:): New methods in EmacsApp for | |
1179 | OSX >= 10.9 to prevent memory leak of GCD dispatch source. | |
1180 | ||
1181 | * nsterm.h (EmacsApp): Add shouldKeepRunning and isFirst for | |
1182 | OSX >= 10.9. | |
1183 | ||
1184 | * nsfns.m (Fx_create_frame): Fix memory leak. | |
1185 | ||
1186 | * macfont.m (CG_SET_FILL_COLOR_WITH_GC_FOREGROUND) | |
1187 | (CG_SET_FILL_COLOR_WITH_GC_BACKGROUND) | |
1188 | (CG_SET_STROKE_COLOR_WITH_GC_FOREGROUND): Fix memory leak. | |
1189 | ||
d0065ff1 EZ |
1190 | 2013-11-04 Eli Zaretskii <eliz@gnu.org> |
1191 | ||
1192 | * xdisp.c (message3_nolog, message_with_string): Encode the string | |
1193 | before writing it to the terminal in a non-interactive session. | |
1194 | ||
1195 | * lread.c (openp): If both FILENAME and SUFFIX are unibyte, make | |
1196 | sure we concatenate them into a unibyte string. | |
1197 | ||
1198 | * fileio.c (make_temp_name): Encode PREFIX, and decode the | |
1199 | resulting temporary name before returning it to the caller. | |
1200 | (Fexpand_file_name): If NAME is pure-ASCII and DEFAULT_DIRECTORY | |
1201 | is a unibyte string, convert NAME to a unibyte string to ensure | |
1202 | that the result is also a unibyte string. | |
1203 | ||
1204 | * emacs.c (init_cmdargs): Use build_unibyte_string to make sure we | |
1205 | create unibyte strings from default paths and directory/file | |
1206 | names. | |
1207 | ||
1208 | * coding.h (ENCODE_FILE): Do not attempt to encode a unibyte | |
1209 | string. | |
1210 | ||
1211 | * callproc.c (init_callproc): Use build_unibyte_string to make | |
1212 | sure we create unibyte strings from default paths and | |
1213 | directory/file names. | |
1214 | ||
1215 | * buffer.c (init_buffer): Don't store default-directory of | |
be80645a | 1216 | *scratch* in multibyte form. The original problem which led to |
d0065ff1 EZ |
1217 | that is described in |
1218 | http://lists.gnu.org/archive/html/emacs-pretest-bug/2004-11/msg00532.html, | |
1219 | but it was solved long ago. (Bug#15260) | |
1220 | ||
91f2d272 PE |
1221 | 2013-11-04 Paul Eggert <eggert@cs.ucla.edu> |
1222 | ||
1223 | Port to stricter C99 platforms. | |
1224 | Especially, C99 prohibits nesting a struct X inside struct Y if | |
1225 | struct X has a flexible array member. | |
1226 | * alloc.c (struct sdata): New type. | |
1227 | (sdata): Implement in terms of struct sdata. | |
1228 | Remove u member; all uses replaced by next_vector, set_next_vector. | |
1229 | (SDATA_SELECTOR, SDATA_DATA, SDATA_DATA_OFFSET): Adjust to sdata change. | |
1230 | (SDATA_DATA_OFFSET): Now a constant, not a macro. | |
1231 | (struct sblock): Rename first_data member to data, which is now | |
1232 | a flexible array member. All uses changed. | |
1233 | (next_vector, set_next_vector, large_vector_vec): New functions. | |
1234 | (vector_alignment): New constant. | |
1235 | (roundup_size): Make it a multiple of ALIGNOF_STRUCT_LISP_VECTOR, too. | |
1236 | (struct large-vector): Now merely a NEXT member, since the old approach | |
1237 | ran afoul of stricter C99. All uses changed to use | |
1238 | large_vector_vec or large_vector_offset. | |
1239 | (large_vector_offset): New constant. | |
1240 | * dispnew.c: Include tparam.h, for tgetent. | |
1241 | Do not include term.h; no longer needed. | |
1242 | * gnutls.c (Fgnutls_boot): Don't continue after calling a _Noreturn. | |
1243 | * lisp.h (ENUM_BF) [__SUNPRO_C && __STDC__]: Use unsigned int. | |
1244 | (struct Lisp_Vector): Use a flexible array member for contents, | |
1245 | instead of a union with a member that is an array of size 1. | |
1246 | All uses changed. | |
1247 | (ALIGNOF_STRUCT_LISP_VECTOR): New constant, to make up for the | |
1248 | fact that the struct no longer contains a union. | |
1249 | (struct Lisp_Misc_Any, struct Lisp_Marker, struct Lisp_Overlay) | |
1250 | (struct Lisp_Save_Value, struct Lisp_Free): | |
1251 | Use unsigned, not int, for spacers, to avoid c99 warning. | |
1252 | (union specbinding): Use unsigned, not bool, for bitfield, as | |
1253 | bool is not portable to pre-C99 hosts. | |
1254 | ||
6dc6d301 GM |
1255 | 2013-11-04 Glenn Morris <rgm@gnu.org> |
1256 | ||
1257 | * emacs.c (usage_message): Mention that `-L :...' appends. | |
1258 | ||
b0b9e592 GM |
1259 | 2013-11-02 Glenn Morris <rgm@gnu.org> |
1260 | ||
fca2fccb GM |
1261 | * Makefile.in (abs_builddir): Remove. |
1262 | (bootstrap_exe): Use relative filename. | |
1263 | ||
c617f3d0 GM |
1264 | Use relative filenames in TAGS files. |
1265 | * Makefile.in (abs_srcdir): Remove it again. | |
1266 | (.PHONY): Remove frc. | |
1267 | (maintainer-clean): No more TAGS-LISP file. | |
1268 | (TAGS): Pass relative file names to etags. | |
1269 | (../lisp/TAGS): Rename from TAGS-LISP. Work in ../lisp. | |
1270 | ||
b0b9e592 | 1271 | * Makefile.in (abs_srcdir): New, set by configure. |
739f57cd | 1272 | (lispdir): Remove. |
b0b9e592 GM |
1273 | (maintainer-clean): Remove pointless echo. That should be in the |
1274 | top-level Makefile, if anywhere. Delete TAGS-LISP. | |
1275 | (extraclean): No s/ and m/ directories for some time. | |
739f57cd GM |
1276 | (TAGS): Also depend on ctagsfiles3. |
1277 | Remove no-longer-defined S_FILE. | |
b0b9e592 | 1278 | Pass absolute filenames to etags once more. |
739f57cd | 1279 | (TAGS-LISP): Replace lispdir with its expansion. |
b0b9e592 GM |
1280 | (TAGS-LISP, $(lwlibdir)/TAGS): Correctly pass ETAGS to sub-makes. |
1281 | ($(lwlibdir)/TAGS): Remove useless subshell, check cd return value. | |
1282 | ||
0c21fa44 JD |
1283 | 2013-11-02 Jan Djärv <jan.h.d@swipnet.se> |
1284 | ||
94ae2ad4 SM |
1285 | * xfaces.c (check_lface_attrs, realize_default_face): |
1286 | Add LFACE_DISTANT_FOREGROUND_INDEX (Bug#15788). | |
39dd7bb2 | 1287 | (realize_default_face): Set DISTANT_FOREGROUND to unspecified_fg. |
0c21fa44 | 1288 | |
a90e5a33 PE |
1289 | 2013-11-02 Paul Eggert <eggert@cs.ucla.edu> |
1290 | ||
1291 | * emacs.c (original_pwd): Remove global var by making it local. | |
1292 | (init_cmdargs): New arg ORIGINAL_PWD; caller changed. | |
1293 | ||
3c334c14 JD |
1294 | 2013-11-01 Jan Djärv <jan.h.d@swipnet.se> |
1295 | ||
1296 | * xfaces.c: Declare color_distance. | |
1297 | (QCdistant_foreground): New variable. | |
1298 | (NEAR_SAME_COLOR_THRESHOLD): New define. | |
1299 | (load_color2): New function. | |
1300 | (load_color): Call load_color2. | |
1301 | (load_face_colors): Call load_color2 and if distant-color is specified | |
1302 | calculate distant and use distant-color if colors are near. | |
1303 | (LFACE_DISTANT_FOREGROUND): New define. | |
1304 | (merge_face_ref, Finternal_set_lisp_face_attribute) | |
1305 | (Finternal_get_lisp_face_attribute) | |
1306 | (x_supports_face_attributes_p): Handle distant-foreground similar to | |
1307 | foreground. | |
1308 | (syms_of_xfaces): DEFSYM QCdistant_foreground. | |
1309 | ||
94ae2ad4 SM |
1310 | * dispextern.h (lface_attribute_index): |
1311 | Add LFACE_DISTANT_FOREGROUND_INDEX. | |
3c334c14 | 1312 | |
d14c81ee CB |
1313 | 2013-11-01 Claudio Bley <claudio.bley@googlemail.com> |
1314 | ||
94ae2ad4 SM |
1315 | * image.c (pbm_next_char): New function. |
1316 | See http://netpbm.sourceforge.net/doc/pbm.html for the details. | |
0e7690de CB |
1317 | (pbm_scan_number): Use it. |
1318 | (Qlibjpeg_version): New variable. | |
d14c81ee CB |
1319 | (syms_of_image): DEFSYM and initialize it. |
1320 | ||
26ca8870 JD |
1321 | 2013-10-31 Jan Djärv <jan.h.d@swipnet.se> |
1322 | ||
1323 | * emacs.c (main): Skip -psn args on OSX even if ! isatty (0). | |
1324 | ||
8fd07417 GM |
1325 | 2013-10-31 Glenn Morris <rgm@gnu.org> |
1326 | ||
1327 | * emacs.c (original_pwd): New char. | |
1328 | (main): If using --chdir, store original_pwd. | |
1329 | (init_cmdargs): When setting Vinvocation_directory based on a | |
1330 | relative argv[0], use original_pwd if set. (Bug#15768) | |
1331 | ||
4c9797cb SM |
1332 | 2013-10-29 Stefan Monnier <monnier@iro.umontreal.ca> |
1333 | ||
1334 | * keyboard.c (command_loop_1): If command is nil, call `undefined'. | |
1335 | ||
dcd163ac PE |
1336 | 2013-10-29 Paul Eggert <eggert@cs.ucla.edu> |
1337 | ||
1338 | * insdel.c: Fix minor problems found by static checking. | |
1339 | (Qregion_extract_function): Now static. | |
1340 | (prepare_to_modify_buffer_1): Remove unused locals. | |
1341 | ||
3472b6c6 SM |
1342 | 2013-10-29 Stefan Monnier <monnier@iro.umontreal.ca> |
1343 | ||
1344 | * xdisp.c (prepare_menu_bars): Call Vpre_redisplay_function. | |
1345 | (syms_of_xdisp): Declare pre-redisplay-function. | |
1346 | (markpos_of_region): Remove function. | |
1347 | (init_iterator, compute_stop_pos, handle_face_prop) | |
1348 | (face_before_or_after_it_pos, reseat_to_string) | |
1349 | (get_next_display_element, window_buffer_changed) | |
1350 | (redisplay_internal, try_cursor_movement, redisplay_window) | |
1351 | (try_window_reusing_current_matrix, try_window_id, display_line) | |
1352 | (note_mode_line_or_margin_highlight, note_mouse_highlight) | |
1353 | (display_string, mouse_face_from_buffer_pos): Remove region handling. | |
1354 | * window.h (struct window): Remove field `region_showing'. | |
1355 | * dispextern.h (struct it): Remove region_beg/end_charpos. | |
1356 | (face_at_buffer_position, face_for_overlay_string) | |
1357 | (face_at_string_position): Update prototypes. | |
1358 | * xfaces.c (face_at_buffer_position, face_for_overlay_string) | |
1359 | (face_at_string_position): Remove `region_beg' and `region_end' args. | |
1360 | * fontset.c (Finternal_char_font): | |
1361 | * font.c (font_at, font_range): Adjust calls accordingly. | |
1362 | * insdel.c (Qregion_extract_function): New var. | |
1363 | (syms_of_insdel): Initialize it. | |
1364 | (prepare_to_modify_buffer_1): Use it. | |
1365 | ||
2d9783e0 DA |
1366 | 2013-10-29 Dmitry Antipov <dmantipov@yandex.ru> |
1367 | ||
1368 | Prefer 'unsigned long' to 'long unsigned int' and 'unsigned long int'. | |
1369 | * ftxfont.c (ftxfont_get_gcs): | |
1370 | * gtkutil.c (xg_set_widget_bg, xg_set_background_color): | |
1371 | * xfaces.c (x_free_colors, x_free_dpy_colors) | |
1372 | (x_create_gc, unload_color): | |
1373 | * xselect.c (x_property_data_to_lisp): | |
1374 | * xsettings.c (parse_settings): | |
1375 | * xterm.c (x_copy_color, x_alloc_lighter_color, x_setup_relief_color) | |
1376 | (get_bits_and_offset): Adjust definition. | |
1377 | * frame.c (XParseGeometry): Adjust locals. | |
1378 | * lisp.h (toplevel): Adjust EMACS_UINT type definition. | |
1379 | * regex.h (toplevel): Likewise for reg_syntax_t. | |
1380 | ||
dee4ba59 SM |
1381 | 2013-10-29 Stefan Monnier <monnier@iro.umontreal.ca> |
1382 | ||
1383 | * eval.c (run_hook_with_args): Use FUNCTIONP. | |
1384 | ||
0085b9be DA |
1385 | 2013-10-29 Dmitry Antipov <dmantipov@yandex.ru> |
1386 | ||
1387 | * xterm.h (struct x_output): For 'black_relief' and 'white_relief' | |
1388 | fields, drop 'allocated_p' member and use -1 for uninitialized value. | |
1389 | * w32term.h (struct w32_output): Similarly but do not use -1 because... | |
1390 | * xfaces.c (unload_color) [HAVE_X_WINDOWS]: ...this function is a no-op | |
1391 | on MS-Windows anyway. | |
1392 | (free_face_colors): Define only if HAVE_X_WINDOWS and... | |
1393 | (free_realized_face): ...adjust user. | |
1394 | * xfns.c (Fx_create_frame, x_create_tip_frame): Initialize black and | |
1395 | white relief pixels to -1. | |
1396 | * xterm.c (x_setup_relief_color, x_free_frame_resources): Adjust users. | |
1397 | * w32term.c (w32_setup_relief_color, x_free_frame_resources): Likewise. | |
1398 | * dispextern.h (unload_color): Move prototype under HAVE_X_WINDOWS. | |
1399 | ||
b7e0ef72 PE |
1400 | 2013-10-28 Paul Eggert <eggert@cs.ucla.edu> |
1401 | ||
1402 | * dispextern.h, image.c (x_bitmap_height, x_bitmap_width): Now static. | |
1403 | * xfaces.c (load_pixmap): Omit last two args, which are always NULL | |
1404 | in practice now. All callers changed. | |
1405 | ||
5d3311e5 DA |
1406 | 2013-10-28 Dmitry Antipov <dmantipov@yandex.ru> |
1407 | ||
1408 | * dispextern.h (struct face): Use bitfields for 'underline_type' | |
1409 | and 'box' members. Remove set-but-unused members 'pixmap_w' and | |
1410 | 'pixmap_h'. If not HAVE_WINDOW_SYSTEM, also remove dummy | |
1411 | 'stipple' member. Move 'lface' member up to help... | |
1412 | * xfaces.c (make_realized_face): ...this function to find and | |
1413 | clear just the members that need clearing. | |
1414 | (load_face_colors, realize_x_face): | |
1415 | * xdisp.c (extend_face_to_end_of_line): Adjust user. | |
1416 | ||
0f771d26 DA |
1417 | 2013-10-27 Dmitry Antipov <dmantipov@yandex.ru> |
1418 | ||
1419 | * xftfont.c (struct xftfont_info): Remove set-but-unused | |
1420 | 'screen' member. | |
1421 | (xftfont_open): Adjust user. | |
1422 | (xftfont_get_colors): Remove useless prototype. | |
1423 | ||
c556b44b EZ |
1424 | 2013-10-26 Eli Zaretskii <eliz@gnu.org> |
1425 | ||
1426 | * emacs.c (Fdump_emacs): Encode FILENAME and SYMFILE arguments | |
1427 | before passing them to 'unexec'. (Bug#15260) | |
1428 | ||
2a03e2bc XF |
1429 | 2013-10-26 Xue Fuqiao <xfq.free@gmail.com> |
1430 | ||
1431 | * fringe.c (set_fringe_bitmap_face): Add usage note from lispref. | |
1432 | ||
6702c559 EZ |
1433 | 2013-10-25 Eli Zaretskii <eliz@gnu.org> |
1434 | ||
f67599d5 EZ |
1435 | * w32uniscribe.c (uniscribe_close): Adjust the argument list to |
1436 | the changed signature of the font driver's 'close' method. | |
1437 | ||
6702c559 EZ |
1438 | * w32font.h (w32font_close): Adjust the prototype to the change in |
1439 | function definition. | |
1440 | ||
1441 | * w32font.c (w32font_close): Reintroduce deleted declaration of i. | |
1442 | ||
1443 | * w32uniscribe.c (uniscribe_close): Adapt the call to | |
1444 | w32font_close to its new prototype. | |
1445 | ||
78e0b35c DA |
1446 | 2013-10-25 Dmitry Antipov <dmantipov@yandex.ru> |
1447 | ||
1448 | Omit unused frame argument of font API's close function. | |
1449 | * font.h (struct font): Drop frame argument. Adjust comment. | |
1450 | * font.c (font_clear_cache, font_close_object): Adjust users. | |
1451 | * ftfont.c (ftfont_close): | |
1452 | * ftxfont.c (ftxfont_close): | |
1453 | * macfont.m (macfont_close): | |
1454 | * nsfont.m (nsfont_close): | |
1455 | * w32font.c (w32font_close): | |
1456 | * xfont.c (xfont_close): | |
86bd985e DA |
1457 | * xftfont.c (xftfont_close): Adjust driver-specific close functions, |
1458 | tweak comments and make functions safe if called more than once for | |
1459 | the same font object. | |
1460 | ||
1461 | Perform font-specific cleanup when font object is swept by GC. See | |
1462 | http://lists.gnu.org/archive/html/emacs-devel/2013-10/msg00740.html. | |
1463 | * alloc.c (cleanup_vector): New function. | |
1464 | (sweep_vector): Call it for each reclaimed vector object. | |
1465 | * font.h (struct font): Adjust comment. | |
78e0b35c | 1466 | |
eb9a3661 GM |
1467 | 2013-10-24 Glenn Morris <rgm@gnu.org> |
1468 | ||
1469 | * Makefile.in (abs_top_srcdir): New, set by configure. | |
1470 | ||
df24a230 DA |
1471 | 2013-10-23 Dmitry Antipov <dmantipov@yandex.ru> |
1472 | ||
66b238df | 1473 | Adjust recent font-related changes to fix bug#15686. |
df24a230 | 1474 | * alloc.c (mark_object) [HAVE_WINDOW_SYSTEM]: If marked frame |
66b238df | 1475 | is a live window system frame, mark its default font too. |
df24a230 | 1476 | |
b8e3b0a9 GM |
1477 | 2013-10-23 Glenn Morris <rgm@gnu.org> |
1478 | ||
1479 | * Makefile.in (RUN_TEMACS): Make relative (again). | |
1480 | ($(leimdir)/leim-list.el, .el.elc, $(lispsource)/loaddefs.el) | |
1481 | (bootstrap-emacs$(EXEEXT)): | |
1482 | Quote entities that might contain whitespace. | |
1483 | ||
e4ea223d PE |
1484 | 2013-10-23 Paul Eggert <eggert@cs.ucla.edu> |
1485 | ||
1486 | Port to Solaris 10 and its bundled GCC. | |
1487 | Problem reported by Timothy C. Burt. | |
1488 | * floatfns.c (isfinite, isnan): Redefine unconditionally. | |
1489 | ||
fc54bdd5 DA |
1490 | 2013-10-21 Dmitry Antipov <dmantipov@yandex.ru> |
1491 | ||
1492 | Do not allow font caches to grow too large. | |
1493 | * alloc.c (compact_font_cache_entry, compact_font_caches): | |
1494 | New functions or stub if not HAVE_WINDOW_SYSTEM. | |
1495 | (compact_undo_list): Factor out from Fgarbage_collect. | |
1496 | Add comment. | |
1497 | (mark_face_cache): Mark face font. Move down to avoid | |
1498 | extra prototypes. | |
1499 | (mark_terminals): Do not mark font cache here. | |
1500 | (Fgarbage_collect): Call compaction functions described | |
1501 | above. Adjust comment. | |
1502 | ||
aca5fcdc JD |
1503 | 2013-10-20 Jan Djärv <jan.h.d@swipnet.se> |
1504 | ||
a9f8deec JD |
1505 | * emacs.c (main): On Cocoa, if GUI session and 0 is not a tty, |
1506 | chdir to HOME (bug#15607). | |
1507 | ||
aca5fcdc JD |
1508 | * nsterm.m (Qcocoa, Qgnustep): New variables. |
1509 | (syms_of_nsterm): Defsym Qcocoa, Qgnustep. Fprovide appropriate one. | |
d4816ab3 | 1510 | (ns_get_color): Make selection color work for GNUStep also. |
aca5fcdc | 1511 | |
c4e3099f EZ |
1512 | 2013-10-18 Eli Zaretskii <eliz@gnu.org> |
1513 | ||
1514 | * keyboard.c (make_lispy_event): Remove GPM-specific code that | |
1515 | handles mouse clicks. Instead, let GPM use the same code as all | |
1516 | the other mice use. See the discussion starting at | |
1517 | http://lists.gnu.org/archive/html/emacs-devel/2013-10/msg00521.html | |
1518 | for the details of the problem with the menu bar this fixes. | |
1519 | ||
d141d701 DA |
1520 | 2013-10-18 Dmitry Antipov <dmantipov@yandex.ru> |
1521 | ||
1522 | Remove port-specific display name lists to avoid extra | |
1523 | complexity and data duplication with display info lists. | |
1524 | * xterm.h (x_display_name_list): Remove declaration. | |
1525 | * xterm.c (x_display_name_list): Remove. | |
1526 | (x_term_init, x_delete_display, syms_of_xterm): Adjust users. | |
1527 | * xfns.c (x_display_info_for_name, Fx_display_list): | |
1528 | Likewise. Use x_display_list where appropriate. | |
1529 | * w32term.h (w32_display_name_list): Remove declaration. | |
1530 | * w32term.c (w32_display_name_list): Remove. | |
1531 | (w32_initialize_display_info, x_delete_display, syms_of_w32term): | |
1532 | Adjust users. | |
1533 | * w32fns.c (x_display_info_for_name, Fx_display_list): | |
1534 | Likewise. Use x_display_list where appropriate. | |
1535 | * nsterm.h (ns_display_name_list): Remove declaration. | |
1536 | * nsterm.m (ns_display_name_list): Remove. | |
1537 | (ns_term_init, syms_of_nsterm): Adjust users. | |
1538 | * nsfns.m (ns_display_info_for_name, Fx_display_list): | |
1539 | Likewise. Use x_display_list where appropriate. | |
1540 | * termhooks.h (TERMINAL_FONT_CACHE): New macro. | |
1541 | * alloc.c (toplevel) [HAVE_WINDOW_SYSTEM]: Include TERM_HEADER. | |
1542 | (mark_terminals): Mark per-terminal font cache. | |
1543 | ||
ef566920 BR |
1544 | 2013-10-17 Barry O'Reilly <gundaetiapo@gmail.com> |
1545 | ||
1546 | Don't run timers in input-pending-p. Its new check-timers param | |
1547 | provides the prior behavior. (Bug#15045). | |
1548 | * src/keyboard.c (Finput_pending_p): Accept optional check-timers | |
1549 | param. | |
1550 | ||
f2752e01 PE |
1551 | 2013-10-17 Paul Eggert <eggert@cs.ucla.edu> |
1552 | ||
3d798ba7 PE |
1553 | Make some functions static in non-Microsoft builds. |
1554 | On my platform (Fedora 19 x86-64), this shrinks the | |
1555 | Emacs executable (text+data) by 0.25%. | |
1556 | * dispextern.h (erase_phys_cursor) [!WINDOWSNT]: | |
1557 | (load_color) [!MSDOS]: | |
1558 | * gnutls.h (emacs_gnutls_transport_set_errno) [!WINDOWSNT]: | |
1559 | * keyboard.h (make_ctrl_char) [!WINDOWSNT]: | |
1560 | * lisp.h (check_existing): | |
1561 | * process.h (conv_sockaddr_to_lisp, network_interface_list) | |
1562 | (network_interface_info) [!WINDOWSNT]: | |
1563 | * termhooks.h (encode_terminal_code) [!WINDOWSNT]: | |
1564 | Remove extern decls. | |
1565 | * fileio.c (check_existing): | |
1566 | * keyboard.c (make_ctrl_char) [!WINDOWSNT]: | |
1567 | * process.c (conv_sockaddr_to_lisp, network_interface_list) | |
1568 | (network_interface_info) [!WINDOWSNT]: | |
1569 | * term.c (encode_terminal_code) [!WINDOWSNT]: | |
1570 | * xdisp.c (erase_phys_cursor) [!WINDOWSNT]: | |
1571 | * xfaces.c (load_color) [!MSDOS]: | |
1572 | Now static. | |
1573 | * fileio.c (check_existing, check_executable, check_writable): | |
1574 | * process.c (network_interface_list, network_interface_info): | |
1575 | Move earlier, so that we don't need forward decls. | |
1576 | * gnutls.c (fn_gnutls_transport_set_errno) | |
1577 | (emacs_gnutls_transport_set_errno) [!WINDOWNT]: | |
1578 | Remove; unused. | |
1579 | * w32.c (init_environment): Use faccessat rather than | |
1580 | check_existing, partly for consistency with the rest of the code | |
1581 | in this file, partly so that check_existing can be static. | |
1582 | ||
bb9937df PE |
1583 | Make VALMASK visible to GDB even if clang is used (Bug#15574). |
1584 | * emacs.c (MAIN_PROGRAM): New macro. | |
1585 | * lisp.h (DEFINE_GDB_SYMBOL_BEGIN, DEFINE_GDB_SYMBOL_END): New macros. | |
1586 | (ARRAY_MARK_FLAG, PSEUDOVECTOR_FLAG, VALMASK): Use them. | |
1587 | ||
f2752e01 PE |
1588 | bool vector int width fixes |
1589 | * data.c (bool_vector_spare_mask, Fbool_vector_count_matches) | |
1590 | (Fbool_vector_count_matches_at): | |
1591 | Use EMACS_INT, not ptrdiff_t, to record bit counts, as a bit count | |
1592 | can exceed PTRDIFF_MAX, at least in theory. | |
1593 | (Fbool_vector_count_matches_at): | |
1594 | Use int, not ptrdiff_t, to record a value that can't exceed INT_MAX. | |
1595 | ||
0a2b8e3c PE |
1596 | 2013-10-16 Paul Eggert <eggert@cs.ucla.edu> |
1597 | ||
1598 | * process.h (conv_sockaddr_to_lisp): New decl, for newly-extern func. | |
1599 | (struct sockaddr): Add forward decl, for platforms that lack it. | |
1600 | ||
2318fcca JD |
1601 | 2013-10-16 Jan Djärv <jan.h.d@swipnet.se> |
1602 | ||
1603 | * nsselect.m (ns_string_from_pasteboard): Remove Fquit, just return | |
1604 | Qnil (Bug#15628). | |
1605 | ||
b911a94d EZ |
1606 | 2013-10-16 Eli Zaretskii <eliz@gnu.org> |
1607 | ||
3dffe395 EZ |
1608 | * w32.c (network_interface_get_info, network_interface_list) |
1609 | (network_interface_info): New functions. (Bug#15610) | |
1610 | (GetAdaptersInfo_Proc): New typedef. | |
1611 | (get_adapters_info): New wrapper function. | |
1612 | (globals_of_w32): Initialize g_b_init_get_adapters_info. | |
1613 | ||
dee4ba59 SM |
1614 | * process.h (network_interface_list, network_interface_info): |
1615 | New prototypes. | |
3dffe395 EZ |
1616 | |
1617 | * process.c (conv_sockaddr_to_lisp): Now externally-visible. | |
1618 | (Fnetwork_interface_list, Fnetwork_interface_info): Define for | |
1619 | all systems. Return non-nil for systems that HAVE_NET_IF_H and | |
1620 | for WINDOWSNT. Doc fix. | |
1621 | (syms_of_process): Defsubr Snetwork_interface_list and | |
1622 | Snetwork_interface_info unconditionally. | |
1623 | ||
b911a94d EZ |
1624 | * menu.c (have_boxes): Fix redundant simulation of radio buttons |
1625 | in NS GUI sessions. (Bug#15629) | |
1626 | ||
04d47595 DA |
1627 | 2013-10-16 Dmitry Antipov <dmantipov@yandex.ru> |
1628 | ||
1629 | * fns.c (Fstring_as_unibyte): Use xlispstrdup. | |
1630 | ||
5e15c624 PE |
1631 | 2013-10-15 Paul Eggert <eggert@cs.ucla.edu> |
1632 | ||
1633 | * print.c (print_object): Print " ..." when truncating bool vectors. | |
1634 | ||
5d64d770 EZ |
1635 | 2013-10-15 Eli Zaretskii <eliz@gnu.org> |
1636 | ||
1637 | * w32inevt.c (do_mouse_event): Support mouse wheel and all the 5 | |
1638 | standard mouse buttons. | |
1639 | ||
1640 | * termhooks.h (struct input_event): Remove incorrect commentary. | |
1641 | ||
c911772e PE |
1642 | 2013-10-15 Paul Eggert <eggert@cs.ucla.edu> |
1643 | ||
454e2fb9 PE |
1644 | Disallow bool vector operations on mixed-length operands. |
1645 | The old behavior left garbage in the result vector sometimes, | |
1646 | and didn't seem to be useful. | |
1647 | * data.c (Qwrong_length_argument): New static var. | |
1648 | (wrong_length_argument): New function. | |
1649 | (bool_vector_binop_driver): Check that args agree in length. | |
1650 | ||
c911772e PE |
1651 | * keyboard.c, keyboard.h (all_kboards): Now static. |
1652 | ||
57f623e2 XF |
1653 | 2013-10-15 Xue Fuqiao <xfq.free@gmail.com> |
1654 | ||
1655 | * buffer.c (syms_of_buffer) <buffer-invisibility-spec>: Add usage | |
1656 | note from the lispref. | |
1657 | ||
47c4d1e9 DA |
1658 | 2013-10-15 Dmitry Antipov <dmantipov@yandex.ru> |
1659 | ||
1660 | * nsterm.h (struct ns_display_info): Remove set-but-unused | |
1661 | member image_cache (image caches are per-terminal anyway). | |
1662 | (FRAME_X_IMAGE_CACHE): Remove. | |
1663 | * nsterm.m (ns_initialize_display_info): Adjust user. | |
1664 | ||
ccd4a783 EZ |
1665 | 2013-10-14 Eli Zaretskii <eliz@gnu.org> |
1666 | ||
279066b2 EZ |
1667 | * w32proc.c: Include mingw_time.h. |
1668 | ||
1669 | * w32.c: Include mingw_time.h. | |
1670 | ||
ccd4a783 EZ |
1671 | Implement scrolling of TTY menus when the screen is too short. |
1672 | ||
1673 | * term.c (tty_menu_display): Accept an additional argument, the | |
1674 | menu item from which to start displaying the menu. Account for | |
1675 | the value of Y when limiting the menu to the number of available | |
1676 | screen lines. | |
1677 | (mi_result): New enumeration. | |
1678 | (read_menu_input): Return enumerated value. When the y coordinate | |
1679 | hits min_y or max_y, return scroll indication instead of wrapping | |
1680 | around the menu. | |
1681 | (tty_menu_activate): Handle the scrolling indications from | |
1682 | read_menu_input. Compute the first menu item to display and pass | |
1683 | it to tty_menu_display. | |
1684 | ||
77e3b1b7 DA |
1685 | 2013-10-14 Dmitry Antipov <dmantipov@yandex.ru> |
1686 | ||
1687 | * termhooks.h (FRAME_MUST_WRITE_SPACES, FRAME_LINE_INS_DEL_OK) | |
1688 | (FRAME_CHAR_INS_DEL_OK, FRAME_SCROLL_REGION_OK) | |
1689 | (FRAME_SCROLL_REGION_COST, FRAME_MEMORY_BELOW_FRAME): | |
1690 | Adjust to match the change described below. | |
1691 | (struct terminal): Move must_write_spaces, line_ins_del_ok, | |
1692 | char_ins_del_ok, scroll_region_ok, scroll_region_cost and | |
1693 | memory_below_frame members to... | |
1694 | * termchar.h (struct tty_display_info): ...here because they're | |
1695 | relevant only on TTYs. Prefer unsigned bitfield where appropriate. | |
1696 | * term.c (init_tty): | |
1697 | * nsterm.m (ns_create_terminal): | |
1698 | * w32term.c (w32_create_terminal): | |
1699 | * xterm.c (x_create_terminal): Adjust users. | |
1700 | * dispnew.c (line_hash_code, line_draw_cost): Pass frame arg | |
1701 | to filter out non-TTY frames. Adjust comment. | |
1702 | (scrolling): Adjust user. Prefer eassert for debugging check. | |
1703 | ||
e558436b DA |
1704 | 2013-10-14 Dmitry Antipov <dmantipov@yandex.ru> |
1705 | ||
1706 | * xfaces.c (PT_PER_INCH): Remove unused macro. | |
1707 | * termhooks.h (struct terminal): Remove set-but-unused | |
1708 | member fast_clear_end_of_line. | |
1709 | (FRAME_FAST_CLEAR_END_OF_LINE): Remove. | |
1710 | * nsterm.m (ns_create_terminal): | |
1711 | * term.c (init_tty): | |
1712 | * w32term.c (w32_create_terminal): | |
1713 | * xterm.c (x_create_terminal): Adjust users. | |
1714 | ||
1c0a7493 PE |
1715 | 2013-10-14 Paul Eggert <eggert@cs.ucla.edu> |
1716 | ||
1717 | * lisp.h (bool_vector_size): New function. | |
1718 | All uses of XBOOL_VECTOR (x)->size changed to bool_vector_size (x). | |
1719 | * data.c (bool_vector_spare_mask, bool_vector_binop_driver) | |
1720 | (Fbool_vector_not, Fbool_vector_count_matches_at): | |
1721 | Remove uses of 'eassume' that should no longer be needed, | |
1722 | because they are subsumed by the 'eassume' in bool_vector_size. | |
1723 | ||
567f95ec EZ |
1724 | 2013-10-12 Eli Zaretskii <eliz@gnu.org> |
1725 | ||
1726 | * image.c (GIFLIB_MAJOR, GIFLIB_MINOR, GIFLIB_RELEASE): Move back | |
1727 | after inclusion of gif_lib.h, thus fixing compiler warnings caused | |
1728 | by 2013-10-10T19:15:33Z!eggert@cs.ucla.edu. | |
1729 | ||
abe02020 EZ |
1730 | 2013-10-11 Eli Zaretskii <eliz@gnu.org> |
1731 | ||
1732 | * xdisp.c (deep_copy_glyph_row): Handle the case that FROM and TO | |
1733 | have different dimensions. (Bug#15575) | |
1734 | ||
1735 | * dispnew.c (fill_up_frame_row_with_spaces): Now has external | |
1736 | visibility. | |
1737 | ||
1738 | * dispextern.h (fill_up_frame_row_with_spaces): Add prototype. | |
1739 | ||
9428abbf DA |
1740 | 2013-10-11 Dmitry Antipov <dmantipov@yandex.ru> |
1741 | ||
1742 | * term.c (tty_menu_show): Never return with unbalanced | |
1743 | specpdl. Use eassert for debugging check. Adjust style. | |
1744 | ||
052bac0b EZ |
1745 | 2013-10-11 Eli Zaretskii <eliz@gnu.org> |
1746 | ||
1747 | * term.c (read_menu_input): Make selection of menu items | |
1748 | cyclical. Suggested by Dmitry Antipov <dmantipov@yandex.ru>. | |
1749 | (tty_menu_activate): Fix off-by-one error when computing max_y. | |
1750 | ||
e1f9f9e3 TZ |
1751 | 2013-10-11 Teodor Zlatanov <tzz@lifelogs.com> |
1752 | ||
1753 | * gnutls.c (gnutls_audit_log_function): Add function for GnuTLS | |
1754 | audit logging (only used with GnuTLS 3.x) and enable it. | |
1755 | ||
7d563e36 DA |
1756 | 2013-10-11 Dmitry Antipov <dmantipov@yandex.ru> |
1757 | ||
1758 | * dispnew.c (redraw_frame): Remove useless #ifdef because | |
1759 | FRAME_MSDOS_P is a compile-time zero everywhere except MS-DOS. | |
1760 | Also, move TTY fflush to... | |
1761 | * term.c (tty_update_end): ...this function. | |
1762 | ||
48621e69 EZ |
1763 | 2013-10-11 Eli Zaretskii <eliz@gnu.org> |
1764 | ||
1765 | * xdisp.c (display_tty_menu_item): Make sure we never write beyond | |
1766 | the end of the frame's glyph matrix. (Bug#15575) | |
1767 | ||
1768 | * term.c (tty_menu_display): Don't move cursor while overwriting | |
1769 | frame's glyphs with menu items. Limit the number of items | |
1770 | displayed to what can be shown on the available screen lines, | |
1771 | excluding the echo area. | |
1772 | (tty_menu_activate): Limit the Y coordinate allowed by | |
1773 | read_menu_input to the last screen line used for menu display. | |
1774 | ||
b9ff995e PE |
1775 | 2013-10-11 Paul Eggert <eggert@cs.ucla.edu> |
1776 | ||
1777 | * lisp.h (eassume): New macro. | |
1778 | Also, include <verify.h>, for 'assume'. | |
1779 | * alloc.c (bool_vector_payload_bytes, Fmake_bool_vector) | |
1780 | (vroundup, vector_nbytes): | |
1781 | * data.c (bool_vector_spare_mask, bool_vector_binop_driver) | |
1782 | (Fbool_vector_not, Fbool_vector_count_matches) | |
1783 | (Fbool_vector_count_matches_at): | |
1784 | Use eassume, not eassert. | |
1785 | * casetab.c (set_identity, shuffle): | |
1786 | * composite.c (composition_gstring_put_cache): | |
1787 | * dispnew.c (update_frame_1): | |
1788 | * ftfont.c (ftfont_shape_by_flt): | |
1789 | * image.c (gif_load): | |
1790 | * intervals.c (offset_intervals): | |
1791 | * macfont.m (macfont_shape): | |
1792 | Remove calls to 'assume' that are no longer needed, because | |
1793 | --enable-gcc-warnings no longer generates bogus warnings | |
1794 | when these calls are removed. | |
1795 | ||
33ac0265 DA |
1796 | 2013-10-11 Dmitry Antipov <dmantipov@yandex.ru> |
1797 | ||
1798 | * xdisp.c (deep_copy_glyph_row): Remove unused locals. | |
1799 | ||
ee041f2d SM |
1800 | 2013-10-10 Stefan Monnier <monnier@iro.umontreal.ca> |
1801 | ||
1802 | * fileio.c (Fsubstitute_in_file_name): Use substitute-env-in-file-name. | |
1803 | (Qsubstitute_env_in_file_name): New var. | |
1804 | (syms_of_fileio): Define it. | |
1805 | ||
00036e1d EZ |
1806 | 2013-10-10 Eli Zaretskii <eliz@gnu.org> |
1807 | ||
1808 | * xdisp.c (deep_copy_glyph_row): Assert that the 'used' counts of | |
1809 | FROM and TO are identical. Copy only the glyphs of TEXT_AREA. | |
1810 | (Bug#15575) | |
1811 | ||
1812 | * term.c (save_and_enable_current_matrix): Don't allocate and | |
1813 | don't save margin areas. | |
1814 | (restore_desired_matrix): Don't restore margin areas. | |
1815 | (free_saved_screen): Don't free margin areas. | |
1816 | ||
99149625 PE |
1817 | 2013-10-10 Paul Eggert <eggert@cs.ucla.edu> |
1818 | ||
1819 | * image.c: Pacify --enable-gcc-warnings. | |
1820 | (GIFLIB_MAJOR, GIFLIB_MINOR, GIFLIB_RELEASE, fn_GifErrorString): | |
1821 | #define only if used. | |
1822 | ||
a5dab159 EZ |
1823 | 2013-10-10 Eli Zaretskii <eliz@gnu.org> |
1824 | ||
1825 | * image.c (GIFLIB_MAJOR): Define to 4 if undefined. | |
1826 | (GIFLIB_MINOR, GIFLIB_RELEASE): Define to zero if undefined. | |
1827 | (GifErrorString) [GIFLIB_MAJOR >= 5]: Define a function pointer. | |
1828 | (gif_load): For giflib v5.x and later, display the error message | |
1829 | produced by giflib when its functions fail. | |
1830 | (syms_of_image) <Qlibgif_version> [HAVE_NTGUI]: New DEFSYM. | |
1831 | (Bug#15531) | |
1832 | ||
6bbe6da8 DA |
1833 | 2013-10-10 Dmitry Antipov <dmantipov@yandex.ru> |
1834 | ||
1835 | * keyboard.c (last_event_timestamp): Remove. For X selection and | |
1836 | GTK popup menus, it may be obtained from per-frame X display info. | |
1837 | (kbd_buffer_store_event_hold, kbd_buffer_get_event) | |
1838 | (process_special_events): Adjust users. | |
1839 | * keyboard.h (last_event_timestamp): Remove declaration. | |
1840 | * xmenu.c (xmenu_show, create_and_show_popup_menu): Lost last arg. | |
1841 | Use FRAME_DISPLAY_INFO (f)->last_user_time for gtk_menu_popup. | |
1842 | * menu.h (xmenu_show): Adjust prototype. | |
1843 | * menu.c (Fx_popup_menu): Adjust user. | |
1844 | * xselect.c (x_own_selection, x_get_foreign_selection) | |
1845 | (Fx_disown_selection_internal): Use dpyinfo->last_user_time. | |
1846 | ||
1afcba63 DA |
1847 | 2013-10-10 Dmitry Antipov <dmantipov@yandex.ru> |
1848 | ||
1849 | * keyboard.c (init_kboard): Now static. Add arg | |
1850 | to denote window system. Adjust comment. | |
1851 | (init_keyboard): Adjust user. | |
1852 | (allocate_kboard): New function. | |
1853 | (syms_of_keyboard): | |
1854 | * nsterm.m (ns_term_init): | |
1855 | * term.c (init_tty): | |
1856 | * w32term.c (w32_create_terminal): | |
1857 | * xterm.c (x_term_init): Use it. | |
1858 | * keyboard.h (init_kboard): Remove prototype. | |
1859 | (allocate_kboard): Add prototype. | |
1860 | ||
f3606ef7 BF |
1861 | 2013-10-10 Barry Fishman <barry_fishman@acm.org> (tiny change) |
1862 | ||
1863 | * image.c (GIFLIB_MAJOR): Ensure it's defined. | |
1864 | (DGifOpen, DGifOpenFileName): Handle giflib 5 syntax. (Bug#15531) | |
1865 | ||
e20bb249 PE |
1866 | 2013-10-09 Paul Eggert <eggert@cs.ucla.edu> |
1867 | ||
1868 | * fns.c (sxhash_bool_vector): Fix buffer read overrun. | |
1869 | ||
9f6a18d2 EZ |
1870 | 2013-10-09 Eli Zaretskii <eliz@gnu.org> |
1871 | ||
1872 | * term.c (tty_menu_activate): Flush the output stream after | |
1873 | showing the cursor, and don't mark the frame garbaged at exit from | |
1874 | the function. Fixes redisplay glitches when moving from one menu | |
1875 | to another. | |
1876 | ||
0486beac JD |
1877 | 2013-10-09 Jan Djärv <jan.h.d@swipnet.se> |
1878 | ||
1879 | * nsfns.m (Fns_convert_utf8_nfd_to_nfc): Check input for valid UTF-8 | |
1880 | or throw error (Bug#15570). | |
1881 | ||
0d5d3029 PE |
1882 | 2013-10-09 Paul Eggert <eggert@cs.ucla.edu> |
1883 | ||
ab7ce978 PE |
1884 | * intervals.c (temp_set_point_both): Move test into 'eassert', |
1885 | for speed. | |
1886 | ||
0d5d3029 PE |
1887 | * lisp.h (eassert): Don't use 'assume'. |
1888 | Sometimes 'assume' wins in performance, and sometimes it loses, | |
1889 | so it shouldn't be used all the time. Perhaps we need two | |
1890 | flavors of 'eassert', one for where 'assume' is far more likely | |
1891 | to help or to hurt; but that can be done later. | |
1afcba63 | 1892 | Problem reported by Dmitry Antipov in |
0d5d3029 PE |
1893 | <http://lists.gnu.org/archive/html/emacs-devel/2013-10/msg00276.html>. |
1894 | Also, don't include <verify.h>; no longer needed. | |
1895 | ||
fa022909 GM |
1896 | 2013-10-09 Glenn Morris <rgm@gnu.org> |
1897 | ||
1898 | * eval.c (Fcond): Doc tweak. | |
1899 | ||
051277bf EZ |
1900 | 2013-10-09 Eli Zaretskii <eliz@gnu.org> |
1901 | ||
1902 | * xfaces.c (x_free_gc) [HAVE_X_WINDOWS, HAVE_NTGUI]: Don't pass | |
1903 | expressions with side effects to eassert. (Bug#15565) | |
1904 | ||
79804536 SM |
1905 | 2013-10-09 Stefan Monnier <monnier@iro.umontreal.ca> |
1906 | ||
1907 | * fns.c (hashfn_user_defined): Allow hash functions to return any | |
1908 | Lisp_Object. | |
1909 | ||
3b158d11 PE |
1910 | 2013-10-08 Paul Eggert <eggert@cs.ucla.edu> |
1911 | ||
1912 | Fix minor problems found by static checking. | |
1913 | * dispnew.c (save_current_matrix): Omit unnecessary casts. | |
1914 | * dispnew.c (update_frame_with_menu): Mark debug local as used. | |
1915 | * keyboard.c, keyboard.h (Qmouse_movement): Now static. | |
1916 | * keyboard.c (read_menu_command): Remove unused local. | |
1917 | * lisp.h (read_menu_command): New decl. | |
1918 | * menu.c, menu.h (menu_item_width): Arg is now unsigned char *, for | |
1919 | benefit of STRING_CHAR_AND_LENGTH. All uses changed. | |
1920 | Return ptrdiff_t, not int. | |
1921 | * term.c (tty_menu_struct): 'allocated' member is now ptrdiff_t, | |
1922 | not int, for benefit of xpalloc. | |
1923 | (tty_menu_create, tty_menu_make_room): Simplify by using xzalloc | |
1924 | and xpalloc. | |
1925 | (have_menus_p): Remove; unused. | |
1926 | (tty_menu_add_pane, tty_menu_add_selection): Change signedness of | |
1927 | local char * pointer to pacify STRING_CHAR_AND_LENGTH. | |
1928 | (tty_menu_add_selection, tty_menu_locate, tty_meny_destroy): | |
1929 | Now static. | |
1930 | (save_and_enable_current_matrix): Omit unnecessary casts. | |
1931 | (read_menu_input): Omit local extern decl (now in lisp.h). | |
1932 | Don't access uninitialized storage if mouse_get_xy fails. | |
1933 | (tty_menu_activate): Mark local as initialized, for lint. | |
1934 | (tty_menu_activate, tty_meny_show): Remove unused locals. | |
1935 | ||
4ed77415 EZ |
1936 | 2013-10-08 Eli Zaretskii <eliz@gnu.org> |
1937 | ||
1938 | Support menus on text-mode terminals. | |
1939 | * xterm.h (xw_popup_dialog): Add prototype. | |
1940 | ||
1941 | * xmenu.c (Fx_popup_dialog): Function moved to menu.c. | |
1942 | (xmenu_show): Block input here, instead in Fx_popup_menu. | |
1943 | (xw_popup_dialog): New function, with X-specific bits of popup | |
1944 | dialogs. | |
1945 | ||
dee4ba59 SM |
1946 | * xdisp.c (deep_copy_glyph_row, display_tty_menu_item): |
1947 | New functions. | |
4ed77415 EZ |
1948 | |
1949 | * window.c (Fset_window_configuration): Use run-time tests of the | |
1950 | frame type instead of compile-time conditionals, when menu-bar | |
1951 | lines are considered. | |
1952 | ||
1953 | * w32term.h (w32con_hide_cursor, w32con_show_cursor) | |
1954 | (w32_popup_dialog): New prototypes. | |
1955 | ||
1956 | * w32menu.c (Fx_popup_dialog): Function deleted. | |
1957 | (w32_popup_dialog): New function, with w32 specific bits of popup | |
1958 | dialogs. Block input here. | |
1959 | ||
1960 | * w32inevt.c (w32_console_read_socket): Minor change to add | |
1961 | debugging TTY events. | |
1962 | ||
1963 | * w32fns.c (show_hourglass): If returning early because the frame | |
1964 | is not a GUI frame, unblock input. | |
1965 | ||
1966 | * w32console.c (w32con_hide_cursor, w32con_show_cursor, cursorX) | |
1967 | (cursorY): New functions. | |
1968 | ||
1969 | * termhooks.h (cursorX, cursorY): Prototypes of functions on | |
1970 | WINDOWSNT, macros that call curX and curY elsewhere. | |
1971 | ||
1972 | * termchar.h (struct tty_display_info) <showing_menu>: New flag. | |
1973 | ||
1974 | * term.c (tty_hide_cursor, tty_show_cursor) [WINDOWSNT]: Call w32 | |
1975 | specific function to hide and show cursor on a text-mode terminal. | |
1976 | (tty_menu_struct, struct tty_menu_state): New structures. | |
1977 | (tty_menu_create, tty_menu_make_room, tty_menu_search_pane) | |
1978 | (tty_menu_calc_size, mouse_get_xy, tty_menu_display) | |
1979 | (have_menus_p, tty_menu_add_pane, tty_menu_add_selection) | |
1980 | (tty_menu_locate, save_and_enable_current_matrix) | |
1981 | (restore_desired_matrix, screen_update, read_menu_input) | |
1982 | (tty_menu_activate, tty_menu_destroy, tty_menu_help_callback) | |
1983 | (tty_pop_down_menu, tty_menu_last_menubar_item) | |
1984 | (tty_menu_new_item_coords, tty_menu_show): New functions. | |
1985 | (syms_of_term): New DEFSYMs for tty-menu-* symbols. | |
1986 | ||
1987 | * nsterm.h (ns_popup_dialog): Adjust prototype. | |
1988 | ||
1989 | * nsmenu.m (ns_menu_show): Block and unblock input here, instead | |
1990 | of in x-popup-menu. | |
1991 | (ns_popup_dialog): Adapt order of arguments to the other | |
1992 | *_menu_show implementations. | |
1993 | (Fx_popup_dialog): Function deleted. | |
1994 | ||
1995 | * msdos.c (x_set_menu_bar_lines): Delete unused function. | |
1996 | ||
1997 | * menu.h (tty_menu_show, menu_item_width): provide prototypes. | |
1998 | ||
1999 | * menu.c (have_boxes): New function. | |
2000 | (single_keymap_panes): Use it instead of a compile-time | |
2001 | conditional. | |
2002 | (single_menu_item): Use run-time tests of the frame type instead | |
2003 | of compile-time conditionals. | |
2004 | (encode_menu_string): New function. | |
2005 | (list_of_items, list_of_panes): Use it instead of ENCODE_STRING | |
2006 | the macro, since different types of frame need different encoding | |
2007 | of menu items. | |
2008 | (digest_single_submenu): Use run-time tests of frame type instead | |
2009 | of, or in addition to, compile-time conditionals. | |
2010 | (menu_item_width, Fmenu_bar_menu_at_x_y): New functions. | |
2011 | (Fx_popup_menu): Detect when the function is called from keyboard | |
dee4ba59 SM |
2012 | on a TTY. Don't barf when invoked on a text-mode frame. |
2013 | Check frame type at run time, instead of compile-time conditionals for | |
2014 | invoking terminal-specific menu-show functions. | |
2015 | Call tty_menu_show on text-mode frames. | |
2016 | (Fx_popup_dialog): Move here from xmenu.c. Test frame types at | |
4ed77415 EZ |
2017 | run time to determine which alternative to invoke; support dialogs |
2018 | on TTYs. | |
2019 | ||
2020 | * keyboard.h <Qmouse_movement>: Declare. | |
2021 | ||
2022 | * keyboard.c <Qmouse_movement>: Now extern. | |
2023 | <Qecho_keystrokes>: New static variable. | |
2024 | (read_key_sequence): Accept an additional argument, a flag to | |
2025 | prevent redisplay during reading of the key sequence. All callers | |
2026 | changed. | |
2027 | (read_menu_command): New function. | |
2028 | (read_char): When COMMANDFLAG is -2, do not redisplay and do not | |
2029 | autosave. | |
2030 | (toolkit_menubar_in_use): New function. | |
2031 | (make_lispy_event): Use it instead of a compile-time test. | |
2032 | ||
2033 | * fns.c (Fyes_or_no_p) [HAVE_MENUS]: Don't condition on | |
2034 | window-system being available. | |
2035 | ||
2036 | * editfns.c (Fmessage_box) [HAVE_MENUS]: Don't condition the call | |
2037 | to x-popup-dialog on the frame type, they all now support popup | |
2038 | dialogs. | |
2039 | ||
2040 | * dispnew.c (save_current_matrix): Save the margin areas. | |
2041 | (restore_current_matrix): Restore margin areas. | |
2042 | (update_frame_with_menu): New function. | |
2043 | ||
2044 | * dispextern.h (display_tty_menu_item, update_frame_with_menu): | |
2045 | Add prototypes. | |
2046 | ||
2047 | * alloc.c (make_save_ptr): Now compiled unconditionally. | |
2048 | ||
ecab13d4 DA |
2049 | 2013-10-08 Dmitry Antipov <dmantipov@yandex.ru> |
2050 | ||
2051 | * dispnew.c (set_window_update_flags): Add buffer arg. Adjust comment. | |
2052 | (redraw_frame, update_frame): Adjust users. | |
2053 | * dispextern.h (set_window_update_flags): Adjust prototype. | |
2054 | * xdisp.c (redisplay_internal): When updating all frames with zero | |
2055 | windows_or_buffers_changed, assume that only the windows that shows | |
2056 | current buffer should be really updated. | |
2057 | ||
f8498081 DA |
2058 | 2013-10-08 Dmitry Antipov <dmantipov@yandex.ru> |
2059 | ||
2060 | Do not allocate huge temporary memory areas and objects while encoding | |
2061 | for file I/O, thus reducing an enormous memory usage for large buffers. | |
2062 | See http://lists.gnu.org/archive/html/emacs-devel/2013-10/msg00180.html. | |
2063 | * coding.h (struct coding_system): New member raw_destination. | |
2064 | * coding.c (setup_coding_system): Initialize it to zero. | |
2065 | (encode_coding_object): If raw_destination is set, do not create | |
2066 | dst_object. Add comment. | |
2067 | * fileio.c (toplevel): New constant E_WRITE_MAX. | |
2068 | (e_write): Do not encode more than E_WRITE_MAX characters per one loop | |
2069 | iteration. Use raw_destination if E_WRITE_MAX characters is encoded. | |
2070 | ||
d180bde8 JD |
2071 | 2013-10-08 Jan Djärv <jan.h.d@swipnet.se> |
2072 | ||
2073 | * nsterm.m (windowDidExitFullScreen:): | |
2074 | (toggleFullScreen:): Change NS_IMPL_COCOA to HAVE_NATIVE_FS. | |
2075 | ||
87c4314d PE |
2076 | 2013-10-08 Paul Eggert <eggert@cs.ucla.edu> |
2077 | ||
18978362 PE |
2078 | Fix race where emacs aborts when sent SIGTERM (Bug#15534). |
2079 | * keyboard.c (unblock_input_to): Don't process pending signals | |
2080 | if a fatal error is in progress. | |
2081 | ||
87c4314d PE |
2082 | * lisp.h (bits_word, BITS_WORD_MAX): New type and macro. |
2083 | All uses of 'size_t' and 'SIZE_MAX' changed to use them, when | |
2084 | they're talking about words in Lisp bool vectors. | |
2085 | (BITS_PER_BITS_WORD): Rename from BITS_PER_SIZE_T. All uses changed. | |
1142cc2a PE |
2086 | * data.c (popcount_bits_word): Rename from popcount_size_t. |
2087 | (bits_word_to_host_endian): Rename from size_t_to_host_endian. | |
2088 | All uses changed. | |
87c4314d | 2089 | |
595e113b PE |
2090 | 2013-10-07 Paul Eggert <eggert@cs.ucla.edu> |
2091 | ||
2092 | Improve support for popcount and counting trailing zeros (Bug#15550). | |
2093 | * data.c: Include <count-one-bits.h>, <count-trailing-zeros.h>. | |
2094 | (USE_MSC_POPCOUNT, POPCOUNT_STATIC_INLINE) | |
2095 | (NEED_GENERIC_POPCOUNT, popcount_size_t_generic) | |
2096 | (popcount_size_t_msc, popcount_size_t_gcc): | |
2097 | Remove; now done by Gnulib. | |
2098 | (popcount_size_t): Now a macro that defers to Gnulib. | |
2099 | (count_trailing_zero_bits): Return int, for consistency with | |
2100 | Gnulib and because Emacs prefers signed to unsigned int. | |
2101 | Don't assume that size_t is either unsigned int or unsigned long | |
2102 | or unsigned long long. | |
2103 | (size_t_to_host_endian): Do not assume that size_t is either | |
2104 | exactly 32 or exactly 64 bits wide. | |
2105 | * lisp.h (BITS_PER_SIZE_T): Define consistently with BITS_PER_LONG | |
2106 | etc., so that it's now an enum constant, not a macro. | |
2107 | No need to assume that it's either 32 or 64. | |
2108 | ||
ddb317ba JD |
2109 | 2013-10-07 Jan Djärv <jan.h.d@swipnet.se> |
2110 | ||
2111 | * nsterm.m (windowDidEnterFullScreen:): setPresentationOptions only | |
2112 | on >= 10.7. | |
2113 | ||
bd74250f DA |
2114 | 2013-10-07 Dmitry Antipov <dmantipov@yandex.ru> |
2115 | ||
2116 | * insdel.c (insert_from_gap): Prefer ptrdiff_t to int where needed. | |
764636db | 2117 | * xdisp.c (handle_fontified_prop): Likewise. Use bool for boolean. |
bd74250f | 2118 | |
223752d7 PE |
2119 | 2013-10-07 Paul Eggert <eggert@cs.ucla.edu> |
2120 | ||
2121 | emacs_read and emacs_write now use void *, not char *. | |
2122 | * alloc.c (valid_pointer_p) [!WINDOWSNT]: Remove now-unnecessary cast. | |
2123 | * sysdep.c (emacs_read, emacs_write, emacs_write_sig): | |
2124 | Buffer arg is now void *, not char *. This matches plain | |
2125 | 'read' and 'write' better, and avoids a constraint violation | |
2126 | on Solaris 9 with Oracle Studio. | |
2127 | ||
3c439e0a DA |
2128 | 2013-10-07 Dmitry Antipov <dmantipov@yandex.ru> |
2129 | ||
2130 | * alloc.c (Fmake_string): For ASCII char initializer, prefer | |
2131 | memset to explicit loop. Otherwise copy largest possible chunk | |
2132 | from initialized to uninitialized part, thus allowing the longer | |
2133 | memcpy runs and reducing the number of loop iterations. | |
2134 | ||
28c76099 JD |
2135 | 2013-10-06 Jan Djärv <jan.h.d@swipnet.se> |
2136 | ||
2137 | * nsterm.m (ns_update_begin): If native fullscreen and no toolbar, | |
2138 | hide toolbar (Bug#15388). | |
2139 | (windowDidEnterFullScreen:): If presentation options are zero, | |
2140 | set them here (Bug#15388). | |
a3e9050c JD |
2141 | (ns_update_auto_hide_menu_bar): Remove runtime check. |
2142 | Don't auto hide dock unless menubar is also auto hidden. | |
28c76099 | 2143 | |
544a2a80 XF |
2144 | 2013-10-05 Xue Fuqiao <xfq.free@gmail.com> |
2145 | ||
2146 | * editfns.c (message): Mention batch mode in doc string. | |
2147 | ||
a27fd309 JD |
2148 | 2013-10-05 Jan Djärv <jan.h.d@swipnet.se> |
2149 | ||
2150 | * nsterm.m (check_native_fs): Remove erroneous comment. | |
2151 | ||
942f6f82 DA |
2152 | 2013-10-04 Dmitry Antipov <dmantipov@yandex.ru> |
2153 | ||
2154 | * xdisp.c (redisplay_internal): Simplify because scan_for_column now | |
2155 | uses find_newline instead of scan_newline and so doesn't move point. | |
2156 | ||
157fec2e PE |
2157 | 2013-10-04 Paul Eggert <eggert@cs.ucla.edu> |
2158 | ||
4eed3157 PE |
2159 | Use hardware support for byteswapping on glibc x86 etc. |
2160 | On Fedora 19 x86-64, the new bswap_64 needs 1 instruction, | |
2161 | whereas the old swap64 needed 30. | |
2162 | * fringe.c (init_fringe_bitmap) [WORDS_BIGENDIAN]: | |
2163 | * sound.c (le2hl, le2hs, be2hl) [!WINDOWSNT]: | |
2164 | Use byteswap.h's macros to swap bytes. | |
2165 | * lisp.h (swap16, swap32, swap64): Remove. | |
2166 | All uses replaced by bswap_16, bswap_32, bswap_64. | |
2167 | ||
157fec2e PE |
2168 | * bytecode.c (exec_byte_code): Use some more volatile variables |
2169 | to work around local variables getting clobbered by longjmp. | |
2170 | Port to pre-C99, which doesn't allow decls after stmts. | |
2171 | ||
b52f569d PE |
2172 | 2013-10-03 Paul Eggert <eggert@cs.ucla.edu> |
2173 | ||
75273afb PE |
2174 | * lisp.h (eassert): Assume that COND is true when optimizing. |
2175 | In other words, take on the behavior of eassert_and_assume. | |
2176 | This makes Emacs 0.2% smaller on my platform (Fedora 19, x86-64). | |
2177 | (eassert_and_assume): Remove. All uses replaced by eassert. | |
2178 | ||
ead45345 PE |
2179 | * xdisp.c (Qglyphless_char): Now static. |
2180 | ||
0a858ebf PE |
2181 | Adjust to merge from gnulib. |
2182 | * conf_post.h (__has_builtin, assume): Remove; gnulib now does these. | |
2183 | * lisp.h: Include <verify.h>, for 'assume'. | |
2184 | ||
b52f569d PE |
2185 | * eval.c (clobbered_eassert): New macro. |
2186 | (internal_catch, internal_condition_case) | |
2187 | (internal_condition_case_1, internal_condition_case_2) | |
2188 | (internal_condition_case_n): Use it instead of eassert | |
2189 | when the argument contains locals clobbered by longjmp. | |
2190 | Don't use clobbered locals outside of clobbered_eassert. | |
2191 | (internal_lisp_condition_case): Use a volatile variable | |
2192 | to work around a local variable's getting clobbered. | |
2193 | ||
adf2aa61 SM |
2194 | 2013-10-03 Stefan Monnier <monnier@iro.umontreal.ca> |
2195 | ||
2196 | * lisp.h (struct handler): Merge struct handler and struct catchtag. | |
2197 | (PUSH_HANDLER): New macro. | |
2198 | (catchlist): Remove. | |
2199 | (handlerlist): Always declare. | |
2200 | ||
2201 | * eval.c (catchlist): Remove (merge with handlerlist). | |
2202 | (handlerlist, lisp_eval_depth): Not static any more. | |
2203 | (internal_catch, internal_condition_case, internal_condition_case_1) | |
2204 | (internal_condition_case_2, internal_condition_case_n): | |
2205 | Use PUSH_HANDLER. | |
2206 | (unwind_to_catch, Fthrow, Fsignal): Adjust to merged | |
2207 | handlerlist/catchlist. | |
2208 | (internal_lisp_condition_case): Use PUSH_HANDLER. Adjust to new | |
2209 | handlerlist which can only handle a single condition-case handler at | |
2210 | a time. | |
2211 | (find_handler_clause): Simplify since we only a single branch here | |
2212 | any more. | |
2213 | ||
2214 | * bytecode.c (BYTE_CODES): Add Bpushcatch, Bpushconditioncase | |
2215 | and Bpophandler. | |
2216 | (bcall0): New function. | |
2217 | (exec_byte_code): Add corresponding cases. Improve error message when | |
2218 | encountering an invalid byte-code. Let Bunwind_protect accept | |
2219 | a function (rather than a list of expressions) as argument. | |
2220 | ||
2221 | * alloc.c (Fgarbage_collect): Merge scans of handlerlist and catchlist, | |
2222 | and make them unconditional now that they're heap-allocated. | |
2223 | ||
328a8179 SM |
2224 | 2013-10-03 Stefan Monnier <monnier@iro.umontreal.ca> |
2225 | ||
2226 | * charset.c (Fdecode_char, Fencode_char): Remove description of | |
2227 | `restriction' arg. now that it's hidden by advertised-calling-convention. | |
2228 | ||
c348360a JD |
2229 | 2013-10-02 Jan Djärv <jan.h.d@swipnet.se> |
2230 | ||
328a8179 SM |
2231 | * macfont.m (mac_ctfont_create_preferred_family_for_attributes): |
2232 | Remove unused variable (from mac-port). | |
c348360a JD |
2233 | (macfont_draw): Use s->ybase for correct y position. |
2234 | ||
1a23cd48 DA |
2235 | 2013-10-02 Dmitry Antipov <dmantipov@yandex.ru> |
2236 | ||
2237 | * frame.h (struct frame): Drop has_minibuffer member because... | |
2238 | (FRAME_HAS_MINIBUF_P): ...this macro can be implemented without it. | |
2239 | * frame.c (make_frame, make_minibuffer_frame): Adjust users. | |
2240 | ||
29bf4de4 DA |
2241 | 2013-10-02 Dmitry Antipov <dmantipov@yandex.ru> |
2242 | ||
2243 | * window.h (struct window): Prefer enum text_cursor_kinds to int | |
2244 | for phys_cursor_type member. Move the latter, phys_cursor_width, | |
2245 | phys_cursor_ascent and phys_cursor_height under HAVE_WINDOW_SYSTEM. | |
2246 | * window.c (replace_window, make_window): Adjust users. | |
2247 | ||
a30ddace DA |
2248 | 2013-10-02 Dmitry Antipov <dmantipov@yandex.ru> |
2249 | ||
2250 | * fringe.c (toplevel): Do not use HAVE_WINDOW_SYSTEM because | |
2251 | this module is never compiled otherwise. | |
2252 | ||
45435f08 AA |
2253 | 2013-10-01 Alp Aker <alp.tekin.aker@gmail.com> |
2254 | ||
2255 | * macfont.m (macfont_draw): Use CGRectMake rather than NSMakeRect | |
2256 | (Bug#15500). | |
2257 | ||
92e5298b EZ |
2258 | 2013-09-29 Eli Zaretskii <eliz@gnu.org> |
2259 | ||
2260 | * xdisp.c (get_next_display_element): Don't call face_for_font in | |
2261 | a build configured --without-x. (Bug#15484) | |
2262 | ||
caa50be2 JD |
2263 | 2013-09-29 Jan Djärv <jan.h.d@swipnet.se> |
2264 | ||
66d13b20 JD |
2265 | * window.c (calc_absolute_offset): #elif should be #elif defined. |
2266 | ||
caa50be2 JD |
2267 | * frame.c (delete_frame): Block/unblock input to overcome race |
2268 | condition (Bug#15475). | |
2269 | ||
d3e2acb6 AP |
2270 | 2013-09-29 Andreas Politz <politza@hochschule-trier.de> (tiny change) |
2271 | ||
2272 | * frame.c (delete_frame): Record selected frame only after | |
2273 | calling Qdelete_frame_functions (Bug#15477). | |
2274 | ||
1610938f JD |
2275 | 2013-09-28 Jan Djärv <jan.h.d@swipnet.se> |
2276 | ||
2277 | * nsterm.m (ns_selection_color): Remove. | |
2278 | (ns_get_color): Check for ns_selection_(fg|bg)_color using | |
2279 | NSColor selectedText(Background)Color. Only for COCOA. | |
2280 | (ns_term_init): Remove assignment of ns_selection_color, logic | |
2281 | moved to ns_get_color. | |
2282 | ||
328a8179 | 2283 | * nsterm.h (NS_SELECTION_BG_COLOR_DEFAULT): Rename from |
1610938f JD |
2284 | NS_SELECTION_COLOR_DEFAULT. |
2285 | (NS_SELECTION_FG_COLOR_DEFAULT): New. | |
2286 | ||
0d2647e6 EZ |
2287 | 2013-09-28 Eli Zaretskii <eliz@gnu.org> |
2288 | ||
2289 | * xdisp.c (Fdump_tool_bar_row): Ifdef away the body if 'struct | |
2290 | frame' does not have the tool_bar_window member. | |
2291 | ||
ba355de0 BR |
2292 | 2013-09-26 Barry O'Reilly <gundaetiapo@gmail.com> |
2293 | ||
2294 | Signal error when reading an empty byte-code object (Bug#15405) | |
2295 | * lread.c (read1): signal error | |
2296 | * alloc.c (make_byte_code): eassert header size | |
2297 | (sweep_vectors): change an int to size_t | |
2298 | ||
4710d6f4 PE |
2299 | 2013-09-24 Paul Eggert <eggert@cs.ucla.edu> |
2300 | ||
cf647d93 PE |
2301 | * dispnew.c (clear_glyph_row, copy_row_except_pointers): Use enums |
2302 | instead of ints, as it's the usual style for offsetof constants. See: | |
2303 | http://lists.gnu.org/archive/html/emacs-devel/2013-09/msg00478.html | |
2304 | ||
4710d6f4 PE |
2305 | * data.c (POPCOUNT_STATIC_INLINE): New macro, as a hack for popcount. |
2306 | This is ugly, but it should fix the performance problem for older | |
2307 | GCC versions in the short run. I'll look into integrating the | |
2308 | Gnulib module for popcount, as a better fix. | |
2309 | See the thread starting in: | |
2310 | http://lists.gnu.org/archive/html/emacs-devel/2013-09/msg00474.html | |
2311 | (popcount_size_t_generic) [NEED_GENERIC_POPCOUNT]: | |
2312 | (popcount_size_t_msc) [USE_MSC_POPCOUNT]: | |
2313 | (popcount_size_t_gcc) [USE_GCC_POPCOUNT]: | |
2314 | (popcount_size_t): Use it. | |
2315 | ||
10ebac9d DC |
2316 | 2013-09-24 Daniel Colascione <dancol@dancol.org> |
2317 | ||
2318 | * process.c (Fnetwork_interface_info): Fix build break due to | |
2319 | vector changes. | |
2320 | ||
9da0f50e PE |
2321 | 2013-09-24 Paul Eggert <eggert@cs.ucla.edu> |
2322 | ||
2323 | * dispnew.c (clear_glyph_row, copy_row_except_pointers): | |
2324 | Prefer signed to unsigned integers where either will do. | |
2325 | No need for 'const' on locals that do not escape. | |
2326 | Omit easserts with unnecessary and unportable assumptions about | |
2327 | alignment. Avoid unnecessary casts to char *. | |
2328 | ||
d6d9cbc1 DA |
2329 | 2013-09-24 Dmitry Antipov <dmantipov@yandex.ru> |
2330 | ||
2331 | Use union for the payload of struct Lisp_Vector. | |
2332 | This helps to avoid a few glitches dictated by C's aliasing rules. | |
2333 | * lisp.h (struct Lisp_Vector): Use union for next and | |
2334 | contents member. Adjust comment. Change related users. | |
2335 | * alloc.c (next_in_free_list, set_next_in_free_list): Remove. | |
2336 | Related users changed. | |
2337 | * buffer.c, bytecode.c, ccl.c, character.h, chartab.c, composite.c: | |
2338 | * composite.h, disptab.h, fns.c, fontset.c, indent.c, keyboard.c: | |
2339 | * lread.c, msdos.c, process.c, w32menu.c, window.c, xdisp.c: | |
2340 | * xfaces.c, xfont.c, xmenu.c: Related users changed. | |
2341 | ||
ec7bc82f DA |
2342 | 2013-09-24 Dmitry Antipov <dmantipov@yandex.ru> |
2343 | ||
2344 | Optimize glyph row clearing and copying routines. | |
2345 | * dispextern.h (struct glyph_row): Change layout of struct | |
2346 | glyph_row to help copy_row_except_pointers. Adjust comment. | |
2347 | * dispnew.c (null_row): Remove. | |
2348 | (clear_glyph_row): Use offsetof and memset to find and clear | |
2349 | just the members that need clearing. Adjust comment. | |
2350 | (copy_row_except_pointers): Likewise for copying. | |
2351 | ||
d160dd0c PE |
2352 | 2013-09-24 Paul Eggert <eggert@cs.ucla.edu> |
2353 | ||
7be68de5 PE |
2354 | Some minor cleanups of recently-added bool vector code. |
2355 | * conf_post.h (assume): Always return void. Use lint version | |
2356 | only if GCC and MSC versions don't apply. | |
2357 | * conf_post.h (assume): | |
2358 | * data.c (USC_MSC_POPCOUNT, count_trailing_zero_bits): | |
2359 | Depend on _MSC_VER, not __MSC_VER, for consistency with | |
2360 | the rest of Emacs. | |
2361 | * data.c (bool_vector_spare_mask, popcount_size_t_generic) | |
2362 | (popcount_size_t_msc, popcount_size_t_gcc, popcount_size_t) | |
2363 | (bool_vector_binop_driver, count_trailing_zero_bits) | |
2364 | (size_t_to_host_endian): Now static, not static inline; | |
2365 | the latter isn't needed with modern compilers and doesn't | |
2366 | work with older compilers anyway. | |
2367 | ||
d160dd0c PE |
2368 | * alloc.c (valgrind_p): Use bool for boolean. |
2369 | ||
e08813d0 DA |
2370 | 2013-09-23 Dmitry Antipov <dmantipov@yandex.ru> |
2371 | ||
2372 | * xdisp.c (noninteractive_need_newline, message_log_need_newline) | |
2373 | (overlay_arrow_seen, message_enable_multibyte, line_number_displayed) | |
2374 | (display_last_displayed_message_p, message_buf_print) | |
2375 | (message_cleared_p, help_echo_showing_p, hourglass_shown_p): | |
2376 | Use bool for boolean. | |
3a6a78fd DA |
2377 | * dispextern.h (cancel_line, init_desired_glyphs): |
2378 | Remove ancient leftover. | |
2379 | (help_echo_showing_p, hourglass_shown_p): | |
e08813d0 DA |
2380 | * lisp.h (noninteractive_need_newline): Adjust declaration. |
2381 | ||
5492865b DA |
2382 | 2013-09-23 Dmitry Antipov <dmantipov@yandex.ru> |
2383 | ||
2384 | * dispnew.c (frame_garbaged, selected_frame, last_nonminibuf_frame): | |
2385 | Move to... | |
2386 | * frame.c (frame_garbaged, selected_frame, last_nonminibuf_frame): | |
2387 | ...this file and convert the latter to static. Adjust comment. | |
2388 | (make_initial_frame): | |
2389 | * window.c (init_window_once): Adjust user. | |
2390 | * frame.h (last_nonminibuf_frame): Remove declaration. | |
2391 | * lisp.h (selected_frame): Likewise. | |
2392 | * msdos.c (the_only_display_info): Adjust comment. | |
2393 | ||
cd548fa4 EZ |
2394 | 2013-09-23 Eli Zaretskii <eliz@gnu.org> |
2395 | ||
f03eddbf EZ |
2396 | * xdisp.c (mouse_face_from_string_pos): Fix off-by-one error in |
2397 | computing the end column of mouse-highlight that comes from | |
2398 | display or overlay strings. (Bug#15437) | |
b519df23 EZ |
2399 | (note_mouse_highlight): Adapt calculation of last argument to |
2400 | mouse_face_from_string_pos to the above change. | |
f03eddbf | 2401 | |
cd548fa4 EZ |
2402 | * conf_post.h (__has_builtin): Define to zero, if undefined, on |
2403 | all platforms, not just for clang. | |
2404 | ||
8762e524 JD |
2405 | 2013-09-23 Jan Djärv <jan.h.d@swipnet.se> |
2406 | ||
2407 | * filelock.c (lock_file_1): Rearrange to remove compiler warning | |
2408 | about excess arguments to snprintf. | |
2409 | ||
2410 | * conf_post.h(assume): Use __builtin_unreachable for clang. | |
2411 | ||
d4a9284f JB |
2412 | 2013-09-23 Juanma Barranquero <lekktu@gmail.com> |
2413 | ||
2414 | * w32console.c (initialize_w32_display): Remove unused variable hlinfo. | |
2415 | * w32term.c (w32_scroll_bar_handle_click): Remove unused variable f. | |
2416 | ||
a84683fd DC |
2417 | 2013-09-23 Daniel Colascione <dancol@dancol.org> |
2418 | ||
2419 | * alloc.c (USE_VALGRIND): New macro; on by default | |
2420 | when ENABLE_CHECKING. | |
ffb3f67a | 2421 | (mark_maybe_object, mark_maybe_pointer) |
a84683fd DC |
2422 | [USE_VALGRIND]: Mark conservatively-scanned regions valid for |
2423 | valgrind purposes. | |
2424 | (valgrind_p) [USE_VALGRIND]: New variable. | |
2425 | (init_alloc) [USE_VALGRIND]: Initialize valgrind_p. | |
2426 | ||
8fef36c6 JD |
2427 | 2013-09-22 Jan Djärv <jan.h.d@swipnet.se> |
2428 | ||
fb83ea63 JD |
2429 | * process.c (wait_reading_process_output): Change int pnamelen to |
2430 | socklen_t. | |
2431 | ||
2432 | * nsterm.m (setMarkedText:selectedRange:): | |
2433 | (deleteWorkingText): | |
2434 | * nsmenu.m (addDisplayItemWithImage:idx:tag:helpText:enabled:): | |
2435 | * nsfont.m (ns_get_covering_families, ns_findfonts): Cast NSLog | |
2436 | argument to unsigned long to avoid warning. | |
2437 | (nsfont_draw): Use 0.25 instead of Fix2X (kATSItalicQDSkew). | |
2438 | ||
8fef36c6 JD |
2439 | * conf_post.h (assume): Fix compiler error: x shall be cond. |
2440 | ||
cd9356f2 DC |
2441 | 2013-09-22 Daniel Colascione <dancol@dancol.org> |
2442 | ||
2443 | * xfns.c (x_get_monitor_attributes): Suppress unused variable | |
2444 | warning when compiling without a window system. | |
2445 | ||
3e0b94e7 DC |
2446 | 2013-09-22 Daniel Colascione <dancol@dancol.org> |
2447 | ||
2448 | * data.c (Qbool_vector_p): New symbol. | |
ffb3f67a PE |
2449 | (bool_vector_spare_mask, popcount_size_t_generic) |
2450 | (popcount_size_t_msc, popcount_size_t_gcc) | |
3e0b94e7 DC |
2451 | (popcount_size_t) |
2452 | (bool_vector_binop_driver) | |
ffb3f67a | 2453 | (count_trailing_zero_bits, size_t_to_host_endian) |
3e0b94e7 DC |
2454 | (Fbool_vector_exclusive_or) |
2455 | (Fbool_vector_union) | |
ffb3f67a PE |
2456 | (Fbool_vector_intersection, Fbool_vector_set_difference) |
2457 | (Fbool_vector_subsetp, Fbool_vector_not) | |
3e0b94e7 DC |
2458 | (Fbool_vector_count_matches) |
2459 | (Fbool_vector_count_matches_at): New functions. | |
2460 | (syms_of_data): Intern new symbol, functions. | |
2461 | * alloc.c (bool_vector_payload_bytes): New function. | |
2462 | (Fmake_bool_vector): Instead of calling Fmake_vector, | |
2463 | which performs redundant initialization and argument checking, | |
2464 | just call allocate_vector ourselves. Make sure we clear any | |
2465 | terminating padding to zero. | |
ffb3f67a | 2466 | (vector_nbytes, sweep_vectors): Use bool_vector_payload_bytes |
3e0b94e7 DC |
2467 | instead of open-coding the size calculation. |
2468 | (vroundup_ct): New macro. | |
2469 | (vroundup): Assume argument >= 0; invoke vroundup_ct. | |
ffb3f67a | 2470 | * casetab.c (shuffle, set_identity): Change lint_assume to assume. |
328a8179 SM |
2471 | * composite.c (composition_gstring_put_cache): |
2472 | Change lint_assume to assume. | |
3e0b94e7 DC |
2473 | * conf_post.h (assume): New macro. |
2474 | (lint_assume): Remove. | |
2475 | * dispnew.c (update_frame_1): Change lint_assume to assume. | |
2476 | * ftfont.c (ftfont_shape_by_flt): Change lint_assume | |
2477 | to assume. | |
2478 | * image.c (gif_load): Change lint_assume to assume. | |
2479 | * lisp.h (eassert_and_assume): New macro. | |
2480 | (Qbool_vector_p): Declare. | |
ffb3f67a PE |
2481 | (CHECK_BOOL_VECTOR, ROUNDUP, BITS_PER_SIZE_T): New macros. |
2482 | (swap16, swap32, swap64): New inline functions. | |
3e0b94e7 DC |
2483 | * macfont.c (macfont_shape): Change lint_assume to assume. |
2484 | * ralloc.c: Rename ROUNDUP to PAGE_ROUNDUP throughout. | |
2485 | * xsettings.c (parse_settings): Use new swap16 and | |
2486 | swap32 from lisp.h instead of file-specific macros. | |
2487 | ||
76880d88 EZ |
2488 | 2013-09-22 Eli Zaretskii <eliz@gnu.org> |
2489 | ||
2490 | * xdisp.c (try_window_id): Don't abort if cursor row could not be | |
2491 | found (which can legitimately happen when the glyph row at the | |
2492 | window start is disabled in the current_matrix. (Bug#15365) | |
2493 | ||
c6cfd910 PE |
2494 | 2013-09-22 Paul Eggert <eggert@cs.ucla.edu> |
2495 | ||
2496 | Fix syntax.h bug introduced by recent INLINE change. | |
2497 | syntax.h defined an extern inline function SYNTAX_ENTRY that was | |
2498 | conditionally compiled one way in some modules, and a different | |
2499 | way in others. This doesn't work with extern inline functions, | |
2500 | which must have the same definition in all modules, because the | |
2501 | defining code might be shared across modules, depending on the | |
2502 | implementation. Symptoms reported by Martin Rudalics in: | |
2503 | http://lists.gnu.org/archive/html/emacs-devel/2013-09/msg00414.html | |
2504 | * regex.c, syntax.c (SYNTAX_ENTRY_VIA_PROPERTY): Remove. | |
2505 | (SYNTAX, SYNTAX_ENTRY, SYNTAX_WITH_FLAGS): New macros, | |
2506 | overriding the corresponding functions in syntax.h. | |
2507 | * syntax.h (syntax_property_entry, syntax_property_with_flags) | |
2508 | (syntax_property): New inline functions. | |
2509 | (SYNTAX_ENTRY, SYNTAX_WITH_FLAGS, SYNTAX): | |
2510 | Rewrite in terms of these new functions. | |
2511 | ||
b3f1d119 EZ |
2512 | 2013-09-21 Eli Zaretskii <eliz@gnu.org> |
2513 | ||
2514 | * dired.c (directory_files_internal): Use multibyte_chars_in_text, | |
2515 | not chars_in_text, whose result depends on the multibyteness of | |
2516 | the current buffer. (Bug#15426) | |
2517 | ||
00382e8b PE |
2518 | 2013-09-20 Paul Eggert <eggert@cs.ucla.edu> |
2519 | ||
e3b29769 PE |
2520 | Port recent change to hosts where pointers aren't 'long'. |
2521 | * xterm.c (x_send_scroll_bar_event, x_scroll_bar_to_input_event): | |
2522 | Don't assume that pointers are the same width as 'long'. | |
2523 | Add a compile-time check that a pointer fits into two X slots. | |
2524 | ||
00382e8b PE |
2525 | A simpler, centralized INLINE. |
2526 | * conf_post.h (INLINE): Define only if not already defined. | |
2527 | This allows us to use a single INLINE, defined by one file | |
2528 | per executable. | |
2529 | * emacs.c (INLINE): Define it. | |
2530 | Also, include category.h, charset.h, composite.h, dispextern.h, | |
2531 | syntax.h, systime.h, so that their INLINE definitions are expanded | |
2532 | properly for Emacs. | |
2533 | * blockinput.h, keyboard.c (BLOCKINPUT_INLINE): | |
2534 | * buffer.h, buffer.c (BUFFER_INLINE): | |
2535 | * category.h, category.c (CATEGORY_INLINE): | |
2536 | * character.h, character.c (CHARACTER_INLINE): | |
2537 | * charset.h, charset.c (CHARSET_INLINE): | |
2538 | * composite.h, composite.c (COMPOSITE_INLINE): | |
2539 | * dispextern.h, dispnew.c (DISPEXTERN_INLINE): | |
2540 | * frame.h, frame.c (FRAME_INLINE): | |
2541 | * intervals.h, intervals.c (INTERVALS_INLINE): | |
2542 | * keyboard.h, keyboard.c (KEYBOARD_INLINE): | |
2543 | * lisp.h, alloc.c (LISP_INLINE): | |
2544 | * process.h, process.c (PROCESS_INLINE): | |
2545 | * syntax.h, syntax.c (SYNTAX_INLINE): | |
2546 | * systime.h, sysdep.c (SYSTIME_INLINE): | |
2547 | * termhooks.h, terminal.h (TERMHOOKS_INLINE): | |
2548 | * window.h, window.c (WINDOW_INLINE): | |
2549 | Remove. All uses replaced with INLINE. | |
2550 | ||
2b943ba6 DA |
2551 | 2013-09-20 Dmitry Antipov <dmantipov@yandex.ru> |
2552 | ||
2553 | * xterm.c (handle_one_xevent): Revert part of 2013-09-17 change | |
2554 | to avoid Bug#15398. | |
2555 | ||
13d9698a EZ |
2556 | 2013-09-19 Eli Zaretskii <eliz@gnu.org> |
2557 | ||
2558 | * w32reg.c (w32_get_string_resource): Make the first 2 arguments | |
2559 | 'const char *' to avoid compiler warnings due to similar change in | |
2560 | the prototype of x_get_string_resource. | |
2561 | ||
ced135eb DA |
2562 | 2013-09-19 Dmitry Antipov <dmantipov@yandex.ru> |
2563 | ||
2564 | * xterm.h (struct x_display_info): New members last_mouse_glyph_frame, | |
2565 | last_mouse_scroll_bar, last_mouse_glyph and last_mouse_movement_time, | |
2566 | going to replace static variables below. Adjust comments. | |
2567 | * xterm.c (last_mouse_glyph, last_mouse_glyph_frame) | |
2568 | (last_mouse_scroll_bar, last_mouse_movement_time): Remove. | |
2569 | (note_mouse_movement, XTmouse_position, x_scroll_bar_note_movement) | |
2570 | (x_scroll_bar_report_motion, handle_one_xevent, syms_of_xterm): | |
2571 | Related users changed. | |
2572 | * w32term.h (struct w32_display_info): New members last_mouse_glyph_frame, | |
2573 | last_mouse_scroll_bar, last_mouse_scroll_bar_pos, last_mouse_glyph and | |
2574 | last_mouse_movement_time, going to replace static variables below. | |
2575 | Adjust comments. | |
2576 | * w32term.c (last_mouse_glyph_frame, last_mouse_scroll_bar) | |
2577 | (last_mouse_scroll_bar_pos, last_mouse_glyph, last_mouse_movement_time): | |
2578 | Remove. | |
2579 | (note_mouse_movement, w32_mouse_position, w32_scroll_bar_handle_click) | |
2580 | (x_scroll_bar_report_motion, syms_of_w32term): Related users changed. | |
2581 | * nsterm.h (struct ns_display_info): New members last_mouse_glyph, | |
2582 | last_mouse_movement_time and last_mouse_scroll_bar, going to replace | |
2583 | static variables below. | |
2584 | * nsterm.m (last_mouse_glyph, last_mouse_movement_time) | |
2585 | (last_mouse_scroll_bar): Remove. | |
2586 | (note_mouse_movement, ns_mouse_position, mouseMoved, mouseEntered) | |
2587 | (mouseExited): Related users changed. | |
2588 | ||
091f1e1f DA |
2589 | 2013-09-19 Dmitry Antipov <dmantipov@yandex.ru> |
2590 | ||
2591 | Do not use external array to process X scroll bar messages. | |
2592 | * xterm.c (scroll_bar_windows, scroll_bar_windows_size): Remove. | |
2593 | (x_send_scroll_bar_event): Pack window pointer into two slots | |
2594 | of XClientMessageEvent if we're 64-bit. Adjust comment. | |
2595 | (x_scroll_bar_to_input_event): Unpack accordingly. | |
2596 | ||
582ed56c DA |
2597 | 2013-09-18 Dmitry Antipov <dmantipov@yandex.ru> |
2598 | ||
2599 | Ifdef away recent changes which aren't relevant to NS port. | |
2600 | * dispextern.h (x_mouse_grabbed, x_redo_mouse_highlight) | |
2601 | [!HAVE_NS]: Declare as such. | |
2602 | * frame.c (x_mouse_grabbed, x_redo_mouse_highlight) | |
2603 | [!HAVE_NS]: Define as such. | |
2604 | ||
18da0d8a DA |
2605 | 2013-09-18 Dmitry Antipov <dmantipov@yandex.ru> |
2606 | ||
2607 | * frame.c (x_redo_mouse_highlight): New function | |
2608 | to factor out common code used in W32 and X ports. | |
2609 | * dispextern.h (x_redo_mouse_highlight): Add prototype. | |
2610 | * xterm.h (struct x_display_info): | |
2611 | * w32term.h (struct w32_display_info): | |
2612 | * nsterm.h (struct ns_display_info): New members | |
2613 | last_mouse_motion_frame, last_mouse_motion_x and | |
2614 | last_mouse_motion_y, going to replace static variables below. | |
2615 | * xterm.c (last_mouse_motion_event, last_mouse_motion_frame) | |
2616 | (redo_mouse_highlight): Remove. | |
2617 | (note_mouse_movement, syms_of_xterm): Adjust user. | |
2618 | (handle_one_xevent): Likewise. Use x_redo_mouse_highlight. | |
2619 | * w32term.c (last_mouse_motion_event, last_mouse_motion_frame) | |
2620 | (redo_mouse_highlight): Remove. | |
2621 | (note_mouse_movement, syms_of_w32term): Adjust user. | |
2622 | (w32_read_socket): Likewise. Use x_redo_mouse_highlight. | |
2623 | * nsterm.m (last_mouse_motion_position, last_mouse_motion_frame): | |
2624 | Remove. | |
2625 | (note_mouse_movement, mouseMoved, syms_of_nsterm): | |
2626 | * nsfns.m (compute_tip_xy): Adjust user. | |
2627 | ||
7a0c745a DA |
2628 | 2013-09-18 Dmitry Antipov <dmantipov@yandex.ru> |
2629 | ||
2630 | * frame.c (x_mouse_grabbed): New function. | |
2631 | * dispextern.h (x_mouse_grabbed): Add prototype. | |
2632 | (last_mouse_frame): Remove declaration. | |
2633 | * xterm.h (struct x_display_info): | |
2634 | * w32term.h (struct w32_display_info): | |
2635 | * nsterm.h (struct ns_display_info): New member | |
2636 | last_mouse_frame, going to replace... | |
2637 | * xdisp.c (last_mouse_frame): ...global variable. | |
2638 | (note_tool_bar_highlight): | |
2639 | * w32term.c (w32_mouse_position, w32_read_socket): | |
2640 | * xterm.c (XTmouse_position, handle_one_xevent): | |
2641 | Use x_mouse_grabbed. | |
2642 | * nsterm.m (ns_mouse_position, mouseDown): Adjust user. | |
2643 | ||
0791d107 DA |
2644 | 2013-09-17 Dmitry Antipov <dmantipov@yandex.ru> |
2645 | ||
2646 | * w32term.c (w32_read_socket): Avoid temporary | |
2647 | variables in a call to x_real_positions. | |
2648 | * xterm.c (handle_one_xevent): Likewise. | |
2649 | ||
2cd98812 DA |
2650 | 2013-09-17 Dmitry Antipov <dmantipov@yandex.ru> |
2651 | ||
2652 | * frame.h (x_set_bitmap_icon) [!HAVE_NS]: New function. | |
2653 | (x_icon_type): Remove prototype. | |
2654 | (x_bitmap_icon) [!HAVE_NS]: Declare as such. | |
2655 | * frame.c (x_icon_type): Remove. | |
2656 | * w32term.c (x_make_frame_visible, x_iconify_frame): | |
2657 | * xterm.c (x_make_frame_visible, x_iconify_frame): | |
2658 | Use x_set_bitmap_icon to factor out common code. | |
2659 | ||
a6c2ee1b DA |
2660 | 2013-09-17 Dmitry Antipov <dmantipov@yandex.ru> |
2661 | ||
2662 | * dispextern.h (check_x_display_info, x_get_string_resource): | |
2663 | Declare here just once and unify the latter. | |
2664 | * frame.c (check_x_display_info, x_get_string_resource): | |
2665 | * nsterm.h (check_x_display_info): | |
2666 | * xrdb.c (x_get_string_resource): | |
2667 | * xterm.h (check_x_display_info): Remove prototypes. | |
2668 | * nsfns.m (x_get_string_resource): Likewise. Adjust definition. | |
2669 | * w32reg.c (x_get_string_resource): Likewise. | |
2670 | (w32_get_rdb_resource): Adjust user. | |
2671 | ||
baed3603 DA |
2672 | 2013-09-17 Dmitry Antipov <dmantipov@yandex.ru> |
2673 | ||
2674 | * xterm.h (struct x_display_info): New member | |
2675 | x_pending_autoraise_frame, going to replace... | |
2676 | * xterm.c (pending_autoraise_frame): ...static variable. | |
2677 | (x_new_focus_frame, XTread_socket): Adjust users. | |
2678 | * w32term.h (struct w32_display_info): New member | |
2679 | w32_pending_autoraise_frame, going to replace... | |
2680 | * w32term.c (pending_autoraise_frame): ...global variable. | |
2681 | (x_new_focus_frame, w32_read_socket): Adjust users. | |
2682 | ||
90582f05 GM |
2683 | 2013-09-17 Glenn Morris <rgm@gnu.org> |
2684 | ||
2685 | * xdisp.c (message_dolog): If we create *Messages*, | |
2686 | switch it to messages-buffer-mode. | |
2687 | ||
b7ad2f74 PE |
2688 | 2013-09-17 Paul Eggert <eggert@cs.ucla.edu> |
2689 | ||
2690 | Don't overuse 'const' in types of locals. | |
2691 | * bidi.c (bidi_count_bytes): | |
2692 | * gtkutil.c, gtkutil.h (xg_event_is_for_menubar) | |
2693 | (xg_event_is_for_scrollbar): | |
2694 | * xselect.c (x_handle_property_notify) | |
2695 | (x_handle_selection_notify, x_handle_dnd_message): | |
2696 | * xsettings.c, xsettings.h (xft_settings_event): | |
2697 | * xterm.c (x_handle_net_wm_state, handle_one_event) | |
2698 | (x_menubar_window_to_frame, x_detect_focus_change) | |
2699 | (construct_mouse_click, note_mouse_movement) | |
2700 | (x_scroll_bar_to_input_event, x_scroll_bar_expose) | |
2701 | (x_scroll_bar_handle_click, x_scroll_bar_note_movement) | |
2702 | (handle_one_xevent, x_handle_net_wm_state): | |
2703 | * xterm.h (x_handle_property_notify, x_handle_selection_notify) | |
2704 | (x_handle_dnd_message): | |
2705 | Avoid unnecessary 'const', typically the second 'const' in | |
2706 | 'const foo * const arg', a 'const' that does not affect the API | |
2707 | and doesn't significantly help the human reader. | |
2708 | ||
19452b86 DA |
2709 | 2013-09-17 Dmitry Antipov <dmantipov@yandex.ru> |
2710 | ||
2711 | * image.c (fn_g_type_init) [WINDOWSNT]: Define and load | |
2712 | only if Glib < 2.36.0. | |
2713 | (fn_g_type_init) [!WINDOWSNT]: Define only if Glib < 2.36.0. | |
2714 | * xsettings.c (init_gconf, init_gsettings): Do not check | |
2715 | for g_type_init. | |
1893694e DA |
2716 | * xterm.c (handle_one_xevent): Do not call to x_clear_area |
2717 | if GTK >= 2.7.0. | |
33b83dd7 | 2718 | (toplevel) [USE_MOTIF]: Include xlwmenu.h to pacify GCC. |
19452b86 | 2719 | |
6434e343 JD |
2720 | 2013-09-16 Jan Djärv <jan.h.d@swipnet.se> |
2721 | ||
3f386383 JD |
2722 | * xsettings.c (init_gconf, init_gsettings): Check for Glib 2.36.0 |
2723 | before calling g_type_init. | |
2724 | ||
6434e343 JD |
2725 | * font.c (syms_of_font): Move call to syms_of_(ns|mac)font ... |
2726 | ||
2727 | * nsterm.m (syms_of_nsterm): ... to here. | |
2728 | ||
83a119f8 DA |
2729 | 2013-09-16 Dmitry Antipov <dmantipov@yandex.ru> |
2730 | ||
2731 | * xterm.c (toolkit_scroll_bar_interaction): Use bool for boolean. | |
2732 | (ignore_next_mouse_click_timeout): Use Time as X does. | |
2733 | (handle_one_xevent): Avoid cast and use unsigned comparison. | |
2734 | ||
61582e6a DA |
2735 | 2013-09-16 Dmitry Antipov <dmantipov@yandex.ru> |
2736 | ||
2737 | Do not copy X event in handle_one_xevent except KeyPress case. | |
2738 | Wnen XEvent is processed, it is unlikely to be changed except | |
2739 | KeyPress case, so we can avoid copying and use const pointer to | |
2740 | const data to make sure that an event is not changed elsewhere. | |
2741 | * xterm.c (handle_one_xevent): Change 2nd arg to 'const XEvent * | |
2742 | const' and do not create local copy except for the KeyPress event. | |
2743 | Use casts to avoid a few glitches. Adjust formatting. Add comments. | |
2744 | (SET_SAVED_BUTTON_EVENT): Remove and move the code to the only user. | |
2745 | (x_handle_net_wm_state, x_menubar_window_to_frame) | |
2746 | (x_detect_focus_change, construct_mouse_click, note_mouse_movement) | |
2747 | (x_scroll_bar_to_input_event, x_scroll_bar_expose) | |
2748 | (x_scroll_bar_handle_click, x_scroll_bar_note_movement): | |
2749 | * gtkutil.c (xg_event_is_for_menubar, xg_event_is_for_scrollbar): | |
2750 | * xselect.c (x_handle_property_notify, x_handle_selection_notify) | |
2751 | (x_handle_dnd_message): | |
2752 | * xsettings.c (xft_settings_event): | |
2753 | Use 'const XEvent * const' where appropriate. | |
2754 | * xterm.h, gtkutil.h, xsettngs.h: Adjust related prototypes. | |
2755 | ||
f8eb1572 DA |
2756 | 2013-09-16 Dmitry Antipov <dmantipov@yandex.ru> |
2757 | ||
2758 | Fix X event waiting to handle multiple frames. | |
2759 | * frame.h (struct frame) [HAVE_X_WINDOWS]: New member wait_event_type. | |
2760 | * xterm.c (pending_event_wait): Remove. Adjust users. | |
2761 | (x_detect_focus_change): Pass frame arg. | |
2762 | (handle_one_xevent): Find related frame early and clear per-frame | |
2763 | wait_event_type only if this is an event for the relevant frame. | |
2764 | (x_wait_for_event): Use per-frame wait_event_type. | |
2765 | ||
3fa2054e JD |
2766 | 2013-09-15 Jan Djärv <jan.h.d@swipnet.se> |
2767 | ||
745d3809 JD |
2768 | * nsfns.m (Fx_create_frame): Fix font driver registration for |
2769 | GNUStep. | |
2770 | ||
2771 | * font.c (syms_of_font): Check MAC_OS_X_VERSION_MAX_ALLOWED >= 1050 | |
2772 | for syms_of_macfont. | |
2773 | ||
3fa2054e JD |
2774 | * nsterm.m: Include macfont.h. |
2775 | (ns_tmp_flags, ns_tmp_font): Remove. | |
2776 | (ns_compute_glyph_string_overhangs): Check for driver Qns. | |
2777 | (ns_draw_glyph_string): Use local variables instead of ns_tmp_flags, | |
2778 | ns_tmp_font. Call ns_draw_text_decoration here instead of nsfont.m. | |
2779 | (changeFont:): Fix code style. Check for font driver type when | |
2780 | getiing font. | |
2781 | ||
2782 | * nsterm.h (FONT_DESCENT, FONT_ASCENT): Define to (f)->ascent and | |
2783 | (f)->descent. | |
2784 | ||
2785 | * nsfont.m (ns_tmp_flags, ns_tmp_font): Remove. | |
2786 | (nsfont_open): Set font driver type. | |
2787 | Set font->ascent and font->descent. Figure out font instead of | |
2788 | ns_tmp_font, and flags instead of ns_tmp_flags. | |
2789 | Fix indentation. Remove call to ns_draw_text_decoration, | |
2790 | moved to nsterm. | |
2791 | ||
2792 | * nsfns.m: Include macfont.h. | |
2793 | (Fx_create_frame): Register macfont driver, make a better default font. | |
2794 | (Fns_popup_font_panel): Get font from macfont driver, if used. | |
2795 | ||
2796 | * macfont.m, macfont.h, maccuvs.h: New files. | |
2797 | ||
2798 | * font.h: Declare syms_of_macfont. | |
2799 | ||
2800 | * font.c (syms_of_font): Call syms_of_macfont. | |
2801 | ||
2802 | * Makefile.in (NS_OBJ, SOME_MACHINE_OBJECTS): Add macfont.o. | |
2803 | ||
0eed0355 DA |
2804 | 2013-09-15 Dmitry Antipov <dmantipov@yandex.ru> |
2805 | ||
2806 | Drop VERTICAL_SCROLL_BAR_WIDTH_TRIM. For X, it is zero since 1999, | |
2807 | and it is always zero for others, so I assume that this is an ancient | |
2808 | leftover which nobody will want to change any more. | |
2809 | * xterm.h, w32term.h, nsterm.h (VERTICAL_SCROLL_BAR_WIDTH_TRIM): Remove. | |
2810 | (VERTICAL_SCROLL_BAR_INSIDE_WIDTH): | |
2811 | * frame.c (x_set_scroll_bar_width): | |
2812 | * w32fns.c (w32_createscrollbar): | |
2813 | * w32term.c (w32_set_vertical_scroll_bar): | |
2814 | * xfns.c (x_set_scroll_bar_default_width): | |
2815 | * xterm.c (XTflash, x_scroll_bar_create, XTset_vertical_scroll_bar) | |
2816 | (x_scroll_bar_expose): Related users changed. | |
2817 | ||
07013c68 DA |
2818 | 2013-09-15 Dmitry Antipov <dmantipov@yandex.ru> |
2819 | ||
2820 | * xterm.h (FRAME_X_SCREEN_NUMBER): Add comment. | |
2821 | (BLACK_PIX_DEFAULT, WHITE_PIX_DEFAULT): Use FRAME_X_SCREEN_NUMBER. | |
901049a6 DA |
2822 | (SCROLL_BAR_X_WIDGET, SET_SCROLL_BAR_X_WIDGET) [USE_X_TOOLKIT]: |
2823 | Define as such. | |
c7cc32f7 DA |
2824 | * frame.h (FRAME_SMALLEST_CHAR_WIDTH, FRAME_SMALLEST_FONT_HEIGHT): |
2825 | Define once here... | |
2826 | * nsterm.h, w32term.h, xterm.h: ...and not here. | |
901049a6 DA |
2827 | * w32term.h (SCROLL_BAR_X_WIDGET, SET_SCROLL_BAR_X_WIDGET): |
2828 | Remove unused Xisms. | |
7f09455e DA |
2829 | * xterm.c, xfns.c (toplevel): Remove #ifdef HAVE_X_WINDOWS because |
2830 | these modules are never compiled otherwise. | |
07013c68 | 2831 | |
0df00f59 EZ |
2832 | 2013-09-14 Eli Zaretskii <eliz@gnu.org> |
2833 | ||
08a209bf | 2834 | * buffer.c (syms_of_buffer) <left-margin-width, right-margin-width>: |
0df00f59 EZ |
2835 | Doc fix. (Bug#15375) |
2836 | ||
fcd42c11 DA |
2837 | 2013-09-13 Dmitry Antipov <dmantipov@yandex.ru> |
2838 | ||
2839 | Unify Fx_focus_frame between all ports. | |
2840 | * frame.h (x_focus_frame): New prototype. | |
2841 | * xfns.c (Fx_focus_frame): Remove. | |
2842 | (syms_of_xfns): Do not defsubr it. | |
2843 | (x_focus_frame): X implementation. | |
2844 | * nsfns.m (Fx_focus_frame): Remove. | |
2845 | (syms_of_nsfns): Do not defsubr it. | |
2846 | (x_focus_frame): NS implementation. | |
2847 | * w32term.c (Fx_focus_frame): Remove. | |
2848 | (x_focus_on_frame): Rename to... | |
2849 | (x_focus_frame): W32 implementation. | |
2850 | * w32term.h (x_focus_on_frame): Remove prototype. | |
2851 | * w32fns.c (Fx_focus_frame): Remove. | |
2852 | (syms_of_w32fns): Do not defsubr it. | |
2853 | * frame.c (Fx_focus_frame): Define here. | |
2854 | (syms_of_frame): Defsubr here. | |
2855 | * gtkutil.c (xg_tool_bar_callback): Use x_focus_frame. | |
2856 | ||
aad3612f DA |
2857 | 2013-09-13 Dmitry Antipov <dmantipov@yandex.ru> |
2858 | ||
2859 | Unify FRAME_window_system_DISPLAY_INFO macros between all ports. | |
2860 | All of them are replaced with FRAME_DISPLAY_INFO, defined in | |
2861 | each port to reference the port-specific window system data. | |
2862 | * msdos.h (FRAME_X_DISPLAY_INFO): Remove. | |
2863 | (FRAME_DISPLAY_INFO): Define. | |
2864 | * w32term.h (FRAME_W32_DISPLAY_INFO, FRAME_X_DISPLAY_INFO): Remove. | |
2865 | (FRAME_DISPLAY_INFO): Define. Adjust users. | |
2866 | * xterm.h (FRAME_X_DISPLAY_INFO): Remove. | |
2867 | (FRAME_DISPLAY_INFO): Define. Adjust users. | |
2868 | * frame.h (FRAME_RES_X, FRAME_RES_Y): Unify. | |
2869 | * font.c, frame.c, gtkutil.c, image.c, menu.c, msdos.c, nsfns.m: | |
2870 | * nsfont.m, nsterm.m, w32fns.c, w32font.c, w32menu.c, w32term.c: | |
2871 | * w32xfns.c, widget.c, xdisp.c, xfaces.c, xfns.c, xfont.c, xmenu.c: | |
2872 | * xselect.c, xterm.c: All related users changed. | |
2873 | ||
9a650e62 DA |
2874 | 2013-09-13 Dmitry Antipov <dmantipov@yandex.ru> |
2875 | ||
2876 | * xterm.h (x_window_to_frame, x_any_window_to_frame) | |
2877 | (x_menubar_window_to_frame): Remove prototypes. | |
2878 | * xfns.c (x_window_to_frame, x_any_window_to_frame) | |
2879 | (x_menubar_window_to_frame, x_top_window_to_frame): | |
2880 | Move from here... | |
2881 | * xterm.c (x_window_to_frame, x_any_window_to_frame) | |
2882 | (x_menubar_window_to_frame, x_top_window_to_frame): | |
2883 | ...to here and convert all but the last to static. | |
2884 | ||
347ae3e1 EZ |
2885 | 2013-09-12 Eli Zaretskii <eliz@gnu.org> |
2886 | ||
2887 | * lisp.mk (lisp): Add w32-common-fns.elc. | |
2888 | ||
15c6d837 XF |
2889 | 2013-09-12 Xue Fuqiao <xfq.free@gmail.com> |
2890 | ||
2891 | * charset.c (char_charset): Document an exception for char-charset. | |
2892 | ||
27e90f77 DA |
2893 | 2013-09-12 Dmitry Antipov <dmantipov@yandex.ru> |
2894 | ||
2895 | * xterm.h (x_display_info): New field last_user_time... | |
2896 | * xterm.c (toplevel): ...to replace static last_user_time. | |
2897 | (handle_one_xevent, x_ewmh_activate_frame): Adjust users. | |
2898 | ||
8ffbc36b DA |
2899 | 2013-09-12 Dmitry Antipov <dmantipov@yandex.ru> |
2900 | ||
2901 | * xterm.c (x_set_scroll_bar_thumb) [USE_LUCID && !HAVE_XAW3D]: Clip | |
2902 | scroll bar values to prevent thumb from disappear and update comment. | |
2903 | ||
5ec0337a GM |
2904 | 2013-09-11 Glenn Morris <rgm@gnu.org> |
2905 | ||
2906 | * emacs.c (usage_message): Possessive apostrophe tweak. | |
2907 | ||
fb55b9d1 DA |
2908 | 2013-09-11 Dmitry Antipov <dmantipov@yandex.ru> |
2909 | ||
8d2db8be DA |
2910 | * nsterm.m (syms_of_nsterm): Use Qns. |
2911 | * w32fns.c (Fx_open_connection): Remove old '#if 0' code. | |
2912 | * w32term.c (w32_create_terminal, syms_of_w32term): Use Qw32. | |
2913 | * xfns.c (x_display_info_for_name, Fx_open_connection): | |
2914 | Remove old '#if 0' code. | |
2915 | (syms_of_xfns): Use Qx. | |
fb55b9d1 DA |
2916 | * termhooks.h (fullscreen_hook): Remove the leftover. |
2917 | (struct terminal): Fix typo in comment. | |
2918 | ||
927eec55 DA |
2919 | 2013-09-11 Dmitry Antipov <dmantipov@yandex.ru> |
2920 | ||
2921 | Cleaning up a few X scroll bar bits. | |
2922 | * termhooks.h (enum scroll_bar_part): Add scroll_bar_nowhere member. | |
2923 | * xterm.h (struct scroll_bar) [USE_TOOLKIT_SCROLL_BARS && USE_LUCID]: | |
2924 | New member last_seen_part, going to replace... | |
2925 | * xterm.c [USE_TOOLKIT_SCROLL_BARS]: ...global last_scroll_bar_part. | |
2926 | (xt_action_hook) [USE_LUCID]: Adjust user. | |
2927 | (xm_scroll_callback, xg_scroll_callback): Do not bloat with | |
2928 | Lucid-specific scroll bar support. | |
2929 | (xaw_jump_callback, xaw_scroll_callback): Prefer enum scroll_par_part | |
2930 | to int and adjust to use last_seen_part member. | |
2931 | (x_set_toolkit_scroll_bar_thumb) [USE_LUCID]: Adjust user. | |
2932 | (x_scroll_bar_create) [USE_TOOLKIT_SCROLL_BARS && USE_LUCID]: | |
2933 | Initialize last_seen_part. | |
2934 | ||
71b28baa SM |
2935 | 2013-09-11 Stefan Monnier <monnier@iro.umontreal.ca> |
2936 | ||
2937 | * insdel.c (insert_from_buffer_1): Don't mark buffer as modified when | |
2938 | insert-buffer-substring an empty string. | |
2939 | ||
f5dacaae PE |
2940 | 2013-09-11 Paul Eggert <eggert@cs.ucla.edu> |
2941 | ||
2942 | * xdisp.c (Ftool_bar_lines_needed): Declare as 'const' if ifdeffed out, | |
2943 | avoiding a GCC warning. | |
2944 | ||
742516e0 DA |
2945 | 2013-09-11 Dmitry Antipov <dmantipov@yandex.ru> |
2946 | ||
2947 | Ifdef away frame tool bar code when it is not really used. | |
2948 | * frame.h (struct frame) [HAVE_WINDOW_SYSTEM && !USE_GTK && !HAVE_NS]: | |
2949 | Move tool_bar_window, desired_tool_bar_string, current_tool_bar_string | |
2950 | and minimize_tool_bar_window_p under the above. | |
2951 | (fset_current_tool_bar_string, fset_desired_tool_bar_string) | |
2952 | (fset_tool_bar_window): Likewise. | |
2953 | * dispnew.c (clear_current_matrices, clear_desired_matrices) | |
2954 | (adjust_frame_glyphs_for_window_redisplay, free_glyphs, update_frame) | |
2955 | (change_frame_size_1): | |
2956 | * window.c (window_from_coordinates, Frecenter): Adjust users. | |
2957 | * window.h (WINDOW_TOOL_BAR_P): Define to zero when frame tool bar | |
2958 | code is not really used. | |
2959 | * xdisp.c (build_desired_tool_bar_string, display_tool_bar_line) | |
2960 | (tool_bar_lines_needed, MAX_FRAME_TOOL_BAR_HEIGHT, tool_bar_item_info) | |
2961 | (get_tool_bar_item, handle_tool_bar_click, note_tool_bar_highlight) | |
2962 | [!USE_GTK && !HAVE_NS]: Define as such. | |
2963 | (Ftool_bar_lines_needed, redisplay_tool_bar, show_mouse_face) | |
2964 | (note_mouse_highlight, expose_frame): | |
2965 | * xfns.c (x_set_tool_bar_lines): | |
2966 | * xterm.c (handle_one_xevent): Adjust users. | |
2967 | ||
73f82c7e PE |
2968 | 2013-09-11 Paul Eggert <eggert@cs.ucla.edu> |
2969 | ||
2970 | Fix corruption with multiple emacsclient -t instances (Bug#15222). | |
2971 | This bug was introduced by my 2013-08-26 patch, which incorrectly | |
2972 | assumed that the terminfo implementation doesn't use termcap buffers. | |
2973 | * term.c (init_tty) [TERMINFO]: Remove optimization, as | |
2974 | these buffers apparently are used after all. | |
2975 | * termchar.h (TERMCAP_BUFFER_SIZE) [TERMINFO]: Define here too. | |
2976 | (struct tty_display_info): Define members termcap_term_buffer and | |
2977 | termcap_strings_buffer even if TERMINFO. | |
2978 | ||
53482f41 DA |
2979 | 2013-09-11 Dmitry Antipov <dmantipov@yandex.ru> |
2980 | ||
2981 | Fix last change. | |
2982 | * data.c (Feqlsign, Flss, Fgtr, Fleq, Fgeq): Add convenient | |
2983 | 'usage' docstring entry to pacify make-docfile. | |
2984 | ||
2985 | 2013-09-11 Barry O'Reilly <gundaetiapo@gmail.com> | |
2986 | ||
2987 | Change comparison functions =, <, >, <=, >= to take many arguments. | |
2988 | * data.c: Change comparison functions' interface and implementation. | |
2989 | * lisp.h: Make arithcompare available for efficient two arg | |
2990 | comparisons. | |
2991 | * bytecode.c: Use arithcompare. | |
2992 | * fileio.c: Use new interface. | |
2993 | ||
533f258f SM |
2994 | 2013-09-11 Stefan Monnier <monnier@iro.umontreal.ca> |
2995 | ||
2996 | * keyboard.c (read_char): Don't break immediate_echo (bug#15332). | |
2997 | ||
8c27f5ff SM |
2998 | 2013-09-10 Stefan Monnier <monnier@iro.umontreal.ca> |
2999 | ||
3000 | * eval.c (Feval): Document the new use of `lexical'. | |
3001 | ||
0750a308 DA |
3002 | 2013-09-09 Dmitry Antipov <dmantipov@yandex.ru> |
3003 | ||
3004 | Review and drop old frame resize hack. | |
3005 | * frame.h (struct frame): Remove force_flush_display_p. | |
3006 | * dispnew.c (update_frame): Adjust user and don't call | |
3007 | flush_frame here. The comment has said that there was an issues | |
3008 | with redisplaying fringes, but I don't see any differences with | |
3009 | and without this hack. Hopefully we can continue without it. | |
3010 | * xdisp.c (clear_garbaged_frames): Adjust user and do not clear | |
3011 | current frame matrices twice if resized_p is set. | |
3012 | ||
83fc0554 DA |
3013 | 2013-09-09 Dmitry Antipov <dmantipov@yandex.ru> |
3014 | ||
3015 | Do not populate pure Xism x_sync to other ports. | |
3016 | * frame.h (x_sync): Move under HAVE_X_WINDOWS. | |
3017 | * frame.c (other_visible_frames) [HAVE_X_WINDOWS]: Use as such. | |
3018 | * nsfns.m, w32xfns.c (x_sync): Remove no-op. | |
3019 | * w32term.h (x_sync): Remove prototype. | |
3020 | ||
fd462129 DA |
3021 | 2013-09-09 Dmitry Antipov <dmantipov@yandex.ru> |
3022 | ||
3023 | Cleanup frame flushing. | |
8c27f5ff SM |
3024 | * dispextern.h (struct redisplay_interface): |
3025 | Drop flush_display_optional because flush_display is enough | |
fd462129 DA |
3026 | for X and flushing via RIF is just a no-op for others. |
3027 | * frame.h (flush_frame): New function. | |
3028 | * dispnew.c (update_frame): | |
3029 | * minibuf.c (read_minibuf): | |
3030 | * xdisp.c (echo_area_display, redisplay_preserve_echo_area): | |
3031 | Use it. | |
3032 | * keyboard.c (detect_input_pending_run_timers): Do not flush | |
3033 | all frames but selected one in redisplay_preserve_echo_area. | |
3034 | * nsterm.m (ns_flush): Remove no-op. | |
3035 | (ns_redisplay_interface): Adjust user. | |
3036 | * w32term.h (x_flush): Remove no-op. | |
3037 | (w32_redisplay_interface): Adjust user. | |
3038 | * xterm.c (x_flush): Simplify because we do not flush all | |
3039 | frames at once any more. Adjust comment. | |
3040 | (x_redisplay_interface): Adjust user. | |
3041 | ||
4b73fc73 PE |
3042 | 2013-09-07 Paul Eggert <eggert@cs.ucla.edu> |
3043 | ||
3044 | Port --without-x --enable-gcc-warnings to Fedora 19. | |
3045 | * gfilenotify.c (globals_of_gfilenotify): | |
3046 | Call g_type_init only if using an older glib version that needs it. | |
3047 | ||
77394d40 DA |
3048 | 2013-09-06 Dmitry Antipov <dmantipov@yandex.ru> |
3049 | ||
3050 | * lisp.h (last_glyphless_glyph_frame, last_glyphless_glyph_face_id) | |
3051 | (last_glyphless_glyph_merged_face_id): Remove declarations. | |
3052 | * dispextern.h (merge_glyphless_glyph_face): Add prototype. | |
3053 | * xdisp.c (last_glyphless_glyph_frame, last_glyphless_glyph_face_id) | |
3054 | (last_glyphless_glyph_merged_face_id): Now static. | |
3055 | (merge_escape_glyph_face): New function, refactored from... | |
3056 | (get_next_display_element): ...here. | |
3057 | (merge_glyphless_glyph_face): New function, refactored from... | |
3058 | (produce_glyphless_glyph): ...here... | |
3059 | * term.c (produce_glyphless_glyph): ...and here. | |
3060 | ||
306d67bd SM |
3061 | 2013-09-06 Stefan Monnier <monnier@iro.umontreal.ca> |
3062 | ||
3063 | * eval.c (eval_sub): Only call Ffunction if necessary. | |
3064 | ||
7f6c6450 DA |
3065 | 2013-09-06 Dmitry Antipov <dmantipov@yandex.ru> |
3066 | ||
3067 | Attempt to make redisplay more selective when changing cursor type. | |
3068 | * frame.h (struct frame): New bitfield cursor_type_changed. | |
3069 | * xdisp.c (cursor_type_changed): Remove. | |
3070 | (try_cursor_movement, redisplay_window, try_window_id) | |
3071 | (set_frame_cursor_types, try_window_reusing_current_matrix): | |
3072 | Adjust to use per-frame bitfield. | |
3073 | (redisplay_internal): Look for cursor type change on each visible | |
3074 | frame and consider all frames if cursor type has been changed on | |
3075 | the frame other than selected. If cursor type has been changed on | |
3076 | selected frame only, do not use fast update. | |
3077 | ||
bd0443bb DA |
3078 | 2013-09-06 Dmitry Antipov <dmantipov@yandex.ru> |
3079 | ||
3080 | Attempt to make redisplay more selective when changing fonts. | |
3081 | * frame.h (struct frame): New bitfield fonts_changed. | |
3082 | * dispextern.h (fonts_changed_p, adjust_glyphs): Remove declaration. | |
3083 | (adjust_frame_glyphs): Add prototype. | |
3084 | * dispnew.c (fonts_changed_p): Remove. | |
8bda01d3 | 3085 | (adjust_glyphs): Remove because we do not |
bd0443bb DA |
3086 | adjust matrices on all frames at once any more. |
3087 | (adjust_frame_glyphs): Block and unblock input here. | |
3088 | (adjust_glyph_matrix): Use fonts_changed. | |
3089 | (change_frame_size_1): Use adjust_frame_glyphs. | |
3090 | * font.c (font_open_entity): Use fonts_changed. | |
3091 | * frame.c (set_menu_bar_lines, Fmake_terminal_frame): | |
3092 | * w32fns.c (x_set_menu_bar_lines, x_set_tool_bar_lines, Fx_show_tip): | |
3093 | * window.c (Fdelete_other_windows_internal, Fwindow_resize_apply) | |
3094 | (Fsplit_window_internal, Fdelete_window_internal, grow_mini_window) | |
3095 | (shrink_mini_window, Fresize_mini_window_internal) | |
3096 | (window_scroll_pixel_based, Fset_window_configuration) | |
3097 | (apply_window_adjustment, Fset_window_vscroll): | |
3098 | * xfns.c (x_set_menu_bar_lines, x_set_tool_bar_lines, Fx_show_tip): | |
3099 | Use adjust_frame_glyphs. | |
3100 | * xdisp.c (redisplay_tool_bar, redisplay_window, try_window) | |
3101 | (try_window_reusing_current_matrix, try_window_id, display_line) | |
3102 | (IT_EXPAND_MATRIX_WIDTH): Use fonts_changed. | |
3103 | (redisplay_internal): Consider fonts_changed and adjust frame | |
3104 | matrices for each frame only if the frame is visible. If font | |
3105 | has been changed on some frame during full redisplay, retry | |
3106 | only visible frames where the font has been actually changed. | |
3107 | ||
b9695828 DA |
3108 | 2013-09-05 Dmitry Antipov <dmantipov@yandex.ru> |
3109 | ||
3110 | Cache current header and mode line height for each window. | |
3111 | * window.h (struct window): New fields mode_line_height | |
3112 | and header_line_height. | |
3113 | * window.c (make_window): Initialize them. | |
3114 | * dispextern.h (CURRENT_MODE_LINE_HEIGHT) | |
3115 | (CURRENT_HEADER_LINE_HEIGHT): Use them. Adjust comment. | |
3116 | (current_mode_line_height, current_header_line_height): | |
3117 | Remove declaration. | |
3118 | * xdisp.c (current_mode_line_height, current_header_line_height): | |
3119 | Remove. | |
3120 | (pos_visible_p, init_xdisp): Adjust user. | |
3121 | (redisplay_window): Invalidate mode_line_height and | |
3122 | header_line_height if current and desired matrices do not agree. | |
3123 | ||
66738305 DA |
3124 | 2013-09-05 Dmitry Antipov <dmantipov@yandex.ru> |
3125 | ||
3126 | * fontset.c, window.c, xdisp.c (toplevel): Use TERM_HEADER. | |
3127 | * xfaces.c (toplevel) [HAVE_X_WINDOWS]: Do not include xterm.h twice. | |
3128 | ||
257b3b03 DA |
3129 | 2013-09-05 Dmitry Antipov <dmantipov@yandex.ru> |
3130 | ||
3131 | Make --without-x compatible with --enable-gcc-warnings. | |
3132 | * font.c (register_font_driver): Move check under HAVE_WINDOW_SYSTEM. | |
3133 | * font.h (struct font_driver): Move draw, get_bitmap and free_bitmap | |
3134 | members under HAVE_WINDOW_SYSTEM. | |
3135 | * keyboard.c (make_lispy_focus_out): Likewise. | |
3136 | (record_menu_key): Move under HAVE_MENUS. | |
3137 | * xdisp.c (toplevel): Move hourglass_shown_p, hourglass_atimer and | |
3138 | THIN_SPACE_WIDTH under HAVE_WINDOW_SYSTEM. | |
3139 | (syms_of_xdisp): Adjust user. | |
3140 | (window_box_edges): Define only if HAVE_WINDOW_SYSTEM. | |
3141 | (start_hourglass, cancel_hourglass): | |
3142 | * xfaces.c (toplevel): Likewise with PT_PER_INCH, | |
3143 | clear_font_table_count, CLEAR_FONT_TABLE_COUNT | |
3144 | and CLEAR_FONT_TABLE_NFONTS. | |
3145 | (set_font_frame_param, clear_face_gcs, realize_non_ascii_face): | |
3146 | Declare only if HAVE_WINDOW_SYSTEM. | |
3147 | (lface_same_font_attributes_p, clear_face_gcs): Define only | |
3148 | if HAVE_WINDOW_SYSTEM. | |
3149 | ||
98b7f4bd DA |
3150 | 2013-09-05 Dmitry Antipov <dmantipov@yandex.ru> |
3151 | ||
3152 | * frame.c (check_minibuf_window): Update 'frame' with frame pointer. | |
3153 | * xterm.c (x_scroll_bar_handle_click) [!USE_TOOLKIT_SCROLL_BARS]: | |
3154 | Don't pass C integer to XINT (tiny fix for 2013-09-03 change). | |
3155 | ||
a7e43722 SM |
3156 | 2013-09-05 Stefan Monnier <monnier@iro.umontreal.ca> |
3157 | ||
3158 | * cmds.c (Fself_insert_command): Don't pass a non-integer to XINT. | |
3159 | ||
0c90b9ee PE |
3160 | 2013-09-04 Paul Eggert <eggert@cs.ucla.edu> |
3161 | ||
3162 | * alloc.c (make_event_array): First arg is now ptrdiff_t, not int. | |
3163 | This fixes a type error on hosts where ptrdiff_t is wider than int. | |
3164 | ||
d99760fa SM |
3165 | 2013-09-04 Stefan Monnier <monnier@iro.umontreal.ca> |
3166 | ||
6629638e SM |
3167 | * keyboard.c (read_key_sequence_vs): New function. |
3168 | (Fread_key_sequence_vector, Fread_key_sequence): Use it to factor out | |
3169 | common code. | |
3170 | ||
d99760fa SM |
3171 | * callint.c (Fcall_interactively): Always return a vector for 'K'. |
3172 | ||
224e313d PE |
3173 | 2013-09-04 Paul Eggert <eggert@cs.ucla.edu> |
3174 | ||
3175 | Makefile improvements. | |
3176 | * Makefile.in (config.status): Don't use double-colon rules, as | |
3177 | they are not portable according to POSIX. Fix shell typo with `; | |
3178 | I guess this rule has never been tested? | |
3179 | (VCSWITNESS): New macro, to override any environment var. | |
3180 | ||
6d6ed1af DA |
3181 | 2013-09-04 Dmitry Antipov <dmantipov@yandex.ru> |
3182 | ||
3183 | * xterm.h (struct x_display_info): Do not track X connection | |
3184 | fd separately because it is always available from Display. | |
3185 | * xterm.c (x_term_init, x_delete_terminal, x_delete_display): | |
3186 | Adjust users. | |
3187 | ||
bc923770 DA |
3188 | 2013-09-03 Dmitry Antipov <dmantipov@yandex.ru> |
3189 | ||
3190 | * buffer.c (drop_overlay): | |
3191 | * fileio.c (restore_point_unwind): Prefer unchain_marker to | |
3192 | Fset_marker (X, Qnil, ...) (which is the same but a bit slower). | |
3193 | ||
b1cf96de DA |
3194 | 2013-09-03 Dmitry Antipov <dmantipov@yandex.ru> |
3195 | ||
3196 | * buffer.c (Fmake_overlay, Fmove_overlay): | |
3197 | * intervals.c (set_point_from_marker): | |
3198 | * print.c (PRINTPREPARE): Prefer signal_error | |
3199 | to plain error and report unsuitable marker too. | |
3200 | ||
d1fc6c21 DA |
3201 | 2013-09-03 Dmitry Antipov <dmantipov@yandex.ru> |
3202 | ||
3203 | * xterm.h (struct scroll_bar): Prefer int to Lisp_Object | |
3204 | for 'dragging' member. | |
d1ae6a0b DA |
3205 | (struct x_output): Remove set-but-unused leftovers |
3206 | 'left_before_move' and 'top_before_move'. | |
d1fc6c21 DA |
3207 | * gtkutil.c (xg_set_toolkit_scroll_bar_thumb): |
3208 | * xterm.c (xt_action_hook, xm_scroll_callback, xg_scroll_callback) | |
3209 | (xg_end_scroll_callback, xaw_jump_callback, xaw_scroll_callback) | |
3210 | (x_set_toolkit_scroll_bar_thumb, x_scroll_bar_create) | |
3211 | (x_scroll_bar_set_handle, XTset_vertical_scroll_bar) | |
3212 | (x_scroll_bar_handle_click, x_scroll_bar_note_movement) | |
d1ae6a0b | 3213 | (x_scroll_bar_report_motion, x_set_offset): Related users changed. |
ec5e7504 | 3214 | * xfns.c, image.c (XLIB_ILLEGAL_ACCESS): No longer needed. |
d1fc6c21 | 3215 | |
0ce9f6de JD |
3216 | 2013-09-03 Jan Djärv <jan.h.d@swipnet.se> |
3217 | ||
3218 | * nsfont.m (INVALID_GLYPH): New define. | |
3219 | (nsfont_encode_char): Use INVALID_GLYPH. | |
3220 | (ns_uni_to_glyphs): Ditto, check for NSNullGlyph (Bug#15138). | |
3221 | ||
b594a96c DA |
3222 | 2013-09-02 Dmitry Antipov <dmantipov@yandex.ru> |
3223 | ||
3224 | * xterm.c (x_last_mouse_movement_time): Revert last change. | |
3225 | This code should use XDisplayMotionBufferSize to check display's | |
3226 | motion history first, and there are few other issues as well. | |
3227 | (x_scroll_bar_note_movement): Pass XMotionEvent rather than XEvent. | |
3228 | (handle_one_xevent): Adjust user. | |
3229 | ||
8b098236 MR |
3230 | 2013-09-02 Martin Rudalics <rudalics@gmx.at> |
3231 | ||
9718b207 MR |
3232 | * dispnew.c (Flast_nonminibuf_frame): Move from here ... |
3233 | * frame.c (Flast_nonminibuf_frame): ... to here. | |
3234 | (check_minibuf_window): Don't abort if no window was found | |
3235 | (Bug#15247). | |
8b098236 | 3236 | |
84e70bba DA |
3237 | 2013-09-02 Dmitry Antipov <dmantipov@yandex.ru> |
3238 | ||
3239 | Use XGetMotionEvents to ask the last mouse motion time from X server. | |
3240 | * xterm.c (X_MOTION_HISTORY): Default to 1. | |
3241 | (x_last_mouse_movement_time) [X_MOTION_HISTORY]: New function. | |
3242 | (x_last_mouse_movement_time) [!X_MOTION_HISTORY]: Legacy version. | |
3243 | (note_mouse_movement, x_scroll_bar_note_movement) [!X_MOTION_HISTORY]: | |
3244 | Ifdef away legacy code. | |
3245 | (XTmouse_position, x_scroll_bar_report_motion): | |
3246 | Use x_last_mouse_movement_time. | |
fc85e20b DA |
3247 | (handle_one_xevent): Use event.xunmap and not event.xmap when handling |
3248 | UnmapNotify event. | |
84e70bba | 3249 | |
1fccc530 DA |
3250 | 2013-09-02 Dmitry Antipov <dmantipov@yandex.ru> |
3251 | ||
3252 | * msdos.c (last_mouse_window): Move to... | |
3253 | (dos_rawgetc): ...this function and adjust comment. | |
3254 | * nsterm.m (last_window): Rename to last_mouse_window, move to... | |
3255 | (mouseMoved): ...this function and adjust comment. | |
3256 | * w32term.c (last_window): Likewise with... | |
3257 | (w32_read_socket): ...this function. | |
3258 | * xterm.c (last_window): Likewise with... | |
3259 | (handle_one_xevent): ...this function. | |
3260 | ||
0ab10992 DA |
3261 | 2013-09-02 Dmitry Antipov <dmantipov@yandex.ru> |
3262 | ||
b7da754d | 3263 | * window.h (Vmouse_window, Vmouse_event): Remove the leftovers. |
0ab10992 DA |
3264 | * xterm.c (toplevel): Drop obsolete comment and move compose_status... |
3265 | (handle_one_xevent): ...to here. | |
3266 | (STORE_KEYSYM_FOR_DEBUG): Move under ENABLE_CHECKING and make no-op | |
3267 | otherwise. | |
3268 | ||
0c7f856e DA |
3269 | 2013-09-02 Dmitry Antipov <dmantipov@yandex.ru> |
3270 | ||
3271 | * msdos.c (IT_set_terminal_window): Remove no-op. | |
3272 | (initialize_msdos_display): Adjust terminal setup. | |
3273 | * w32console.c (w32con_set_terminal_window): Remove no-op. | |
3274 | (initialize_w32_display): Adjust terminal setup. | |
3275 | * w32term.c (w32_set_terminal_window): Remove no-op. | |
3276 | (w32_create_terminal): Adjust terminal setup. | |
3277 | * xterm.c (XTset_terminal_window): Remove no-op. | |
3278 | (x_create_terminal): Adjust terminal setup. | |
3279 | ||
a892a94c DA |
3280 | 2013-09-01 Dmitry Antipov <dmantipov@yandex.ru> |
3281 | ||
3282 | * nsterm.m (ns_set_terminal_modes, ns_reset_terminal_modes): | |
3283 | Remove no-ops. | |
3284 | (ns_create_terminal): Adjust terminal setup. | |
3285 | * w32term.c (w32_set_terminal_modes, w32_reset_terminal_modes): | |
3286 | Remove no-ops. | |
3287 | (w32_create_terminal): Adjust terminal setup. | |
3288 | * xterm.c (XTset_terminal_modes, XTreset_terminal_modes): | |
3289 | Remove no-ops. | |
3290 | (x_create_terminal): Adjust terminal setup. | |
3291 | ||
cf91889a DA |
3292 | 2013-09-01 Dmitry Antipov <dmantipov@yandex.ru> |
3293 | ||
3294 | * dispextern.h (SET_TEXT_POS_FROM_MARKER): Indent. | |
3295 | (CLIP_TEXT_POS_FROM_MARKER): New macro. | |
3296 | * dispnew.c (buffer_posn_from_coords): | |
3297 | * window.c (Fwindow_end, displayed_window_lines): | |
3298 | * xdisp.c (redisplay_mode_lines): Use it. | |
3299 | ||
5b0891df JD |
3300 | 2013-09-01 Jan Djärv <jan.h.d@swipnet.se> |
3301 | ||
3302 | * fontset.c (face_for_char): Check char in the current face font first | |
3303 | if HAVE_NS (Bug#15138). | |
3304 | ||
0a357e98 MR |
3305 | 2013-08-31 Martin Rudalics <rudalics@gmx.at> |
3306 | ||
3307 | * window.c (temp_output_buffer_show): Make sure window returned | |
3308 | by display_buffer is live (Bug#15213). | |
3309 | ||
9d7693d7 DA |
3310 | 2013-08-30 Dmitry Antipov <dmantipov@yandex.ru> |
3311 | ||
3312 | Minor cleanup to avoid forward declarations. | |
3313 | * coding.h (struct ccl_spec): Remove forward declaration. | |
3314 | * composite.h (toplevel): Include font.h. | |
3315 | (struct composition_it, struct face, struct font_metrics): | |
3316 | Remove forward declaration. | |
3317 | * dispextern.h (struct image, struct atimer): Likewise. | |
3318 | * emacsgtkfixed.h (struct frame): Likewise. | |
3319 | * emacsgtkfixed.c (toplevel): Reorder headers and drop stdio.h. | |
3320 | * font.h (struct font_driver, struct font, struct glyph_string) | |
3321 | (struct face): Remove forward declaration. | |
3322 | * fontset.h (struct face, struct font): Likewise. | |
3323 | * frame.h (toplevel): Style cleanup. | |
3324 | (enum output_method): Move to... | |
3325 | * termhooks.h (enum output_method): ...here. | |
3326 | (struct glyph, struct frame, struct ns_display_info) | |
3327 | (struct x_display_info, struct w32_display_info): | |
3328 | Remove forward declaration. | |
3329 | * xterm.h (toplevel): Include termhooks.h. | |
3330 | (struct font, struct window, struct glyph_matrix, struct frame) | |
3331 | (struct input_event, struct face, struct image): Remove forward | |
3332 | declaration. | |
3333 | * gtkutil.h (struct _widget_value): Likewise. | |
3334 | * keyboard.h (toplevel): Include termhooks.h. | |
3335 | (struct input_event): Remove forward declaration. | |
3336 | ||
032f7451 DA |
3337 | 2013-08-29 Dmitry Antipov <dmantipov@yandex.ru> |
3338 | ||
3339 | * intervals.c (set_point_from_marker): New function. | |
3340 | * editfns.c (Fgoto_char): | |
3341 | * process.c (Finternal_default_process_filter): | |
3342 | * window.c (select_window_1): Use it. | |
3343 | * buffer.h (set_point_from_marker): Add prototype. | |
3344 | ||
3f940c5a EZ |
3345 | 2013-08-29 Eli Zaretskii <eliz@gnu.org> |
3346 | ||
3347 | * w32.c (term_winsock): Call release_listen_threads before calling | |
3348 | WSACleanup. | |
3349 | (_sys_wait_accept): Wait for accept event in a loop with a finite | |
3350 | timeout, instead of waiting indefinitely. Will hopefully avoid | |
3351 | hanging during exit because WSACleanup deadlocks waiting for the | |
3352 | event object to be released. (Bug#14333) | |
3353 | ||
3354 | * w32proc.c (release_listen_threads): New function, signals all | |
3355 | the reader threads that listen for connections to stop waiting. | |
3356 | ||
3357 | * w32.h (release_listen_threads): Add prototype. | |
3358 | ||
101ed2bb DA |
3359 | 2013-08-29 Dmitry Antipov <dmantipov@yandex.ru> |
3360 | ||
3361 | * alloc.c (Fmake_marker, build_marker): Zero need_adjustment | |
3362 | field of new marker (for sanity and safety). | |
20de2834 DA |
3363 | * lisp.h (XSETMARKER): Remove unused macro (it doesn't work |
3364 | anyway because XMISCTYPE is a function and can't be an lvalue). | |
101ed2bb | 3365 | |
1f5cf200 DA |
3366 | 2013-08-29 Dmitry Antipov <dmantipov@yandex.ru> |
3367 | ||
3368 | * xterm.c (x_clear_area): Lost 7th arg because it is always False. | |
3369 | (x_after_update_window_line, x_scroll_bar_create): | |
3370 | (x_scroll_bar_set_handle, XTset_vertical_scroll_bar): | |
3371 | (handle_one_xevent, x_clear_frame_area): | |
3372 | * gtkutil.c (xg_clear_under_internal_border, xg_update_scrollbar_pos): | |
3373 | * xfns.c (x_set_menu_bar_lines, x_set_tool_bar_lines): Adjust users. | |
3374 | * xterm.h (x_clear_area): Adjust prototype. | |
3375 | ||
d2b36813 DA |
3376 | 2013-08-29 Dmitry Antipov <dmantipov@yandex.ru> |
3377 | ||
3378 | Hook scanning and indentation functions to find_newline. This helps | |
3379 | to avoid duplicated code and renders more respect to newline cache. | |
3380 | * lisp.h (scan_newline): Prefer ptrdiff_t to EMACS_INT. | |
3381 | * cmds.c (Fforward_line): | |
3382 | * indent.c (scan_for_column, Fcurrent_indentation, indented_beyond_p): | |
3383 | Use find_newline and avoid unnecessary point movements. | |
3384 | * search.c (scan_newline): Implement on top of find_newline. | |
3385 | ||
3ec7babc SM |
3386 | 2013-08-28 Stefan Monnier <monnier@iro.umontreal.ca> |
3387 | ||
3388 | * eval.c (Ffuncall): Fix handling of ((lambda ..) ..) in lexically | |
3389 | scoped code (bug#11258). | |
3390 | ||
5ab473cd JD |
3391 | 2013-08-28 Davor Cubranic <cubranic@stat.ubc.ca> (tiny change) |
3392 | ||
3393 | * nsterm.m (last_window): New variable. | |
3394 | (EV_TRAILER2): New macro. | |
3395 | (EV_TRAILER): Call EV_TRAILER2. | |
3396 | (mouseMoved:): Add support for mouse-autoselect-window | |
3397 | on nextstep (Bug#6888). | |
3398 | ||
78779650 AS |
3399 | 2013-08-28 Andreas Schwab <schwab@suse.de> |
3400 | ||
3401 | * regex.c (CHAR_CHARSET, CHARSET_LEADING_CODE_BASE, CHAR_HEAD_P) | |
3402 | (SINGLE_BYTE_CHAR_P, SAME_CHARSET_P, MAKE_CHAR, BYTE8_TO_CHAR): | |
3403 | Remove unused macro definitions. | |
3404 | (CHARSET_RANGE_TABLE_BITS, EXTEND_RANGE_TABLE) | |
3ec7babc SM |
3405 | (SET_RANGE_TABLE_WORK_AREA_BIT, SET_RANGE_TABLE_WORK_AREA): |
3406 | Only define if emacs. | |
78779650 | 3407 | |
c3c4768d DA |
3408 | 2013-08-28 Dmitry Antipov <dmantipov@yandex.ru> |
3409 | ||
3410 | Prefer enum glyph_row_area to int where appropriate. | |
3411 | * dispextern.h (enum glyph_row_area): Add ANY_AREA member. | |
3412 | Fix comment. | |
3413 | (window_box, window_box_width, window_box_left, window_box_left_offset) | |
3414 | (window_box_right, window_box_right_offset): Adjust prototypes. | |
3415 | * xdisp.c (window_box, window_box_width, window_box_left) | |
3416 | (window_box_left_offset, window_box_right, window_box_right_offset): | |
3417 | Use enum glyph_row_area. Adjust users and tweak comment where needed. | |
3418 | (window_box_edges): Likewise. Lost 2nd arg since it is always ANY_AREA. | |
3419 | * nsterm.m (ns_clip_to_row): | |
3420 | * w32term.c (w32_clip_to_row): | |
3421 | * xterm.c (x_clip_to_row): Likewise. | |
3422 | ||
6bdcbfe1 DA |
3423 | 2013-08-28 Dmitry Antipov <dmantipov@yandex.ru> |
3424 | ||
3425 | * buffer.c (Foverlays_at, Foverlays_in, Fnext_overlay_change) | |
3426 | (Fprevious_overlay_change): Fast path for buffer with no overlays. | |
3427 | ||
50b13cde PE |
3428 | 2013-08-28 Paul Eggert <eggert@cs.ucla.edu> |
3429 | ||
3430 | * Makefile.in (SHELL): Now @SHELL@, not /bin/sh, | |
3431 | for portability to hosts where /bin/sh has problems. | |
3432 | ||
f60e429a DA |
3433 | 2013-08-28 Dmitry Antipov <dmantipov@yandex.ru> |
3434 | ||
3435 | Redesign redisplay interface to drop global output_cursor. | |
3436 | * dispextern.h (struct redisplay_interface): Remove cursor_to member. | |
3437 | (toplevel): Remove declaration of output_cursor. | |
3438 | (set_output_cursor, x_cursor_to): Remove prototype. | |
3439 | * window.h (struct window): New member output_cursor. | |
3440 | (output_cursor_to): New function to replace RIF member. | |
3441 | * dispnew.c (redraw_overlapped_rows, update_marginal_area) | |
3442 | (update_text_area, set_window_cursor_after_update): Use it. | |
3443 | * xdisp.c (output_cursor, set_output_cursor, x_cursor_to): Remove. | |
3444 | (x_write_glyphs, x_insert_glyphs, x_clear_end_of_line): | |
3445 | * nsterm.m (ns_update_window_begin, ns_update_window_end): | |
3446 | * w32term.c (x_update_window_begin, x_update_window_end): | |
3447 | * xterm.c (x_update_window_begin, x_update_window_end): | |
3448 | Adjust to use per-window output cursor. | |
3449 | ||
43aac990 PE |
3450 | 2013-08-27 Paul Eggert <eggert@cs.ucla.edu> |
3451 | ||
d486344e PE |
3452 | Simplify SELECT_TYPE-related code. |
3453 | Like EMACS_TIME, this portability layer is no longer needed, since | |
3454 | Emacs has been using fd_set as a portability layer for some time. | |
3455 | * sysselect.h (FD_SETSIZE): Rename from MAXDESC. All uses changed. | |
3456 | (SELECT_TYPE): Remove. All uses changed to fd_set. | |
3457 | (fd_set) [!FD_SET]: New typedef. | |
3458 | ||
43aac990 PE |
3459 | Simplify EMACS_TIME-related code. |
3460 | This portability layer is no longer needed, since Emacs has been | |
3461 | using struct timespec as a portability layer for some time. | |
3462 | * atimer.h, buffer.h, dispextern.h, xgselect.h: | |
3463 | Include <time.h> rather than "systime.h"; that's all that's needed now. | |
3464 | * dispnew.c: Include <timespec.h> rather than "systime.h"; | |
3465 | that's all that's needed now. | |
3466 | * systime.h (EMACS_TIME): Remove. All uses changed to struct timespec. | |
3467 | (EMACS_TIME_RESOLUTION): Remove. All uses changed to | |
3468 | TIMESPEC_RESOLUTION. | |
3469 | (LOG10_EMACS_TIME_RESOLUTION): Remove. All uses changed to | |
3470 | LOG10_TIMESPEC_RESOLUTION. | |
3471 | (EMACS_SECS, emacs_secs_addr): Remove. All uses changed to tv_sec. | |
3472 | (EMACS_NSECS): Remove. All uses changed to tv_nsec. | |
3473 | (make_emacs_time): Remove. All used changed to make_timespec. | |
3474 | (invalid_timespec): Rename from invalid_emacs_time. All uses changed. | |
3475 | (current_timespec): Rename from current_emacs_time. All uses changed. | |
3476 | (add_emacs_time): Remove. All uses changed to timespec_add. | |
3477 | (sub_emacs_time): Remove. All uses change dot timespec_sub. | |
3478 | (EMACS_TIME_SIGN): Remove. All uses changed to timespec_sign. | |
3479 | (timespec_valid_p): Rename from EMACS_TIME_VALID_P. All uses changed. | |
3480 | (EMACS_TIME_FROM_DOUBLE): Remove. All uses changed to dtotimespec. | |
3481 | (EMACS_TIME_TO_DOUBLE): Remove. All uses changed to timespectod. | |
3482 | (current_timespec): Rename from current_emacs_time. All uses changed. | |
3483 | (EMACS_TIME_EQ, EMACS_TIME_LT, EMACS_TIME_LE): Remove. All uses | |
3484 | changed to timespec_cmp. | |
3485 | * xgselect.c: Include <timespec.h>, since our .h files don't. | |
3486 | ||
d350e350 DA |
3487 | 2013-08-27 Dmitry Antipov <dmantipov@yandex.ru> |
3488 | ||
3489 | * xterm.h (FONT_TYPE_FOR_UNIBYTE, FONT_TYPE_FOR_MULTIBYTE:) | |
3490 | * nsterm.h (FONT_TYPE_FOR_UNIBYTE, FONT_TYPE_FOR_MULTIBYTE): | |
3491 | Remove the leftovers. | |
3492 | * gtkutil.c (toplevel): Do not declare Qxft but include | |
3493 | font.h to do so. | |
3494 | * image.c (toplevel): Do not declare Vlibrary_cache because | |
3495 | it's already done in lisp.h. | |
3496 | ||
9fed9729 DA |
3497 | 2013-08-27 Dmitry Antipov <dmantipov@yandex.ru> |
3498 | ||
3499 | * lisp.h (Mouse_HLInfo): Move from here... | |
3500 | * dispextern.h (Mouse_HLInfo): ...to here and offload lisp.h. | |
3501 | (reset_mouse_highlight): New function. | |
3502 | * msdos.c (dos_set_window_size, IT_update_begin) | |
3503 | (internal_terminal_init): | |
3504 | * nsterm.m (ns_update_window_end, x_free_frame_resources) | |
3505 | (ns_initialize_display_info): | |
3506 | * w32console.c (initialize_w32_display): | |
3507 | * w32term.c (x_update_window_end, x_free_frame_resources) | |
3508 | (w32_initialize_display_info): | |
3509 | * xterm.c (x_update_window_end, x_free_frame_resources, x_term_init): | |
3510 | * window.c (Fdelete_other_windows_internal): | |
3511 | * xdisp.c (clear_mouse_face, cancel_mouse_face): Use it. | |
3512 | * termchar.h (toplevel): | |
3513 | * xterm.h (toplevel): Include dispextern.h. | |
3514 | ||
f462f075 PE |
3515 | 2013-08-26 Paul Eggert <eggert@cs.ucla.edu> |
3516 | ||
3517 | Fix minor problems found by static checking. | |
3518 | * image.c (XGetPixel, XPutPixel) [HAVE_NS]: Now static. | |
3519 | (expect): Avoid nested-if warning. | |
3520 | (x_build_heuristic_mask) [HAVE_NS]: Avoid unused-var warning. | |
3521 | * nsmenu.m (fillWithWidgetValue:): Avoid type warning. | |
3522 | * nsterm.h, nsterm.m (ns_select): | |
3523 | * xgselect.c, xgselect.h (xg_select): | |
3524 | Adjust signature to better match pselect's. | |
3525 | * nsterm.m (ns_select): | |
3526 | Don't set *TIMEOUT, since pselect doesn't. | |
3527 | * regex.c (whitespace_regexp): Now const_re_char *, to avoid | |
3528 | diagnostic about assigning const char * to it. | |
3529 | * xfaces.c (x_display_info) [HAVE_NS]: Remove; unused. | |
3530 | ||
068f9124 SM |
3531 | 2013-08-26 Stefan Monnier <monnier@iro.umontreal.ca> |
3532 | ||
3533 | * lread.c (substitute_object_recurse): Handle hash-tables as well | |
3534 | (bug#15190). | |
3535 | ||
f5adc984 PE |
3536 | 2013-08-26 Paul Eggert <eggert@cs.ucla.edu> |
3537 | ||
1fc8eb33 PE |
3538 | Fix unlikely core dump in init_tty, and simplify terminfo case. |
3539 | * term.c (init_tty) [TERMINFO]: Fix check for buffer overrun. | |
3540 | The old version incorrectly dumped core if malloc returned a | |
3541 | buffer containing only non-NUL bytes. | |
3542 | (init_tty): Do not allocate or free termcap buffers; the | |
3543 | struct does that for us now. | |
3544 | * termchar.h (TERMCAP_BUFFER_SIZE) [!TERMINFO]: New constant. | |
3545 | (struct tty_display_info): Define members termcap_term_buffer and | |
3546 | termcap_strings_buffer only if !TERMINFO, since terminfo doesn't | |
3547 | use them. Allocate them directly in struct rather than indirectly | |
3548 | via a pointer, to simplify init_tty. | |
3549 | ||
f5adc984 PE |
3550 | * frame.c (check_minibuf_window): Initialize 'window' properly, |
3551 | so that Emacs reliably aborts later if 'window' is not initialized. | |
3552 | ||
efec3894 JD |
3553 | 2013-08-26 Jan Djärv <jan.h.d@swipnet.se> |
3554 | ||
3555 | * gtkutil.c (xg_initialize): Set gtk-menu-bar-accel to "" instead | |
3556 | of VoidSymbol (Bug#15154). | |
3557 | ||
e1d0341e DA |
3558 | 2013-08-26 Dmitry Antipov <dmantipov@yandex.ru> |
3559 | ||
3560 | * lisp.h (Mouse_HLInfo): Drop set-but-unused members | |
3561 | mouse_face_beg_y and mouse_face_end_y. | |
3562 | * xdisp.c (note_tool_bar_highlight, mouse_face_from_buffer_pos) | |
3563 | (mouse_face_from_string_pos, note_mode_line_or_margin_highlight): | |
3564 | Adjust users and update comment where appropriate. | |
3565 | ||
bfff6445 MR |
3566 | 2013-08-26 Martin Rudalics <rudalics@gmx.at> |
3567 | ||
3568 | * frame.c (check_minibuf_window): New function. | |
068f9124 SM |
3569 | (delete_frame, Fmake_frame_invisible, Ficonify_frame): |
3570 | Call check_minibuf_window (Bug#15183). | |
bfff6445 | 3571 | |
c80016b3 DA |
3572 | 2013-08-26 Dmitry Antipov <dmantipov@yandex.ru> |
3573 | ||
3574 | * window.h (struct window): Replace last_cursor with last_cursor_vpos | |
3575 | because this is the only last cursor data we need to keep and consult. | |
3576 | * window.c (replace_window, set_window_buffer, Fsplit_window_internal): | |
3577 | * xdisp.c (mark_window_display_accurate_1, try_cursor_movement): | |
3578 | Adjust users. | |
3579 | ||
de396731 DA |
3580 | 2013-08-26 Dmitry Antipov <dmantipov@yandex.ru> |
3581 | ||
068f9124 SM |
3582 | Fix recovering from possible decompression error. |
3583 | Since insert_from_gap doesn't always move point, we can't use PT as | |
de396731 | 3584 | the position where the partially decompressed data ends, and |
447218dd | 3585 | should count how many bytes was produced so far. |
de396731 DA |
3586 | * decompress.c (struct decompress_unwind_data): Add nbytes member. |
3587 | (unwind_decompress): Really delete partially uncompressed data. | |
3588 | (Fzlib_decompress_region): Take decompressed data size into account. | |
3589 | ||
c76826d9 DA |
3590 | 2013-08-26 Dmitry Antipov <dmantipov@yandex.ru> |
3591 | ||
3592 | * syntax.c (init_syntax_once): Adjust comment and do an early | |
3593 | initialization of Qchar_table_extra_slots just once... | |
3594 | * casetab.c (init_casetab_once): | |
3595 | * category.c (init_category_once): | |
3596 | * character.c (syms_of_character): | |
3597 | * coding.c (syms_of_coding): | |
3598 | * xdisp.c (syms_of_xdisp): ...and omit it here. | |
3599 | ||
b34454d0 EZ |
3600 | 2013-08-24 Eli Zaretskii <eliz@gnu.org> |
3601 | ||
11f20add EZ |
3602 | * xdisp.c (get_next_display_element): Don't apply to characters |
3603 | from a display vector the logic of setting it->end_of_box_run_p | |
3604 | suitable for characters from a buffer. (Bug#15175) | |
3605 | ||
b34454d0 EZ |
3606 | * w32.c (fdutimens): Call 'utime', which is implemented on w32.c |
3607 | to handle directories, rather than '_utime' which doesn't. | |
3608 | (Bug#15176) | |
3609 | ||
6e1b469e JD |
3610 | 2013-08-24 Jan Djärv <jan.h.d@swipnet.se> |
3611 | ||
3612 | * gtkutil.c (x_wm_set_size_hint): Don't set hints when maximized | |
3613 | or fullscreen (Bug#14627). | |
3614 | ||
9c05bccf PE |
3615 | 2013-08-24 Paul Eggert <eggert@cs.ucla.edu> |
3616 | ||
3617 | System-dependent integer overflow fixes. | |
3618 | * process.c (Fset_process_window_size): Signal an error if | |
3619 | the window size is outside the range supported by the lower level. | |
3620 | * sysdep.c (set_window_size): Return negative on error, | |
3621 | nonnegative on success, rather than -1, 0, 1 on not in system, | |
3622 | failure, success. This is simpler. Caller changed. | |
3623 | (serial_configure): Remove unnecessary initialization of local. | |
3624 | (procfs_get_total_memory) [GNU_LINUX]: Don't assume system memory | |
3625 | size fits in unsigned long; this isn't true on some 32-bit hosts. | |
3626 | Avoid buffer overrun if some future version of /proc/meminfo has a | |
3627 | variable name longer than 20 bytes. | |
3628 | (system_process_attributes) [__FreeBSD__]: | |
3629 | Don't assume hw.availpages fits in 'int'. | |
3630 | ||
c365c355 PE |
3631 | 2013-08-23 Paul Eggert <eggert@cs.ucla.edu> |
3632 | ||
3633 | Don't let very long directory names overrun the stack. | |
3634 | Fix some related minor problems involving "//", vfork. | |
3635 | * callproc.c (encode_current_directory): New function. | |
3636 | (call_process): Don't append "/"; not needed. | |
3637 | * fileio.c (file_name_as_directory_slop): New constant. | |
3638 | (file_name_as_directory): Allow SRC to be longer than SRCLEN; | |
3639 | this can save the caller having to alloca. | |
3640 | (Ffile_name_as_directory, Fdirectory_file_name, Fexpand_file_name): | |
3641 | Use SAFE_ALLOCA, not alloca. | |
3642 | (directory_file_name, Fexpand_file_name): Leave leading "//" | |
3643 | alone, since it can be special even on POSIX platforms. | |
3644 | * callproc.c (call_process): | |
3645 | * process.c (Fformat_network_address): | |
3646 | * sysdep.c (sys_subshell): | |
3647 | Use encode_current_directory rather than rolling our own. | |
3648 | (create_process): No need to encode directory; caller does that now. | |
3649 | * process.h (encode_current_directory): New decl. | |
3650 | * sysdep.c (sys_subshell): Work even if vfork trashes saved_handlers. | |
3651 | Rework to avoid 'goto xyzzy;'. | |
3652 | ||
6c6014d4 EZ |
3653 | 2013-08-23 Eli Zaretskii <eliz@gnu.org> |
3654 | ||
3655 | * xdisp.c (handle_face_prop): If the default face was remapped use | |
3656 | the remapped face for strings from prefix properties. (Bug#15155) | |
3657 | ||
9997ec56 DA |
3658 | 2013-08-23 Dmitry Antipov <dmantipov@yandex.ru> |
3659 | ||
3660 | Minor cleanup for redisplay interface and few related functions. | |
3661 | * frame.h (enum text_cursor_kinds): Move from here... | |
3662 | * dispextern.h (enum text_cursor_kinds): ...to here. | |
3663 | (toplevel): Drop unnecessary declarations. | |
3664 | (struct redisplay_interface): Use bool and enum text_cursor_kinds | |
3665 | in update_window_end_hook and draw_window_cursor functions. | |
3666 | (display_and_set_cursor, x_update_cursor): Adjust prototypes. | |
3667 | * nsterm.m (ns_update_window_end, ns_draw_window_cursor): | |
ffb3f67a | 3668 | * w32term.c (x_update_window_end, w32_draw_window_cursor): |
9997ec56 DA |
3669 | * xterm.c (x_update_window_end, x_draw_window_cursor): |
3670 | * xdisp.c (display_and_set_cursor, update_window_cursor) | |
3671 | (update_cursor_in_window_tree, x_update_cursor): Use bool and | |
3672 | enum text_cursor_kinds where appropriate. | |
3673 | ||
7f780da6 DA |
3674 | 2013-08-23 Dmitry Antipov <dmantipov@yandex.ru> |
3675 | ||
3676 | Redesign redisplay interface to drop updated_row and updated_area. | |
3677 | * dispextern.h (updated_row, updated_area): Remove declaration. | |
3678 | (struct redisplay_interface): Pass glyph row and row area parameters | |
3679 | to write_glyphs, insert_glyphs and clear_end_of_line functions. | |
3680 | (x_write_glyphs, x_insert_glyphs, x_clear_end_of_line): | |
3681 | Adjust prototypes. | |
3682 | * dispnew.c (updated_row, updated_area): Remove. | |
3683 | (redraw_overlapped_rows, update_window_line): Adjust user. | |
3684 | (update_marginal_area, update_text_area): Likewise. Pass updated row | |
3685 | as a parameter. Prefer enum glyph_row_area to int where appropriate. | |
3686 | * xdisp.c (x_write_glyphs, x_insert_glyphs, x_clear_end_of_line): | |
3687 | Adjust users. | |
3688 | ||
26495794 PE |
3689 | 2013-08-22 Paul Eggert <eggert@cs.ucla.edu> |
3690 | ||
3691 | * process.c (flush_pending_output): Remove stub. | |
3692 | All uses removed. | |
3693 | ||
4a88129a PE |
3694 | 2013-08-21 Paul Eggert <eggert@cs.ucla.edu> |
3695 | ||
3696 | * callproc.c: Fix race that killed background processes (Bug#15144). | |
3697 | (call_process): New arg TEMPFILE_INDEX. Callers changed. | |
3698 | Record deleted process-id in critical section, not afterwards. | |
3699 | Don't mistakenly kill process created by a call-process invocation | |
3700 | that discards output and does not wait. | |
3701 | ||
0c5307b0 DA |
3702 | 2013-08-21 Dmitry Antipov <dmantipov@yandex.ru> |
3703 | ||
3704 | Fix compilation with GC_MARK_STACK == GC_USE_GCPROS_AS_BEFORE | |
3705 | and GC_MARK_STACK == GC_USE_GCPROS_CHECK_ZOMBIES. | |
3706 | * alloc.c (toplevel): Remove unnecessary nested #if...#endif. | |
3707 | (mark_maybe_object) [!GC_MARK_STACK]: Define to emacs_abort | |
3708 | to shut up compiler in mark_object. | |
3709 | (dump_zombies): Convert to global and add EXTERNALLY_VISIBLE. | |
3710 | ||
0d7c1e66 PE |
3711 | 2013-08-21 Paul Eggert <eggert@cs.ucla.edu> |
3712 | ||
3713 | * process.c (allocate_pty) [PTY_OPEN]: Set fd's FD_CLOEXEC flag. | |
3714 | We can't portably rely on PTY_OPEN doing that, even if | |
3715 | it calls posix_openpt with O_CLOEXEC. | |
3716 | ||
3f246b65 KH |
3717 | 2013-08-20 Kenichi Handa <handa@gnu.org> |
3718 | ||
3719 | * character.c (string_char): Improve commentary. | |
3720 | ||
8c2f38aa PE |
3721 | 2013-08-20 Paul Eggert <eggert@cs.ucla.edu> |
3722 | ||
3723 | * image.c (SIGNATURE_DIGESTSIZE): Remove. | |
3724 | (struct animation_cache): Make signature a flexible array member. | |
3725 | All uses changed. This is a tad slower but may insulate us better | |
3726 | from future changes to ImageMagick. | |
3727 | ||
bb566cea PE |
3728 | 2013-08-19 Paul Eggert <eggert@cs.ucla.edu> |
3729 | ||
3730 | * image.c: Shrink memory needed for animation cache. | |
3731 | (SIGNATURE_DIGESTSIZE): New constant. | |
3732 | (struct animation_cache): Make 'signature' a fixed size array of bytes. | |
3733 | (imagemagick_create_cache): Copy the signature. This saves | |
3734 | several KB of memory that ImageMagick wastes per signature. | |
3735 | Don't bother updating the update_time, as the caller does that now. | |
3736 | (imagemagick_prune_animation_cache): Don't destroy the signature, as | |
3737 | it's a fixed size struct member now. | |
3738 | (imagemagick_get_animation_cache): Always destroy the signature, | |
3739 | as it's now imagemagick_create_cache's responsibility to copy it. | |
3740 | Avoid duplicate calls to strcmp and to imagemagick_create_cache, | |
3741 | and use memcmp rather than strcmp. | |
3742 | eassert that ImageMagick returns a signature of the specified length. | |
3743 | ||
6da26928 LMI |
3744 | 2013-08-19 Lars Magne Ingebrigtsen <larsi@gnus.org> |
3745 | ||
3746 | * image.c (imagemagick_get_animation_cache): Don't segfault on | |
3747 | each invocation. | |
453f4022 LMI |
3748 | (imagemagick_get_animation_cache): Revert to previous definition |
3749 | so that it actually works. But keep the memory leak fix. | |
3750 | (imagemagick_get_animation_cache): Fix memory leak. | |
6da26928 | 3751 | |
22490125 PE |
3752 | 2013-08-19 Paul Eggert <eggert@cs.ucla.edu> |
3753 | ||
d0139df5 PE |
3754 | * image.c: Fix animation cache signature memory leak. |
3755 | Fix some other minor performance problems while we're at it. | |
3756 | (imagemagick_create_cache): Clear just the members that | |
3757 | need clearing. Don't set update_time, as caller does that now. | |
3758 | (imagemagick_prune_animation_cache, imagemagick_get_animation_cache): | |
3759 | Simplify by using pointer-to-pointer instead of a prev pointer. | |
3760 | (imagemagick_prune_animation_cache): Use make_emacs_time rather | |
3761 | than EMACS_TIME_FROM_DOUBLE, and DestroyString rather than free. | |
3762 | (imagemagick_get_animation_cache): Don't xstrdup the image signature; | |
3763 | it's already a copy. Free the signature probe unless it's cached. | |
3764 | ||
22490125 PE |
3765 | * process.c (handle_child_signal): Fix crash; deleted pid (Bug#15106). |
3766 | This was introduced by my 2013-08-12 fix for Bug#15035. | |
3767 | ||
deb31e75 DA |
3768 | 2013-08-19 Dmitry Antipov <dmantipov@yandex.ru> |
3769 | ||
3770 | * image.c (imagemagick_create_cache, imagemagick_get_animation_cache) | |
3771 | (imagemagick_prune_animation_cache): Now static. | |
3772 | ||
319a4d03 LMI |
3773 | 2013-08-18 Lars Magne Ingebrigtsen <larsi@gnus.org> |
3774 | ||
3775 | * image.c (imagemagick_get_animation_cache): Don't segfault when | |
3776 | pruning all entries. | |
3777 | ||
f747d82e KB |
3778 | 2013-08-18 Ken Brown <kbrown@cornell.edu> |
3779 | ||
3780 | * sheap.c (STATIC_HEAP_SIZE): Adjust to current needs; use bigger | |
3781 | static heap if ENABLE_CHECKING is defined. | |
3782 | (max_bss_sbrk_ptr): New variable. | |
3783 | (bss_sbrk): Use it. | |
3784 | (report_sheap_usage): Report maximum static heap usage instead of | |
3785 | ending static heap usage. | |
3786 | ||
d2c28fab EZ |
3787 | 2013-08-17 Eli Zaretskii <eliz@gnu.org> |
3788 | ||
3789 | * decompress.c (Fzlib_available_p) [WINDOWSNT]: Update the value | |
3790 | of zlib_initialized according to the results of calling | |
3791 | init_zlib_functions. | |
3792 | ||
274ff63f LMI |
3793 | 2013-08-16 Lars Magne Ingebrigtsen <larsi@gnus.org> |
3794 | ||
3795 | * image.c: Implement an ImageMagick per-image cache. | |
8a6f875f | 3796 | (imagemagick_get_animation_cache): Fix a double-free error. |
49ceb676 LMI |
3797 | (imagemagick_load_image): Remove the ping_wand code, which only |
3798 | apparently saved time on invalid animated images, and slowed down | |
3799 | everything else. Optimise for the common case. | |
274ff63f | 3800 | |
2bede2ed XF |
3801 | 2013-08-16 Xue Fuqiao <xfq.free@gmail.com> |
3802 | ||
70ff8240 XF |
3803 | * buffer.c (syms_of_buffer) <buffer-undo-list>: Doc fix. |
3804 | ||
de179a3e XF |
3805 | * editfns.c (insert_before_markers): Mention overlay in the doc string. |
3806 | ||
2bede2ed XF |
3807 | * marker.c (set_marker): Remove documentation of undefined behavior. |
3808 | ||
703dbeba LMI |
3809 | 2013-08-15 Lars Magne Ingebrigtsen <larsi@gnus.org> |
3810 | ||
3811 | * image.c (imagemagick_compute_animated_image): Animate correctly | |
3812 | when sub-images are smaller than the main image. | |
1d18b1e6 LMI |
3813 | (imagemagick_compute_animated_image): Setting the iterator row to |
3814 | zero is apparently not allowed. | |
79670014 LMI |
3815 | (imagemagick_compute_animated_image): Allow images that say they |
3816 | have sub-images that are bigger than the main image, but just crop | |
3817 | them. | |
703dbeba | 3818 | |
63216c5e JD |
3819 | 2013-08-15 Jan Djärv <jan.h.d@swipnet.se> |
3820 | ||
3821 | * nsmenu.m (menuWillOpen:): Fix preprocessor test (Bug#15001). | |
3822 | ||
a5b5f73f LMI |
3823 | 2013-08-15 Lars Magne Ingebrigtsen <larsi@gnus.org> |
3824 | ||
3825 | * image.c (imagemagick_compute_animated_image): Respect the GIF | |
3826 | disposal methods. | |
3827 | ||
0fe73012 KB |
3828 | 2013-08-15 Ken Brown <kbrown@cornell.edu> |
3829 | ||
3830 | * emacs.c (main): Update comment about G_SLICE_ALWAYS_MALLOC. | |
3831 | * gmalloc.c (memalign) [CYGWIN]: Revert last change; it's not | |
3832 | needed. | |
3833 | ||
691a357f PE |
3834 | 2013-08-15 Paul Eggert <eggert@cs.ucla.edu> |
3835 | ||
3836 | Fix minor problems found by static checking. | |
3837 | * frame.c (delete_frame): | |
3838 | * xdisp.c (next_element_from_display_vector): | |
3839 | Avoid uninitialized local. | |
3840 | * image.c (imagemagick_compute_animated_image): Port to C89. | |
3841 | Prefer usual GNU indentation style for loops. | |
3842 | Be more careful about bizarrely large sizes, by using ptrdiff_t | |
3843 | instead of int. | |
3844 | ||
42fe2e88 DA |
3845 | 2013-08-15 Dmitry Antipov <dmantipov@yandex.ru> |
3846 | ||
3847 | Fix infinite frame selection loop (Bug#15025). | |
3848 | * frame.c (delete_frame): Prefer fast ad-hoc loop to next_frame. | |
3849 | ||
d39a3da6 EZ |
3850 | 2013-08-15 Eli Zaretskii <eliz@gnu.org> |
3851 | ||
068f9124 SM |
3852 | * xdisp.c (compute_window_start_on_continuation_line): |
3853 | When WORD_WRAP is in effect, use move_it_to instead of move_it_by_lines | |
d39a3da6 EZ |
3854 | to make sure we end up setting the window start at the leftmost |
3855 | visible character of the display line. This avoids funky | |
3856 | horizontal shifting because the window start is not kept on the | |
3857 | same position. (Bug#15090) | |
05426239 EZ |
3858 | (next_element_from_display_vector): Support 'box' face attribute |
3859 | in the face definitions of a display vector. (Bug#15099) | |
d39a3da6 | 3860 | |
6e856b69 LMI |
3861 | 2013-08-15 Lars Magne Ingebrigtsen <larsi@gnus.org> |
3862 | ||
3863 | * image.c (imagemagick_compute_animated_image): Implement animated | |
3864 | images (bug#14700). | |
995be755 LMI |
3865 | (imagemagick_compute_animated_image): Fix some compilation |
3866 | warnings. Implement a very simple cache to make the animation | |
3867 | usable at all, but it should be replaced with a per-image cache. | |
6e856b69 | 3868 | |
d5a1acfa DA |
3869 | 2013-08-15 Dmitry Antipov <dmantipov@yandex.ru> |
3870 | ||
3871 | * lisp.h (FOR_EACH_ALIST_VALUE): New macro | |
3872 | to do `for' loops over alist values. | |
3873 | * buffer.h (FOR_EACH_BUFFER): | |
3874 | * process.c (FOR_EACH_PROCESS): Use it. | |
3875 | (handle_child_signal, status_notify, Fget_buffer_process) | |
3876 | (kill_buffer_processes): Use FOR_EACH_PROCESS. | |
3877 | ||
9c253307 DA |
3878 | 2013-08-15 Dmitry Antipov <dmantipov@yandex.ru> |
3879 | ||
3880 | * term.c (get_named_tty, create_tty_output, tty_free_frame_resources) | |
3881 | (tty_free_frame_resources, delete_tty): Prefer eassert to emacs_abort. | |
3882 | * image.c (make_image_cache): For struct image_cache, prefer xmalloc | |
3883 | to xzalloc and so avoid redundant call to memset. | |
3884 | * xterm.c (x_term_init): Avoid unnecessary initializations of dpyinfo | |
3885 | members because it is allocated with xzalloc and so already zeroed. | |
3886 | ||
05e64f9f KB |
3887 | 2013-08-14 Ken Brown <kbrown@cornell.edu> |
3888 | ||
3889 | * gmalloc.c (memalign) [CYGWIN]: Rename to emacs_memalign | |
3890 | (Bug#15094). | |
3891 | ||
5b71542d DA |
3892 | 2013-08-14 Dmitry Antipov <dmantipov@yandex.ru> |
3893 | ||
3894 | Utility function and macro to copy Lisp string to C string. | |
3895 | * lisp.h (xlispstrdupa): New macro. | |
3896 | (xlispstrdup): New prototype. | |
3897 | * alloc.c (xlispstrdup): New function. | |
3898 | * callint.c (Fcall_interactively): | |
3899 | * fileio.c (Ffile_name_directory, Fexpand_file_name) | |
3900 | (Fsubstitute_in_file_name): | |
3901 | * frame.c (Fmake_terminal_frame): Use xlispstrdupa. | |
3902 | * image.c (x_create_bitmap_from_file): | |
3903 | * w32term.c (w32_term_init): | |
3904 | * xterm.c (x_term_init): Use xlispstrdup. | |
3905 | ||
71530c97 LMI |
3906 | 2013-08-14 Lars Magne Ingebrigtsen <larsi@gnus.org> |
3907 | ||
4ce82fb8 LMI |
3908 | * image.c (imagemagick_load_image): Make animated pictures work. |
3909 | There's still some problems with background color settings, though | |
3910 | (bug#14700). | |
3911 | ||
71530c97 LMI |
3912 | * decompress.c (unwind_decompress): Always restore point. |
3913 | ||
7510a061 XF |
3914 | 2013-08-14 Xue Fuqiao <xfq.free@gmail.com> |
3915 | ||
3916 | * marker.c (set_marker): Reformat documentation. | |
3917 | ||
01c3051f PE |
3918 | 2013-08-14 Paul Eggert <eggert@cs.ucla.edu> |
3919 | ||
aab1fcdf PE |
3920 | * xdisp.c (cursor_type_changed): Now static. |
3921 | ||
01c3051f PE |
3922 | * image.c (imagemagick_filename_hint): New arg HINT_BUFFER. |
3923 | Use changed. This avoids the need to call xmalloc and for the | |
3924 | caller to call xfree, and avoids memory leaks in some situations. | |
3925 | ||
2084152a DA |
3926 | 2013-08-14 Dmitry Antipov <dmantipov@yandex.ru> |
3927 | ||
3928 | * xdisp.c (adjust_window_ends): Move duplicated code to new function. | |
3929 | (try_window, try_window_reusing_current_matrix, try_window_id): Use it. | |
94a4e898 DA |
3930 | (redisplay_window): If window_end_valid is cleared due to non-zero |
3931 | windows_or_buffers_changed, clear current_matrix_up_to_date_p and | |
3932 | so do not call to try_cursor_movement for that window. | |
2084152a | 3933 | |
02455cb6 DA |
3934 | 2013-08-14 Dmitry Antipov <dmantipov@yandex.ru> |
3935 | ||
3936 | * window.h (struct window): Convert window_end_pos and | |
3937 | window_end_vpos from Lisp_Object to ptrdiff_t and int, respectively. | |
3938 | (wset_window_end_pos, wset_window_end_vpos): Remove. | |
3939 | * dispnew.c (adjust_glyph_matrix): | |
3940 | * window.c (Fwindow_end, replace_window, set_window_buffer) | |
3941 | (make_window): | |
3942 | * xdisp.c (check_window_end, move_it_to, redisplay_internal) | |
3943 | (set_vertical_scroll_bar, redisplay_window, try_window) | |
3944 | (try_window_reusing_current_matrix, find_first_unchanged_at_end_row) | |
3945 | (try_window_id, decode_mode_spec, mouse_face_from_buffer_pos) | |
3946 | (note_mouse_highlight): Adjust users. | |
3947 | (try_cursor_movement): Likewise. Convert old precondition to eassert. | |
3948 | Add comment. | |
3949 | ||
da5707e8 DA |
3950 | 2013-08-14 Dmitry Antipov <dmantipov@yandex.ru> |
3951 | ||
3952 | Fix --enable-gcc-warnings errors introduced in 2013-08-13 commit. | |
3953 | * image.c (imagemagick_filename_hint): Use `const char *' and | |
3954 | prefer SSDATA to SDATA to avoid warnings. | |
3955 | ||
25554267 DA |
3956 | 2013-08-14 Dmitry Antipov <dmantipov@yandex.ru> |
3957 | ||
3958 | Cleanup window fringes, margins and scroll bars adjustments. | |
3959 | * window.c (set_window_fringes, set_window_margins) | |
3960 | (set_window_scroll_bars, apply_window_adjustment): New functions. | |
3961 | (set_window_buffer, Fset_window_margins, Fset_window_fringes) | |
3962 | (Fset_window_scroll_bars): Use them. | |
3963 | ||
38a2c910 DA |
3964 | 2013-08-14 Dmitry Antipov <dmantipov@yandex.ru> |
3965 | ||
3966 | * window.h (struct window): Convert scroll_bar_width | |
3967 | from Lisp_Object to integer. Adjust comment. | |
3968 | (WINDOW_CONFIG_SCROLL_BAR_WIDTH, WINDOW_CONFIG_SCROLL_BAR_COLS): | |
3969 | Adjust users. | |
3970 | * window.c (wset_scroll_bar_width): Remove. | |
3971 | (make_window): Initialize scroll_bar_width. | |
3972 | (Fsplit_window_internal): Use direct assignment. | |
3973 | (Fset_window_configuration, save_window_save): | |
3974 | Convert Lisp_Object to integer and back where appropriate. | |
3975 | (Fset_window_scroll_bars): Adjust user. Return t if any scroll | |
3976 | bar was actually changed, and mention this in docstring. | |
3977 | ||
2d065031 PE |
3978 | 2013-08-13 Paul Eggert <eggert@cs.ucla.edu> |
3979 | ||
3980 | * decompress.c: Minor simplifications. | |
3981 | (Fzlib_decompress_region): Don't bother verifying | |
3982 | that avail_out <= UINT_MAX, as that was confusing. | |
3983 | Mention the restriction in a comment instead. | |
3984 | Prefer 'int' to 'ptrdiff_t' when 'int' is wide enough. | |
3985 | ||
a5bd5abb JD |
3986 | 2013-08-13 Jan Djärv <jan.h.d@swipnet.se> |
3987 | ||
3988 | * nsmenu.m (x_activate_menubar): Check for OSX >= 10.5 | |
3989 | (trackingNotification:): Call ns_check_menu_open only for OSX >= 10.5. | |
3990 | ||
66e7901a LMI |
3991 | 2013-08-13 Lars Magne Ingebrigtsen <larsi@gnus.org> |
3992 | ||
3993 | * image.c (imagemagick_filename_hint): Check for errors in the | |
3994 | alist structure. | |
3995 | ||
2fa611b7 EZ |
3996 | 2013-08-13 Eli Zaretskii <eliz@gnu.org> |
3997 | ||
3998 | * window.c (Fwindow_margins): Return nil when there's no marginal | |
3999 | area, as per the documented API. | |
4000 | ||
4001 | * w32term.c (x_scroll_bar_create): Use ALLOCATE_PSEUDOVECTOR, not | |
4002 | Fmake_vector, as scroll bar's struct members are not all Lisp | |
4003 | objects now. This avoids crashes in GC. | |
4004 | ||
4005 | * w32term.h (struct scroll_bar): Convert fringe_extended_p to a | |
4006 | bool, so its address could be taken. | |
4007 | ||
8259030d LMI |
4008 | 2013-08-13 Lars Magne Ingebrigtsen <larsi@gnus.org> |
4009 | ||
4010 | * image.c (imagemagick_filename_hint): New function to possibly | |
4011 | apply `image-content-type-suffixes'. | |
4012 | (imagemagick_load_image): Use it. | |
4013 | ||
866c710e EZ |
4014 | 2013-08-13 Eli Zaretskii <eliz@gnu.org> |
4015 | ||
4016 | * decompress.c (Fzlib_decompress_region) [WINDOWSNT]: Return Qnil | |
4017 | if loading zlib failed. | |
4018 | ||
f10490f0 JD |
4019 | 2013-08-13 Jan Djärv <jan.h.d@swipnet.se> |
4020 | ||
96311be7 JD |
4021 | * nsterm.m (ns_set_vertical_scroll_bar): Fix breakage intruduced by |
4022 | 2013-08-13 checkin below. Change bool to BOOL, rule is: | |
4023 | All Obj-C code uses BOOL, except for interfaces callable from C. | |
4024 | ||
f10490f0 JD |
4025 | * nsterm.h: Fix CGFloat for OSX 10.4 (Bug#15086). |
4026 | ||
c8ae93b0 DA |
4027 | 2013-08-13 Dmitry Antipov <dmantipov@yandex.ru> |
4028 | ||
4029 | * window.h (WINDOW_FRINGE_EXTENDED_P): New macro. | |
4030 | * nsterm.m (ns_set_vertical_scroll_bar): Use it. Use convenient | |
4031 | bool instead of BOOL. | |
4032 | * w32term.h (struct scroll_bar): Convert fringe_extended_p | |
4033 | from Lisp_Object to bitfield. Adjust comment. | |
4034 | * w32term.c (x_scroll_bar_create): Adjust user. | |
4035 | Use WINDOW_FRINGE_EXTENDED_P and bool for boolean. | |
4036 | * xterm.c (XTset_vertical_scroll_bar): Likewise. | |
4037 | Use bool for boolean. | |
4038 | * xterm.h (struct scroll_bar): Prefer commonly used `unsigned' | |
4039 | to `unsigned int' when defining a bitfield. | |
4040 | ||
53b64418 PE |
4041 | 2013-08-13 Paul Eggert <eggert@cs.ucla.edu> |
4042 | ||
4043 | * decompress.c (Fzlib_decompress_region): Try to clarify 'avail_out'. | |
4044 | ||
eeaf9bf3 DA |
4045 | 2013-08-13 Dmitry Antipov <dmantipov@yandex.ru> |
4046 | ||
4047 | * window.h (struct window): Convert left_margin_cols and | |
4048 | right_margin_cols from Lisp_Objects to integers. Adjust comment. | |
4049 | (WINDOW_LEFT_MARGIN_COLS, WINDOW_RIGHT_MARGIN_COLS) | |
4050 | (WINDOW_LEFT_MARGIN_WIDTH, WINDOW_RIGHT_MARGIN_WIDTH): | |
4051 | Adjust users. | |
4052 | * dispnew.c (margin_glyphs_to_reserve): Convert 3rd arg to int. | |
4053 | Adjust comment. | |
4054 | (showing_window_margins_p, update_window_line, update_frame_1): | |
4055 | * fringe.c (draw_fringe_bitmap_1): | |
4056 | * xdisp.c (window_box_width): Adjust users. | |
4057 | * window.c (wset_left_margin_cols, wset_right_margin_cols): Remove. | |
4058 | (adjust_window_margins, set_window_buffer, Fsplit_window_internal): | |
4059 | Use direct assignment. | |
4060 | (Fset_window_configuration, save_window_save, Fwindow_margins): | |
4061 | Convert Lisp_Object to integer and back where appropriate. | |
4062 | (Fset_window_margins): Adjust user. Return t if any margin | |
4063 | was actually changed, and mention this in docstring. | |
4064 | ||
956720af XF |
4065 | 2013-08-13 Xue Fuqiao <xfq.free@gmail.com> |
4066 | ||
f73f4ce6 | 4067 | * syntax.c (forward_word): |
956720af XF |
4068 | * cmds.c (forward_char, backward_char): Mention the optional argument. |
4069 | ||
9e37ee3b DA |
4070 | 2013-08-13 Dmitry Antipov <dmantipov@yandex.ru> |
4071 | ||
4072 | * window.h (struct window): Convert left_fringe_width | |
4073 | and right_fringe_width from Lisp_Objects to integers. | |
4074 | Adjust comment. | |
4075 | (WINDOW_FRINGE_COLS, WINDOW_LEFT_FRINGE_WIDTH) | |
4076 | (WINDOW_RIGHT_FRINGE_WIDTH): Adjust users. | |
4077 | * window.c (wset_left_fringe_width, wset_right_fringe_width): | |
4078 | Remove. | |
4079 | (make_window): Initialize new integer fields to -1. | |
4080 | (Fsplit_window_internal): Use direct assignment. | |
068f9124 SM |
4081 | (Fset_window_configuration, save_window_save): |
4082 | Convert Lisp_Object to integer and back where appropriate. | |
9e37ee3b DA |
4083 | (Fset_window_fringes): Adjust user. Return t if any fringe |
4084 | was actually changed, and mention this in docstring. | |
4085 | ||
e4375ca7 DA |
4086 | 2013-08-13 Dmitry Antipov <dmantipov@yandex.ru> |
4087 | ||
4088 | * keyboard.c (Fdiscard_input): Do not increment update_mode_lines. | |
9cda66e4 DA |
4089 | * nsfns.m (x_set_cursor_type): |
4090 | * w32fns.c (x_set_cursor_type): | |
e903c210 | 4091 | * xfns.c (x_set_cursor_type): Do not set cursor_type_changed here... |
9cda66e4 | 4092 | * xdisp.c (set_frame_cursor_types): ...but in common code. |
e4375ca7 | 4093 | |
a45543bc DA |
4094 | 2013-08-13 Dmitry Antipov <dmantipov@yandex.ru> |
4095 | ||
4096 | * font.c (clear_font_cache): New function, stripped from... | |
4097 | (Fclear_font_cache): ...here, which now uses the function | |
4098 | above. Adjust comment. | |
4099 | * font.h (clear_font_cache): Add prototype. | |
4100 | * xfaces.c (clear_face_cache): Use clear_font_cache. | |
4101 | ||
ae966a86 DA |
4102 | 2013-08-13 Dmitry Antipov <dmantipov@yandex.ru> |
4103 | ||
4104 | * window.c (Fset_window_start): Compare `w', not `window' because | |
4105 | `w' might not be equal to `window' after call to decode_live_window. | |
4106 | ||
297a545b PE |
4107 | 2013-08-12 Paul Eggert <eggert@cs.ucla.edu> |
4108 | ||
4109 | * process.c (deactivate_process): Reset fds to -1 (Bug#15035). | |
4110 | This fixes a problem introduced by the Bug#15035 patch | |
4111 | when using GPG. Reported by Herbert J. Skuhra. | |
4112 | ||
aa942e2b EZ |
4113 | 2013-08-12 Eli Zaretskii <eliz@gnu.org> |
4114 | ||
4115 | * decompress.c <zlib_initialized> [WINDOWSNT]: New static variable. | |
4116 | (Fzlib_decompress_region) [WINDOWSNT]: Call init_zlib_functions if | |
4117 | not yet initialized. | |
4118 | ||
7699d09e LMI |
4119 | 2013-08-12 Lars Magne Ingebrigtsen <larsi@gnus.org> |
4120 | ||
4121 | * decompress.c (Fzlib_decompress_region): Support zlib | |
4122 | decompression, too, and rename. | |
4123 | ||
1d238bc7 PE |
4124 | 2013-08-12 Paul Eggert <eggert@cs.ucla.edu> |
4125 | ||
4126 | Minor zlib configuration tweaks. | |
4127 | * decompress.c (fn_inflateInit2) [!WINDOWSNT]: | |
4128 | Don't assume presence of fn_inflateInit2_ zlib internal function. | |
4129 | ||
8a44a184 LMI |
4130 | 2013-08-12 Lars Magne Ingebrigtsen <larsi@gnus.org> |
4131 | ||
4132 | * decompress.c (Fzlib_decompress_gzipped_region): Rename to | |
4133 | include the zlib prefix. | |
4134 | ||
594a4307 EZ |
4135 | 2013-08-12 Eli Zaretskii <eliz@gnu.org> |
4136 | ||
4137 | * decompress.c [WINDOWSNT]: Include windows.h and w32.h. | |
4138 | (DEF_ZLIB_FN, LOAD_ZLIB_FN) [WINDOWSNT]: New macros. Use them to | |
4139 | define static variables that are pointers to zlib functions to be | |
4140 | dynamically loaded. | |
4141 | (init_zlib_functions) [WINDOWSNT]: New function. | |
4142 | (fn_inflateInit2_, fn_inflate, fn_inflateEnd, fn_inflateInit2): | |
4143 | New macros. | |
4144 | (Fdecompress_gzipped_region, unwind_decompress): Use the fn_* | |
4145 | macros instead of invoking the zlib functions directly. | |
068f9124 SM |
4146 | (syms_of_decompress): DEFSYM Qzlib_dll. |
4147 | Staticpro Szlib_available_p. | |
594a4307 | 4148 | |
d2e113bc DA |
4149 | 2013-08-12 Dmitry Antipov <dmantipov@yandex.ru> |
4150 | ||
4151 | Avoid looping over all frame windows to freeze and unfreeze. | |
4152 | * window.h (struct window): Drop frozen_window_start_p. | |
4153 | (freeze_window_starts): Drop prototype. | |
4154 | * frame.h (struct frame): New frozen_window_starts flag. | |
4155 | (FRAME_WINDOWS_FROZEN): New macro. | |
4156 | * window.c (freeze_window_start, freeze_window_starts): | |
4157 | Remove. | |
4158 | (select_window, replace_window): Adjust users. | |
4159 | * xdisp.c (resize_mini_window): Use FRAME_WINDOWS_FROZEN. | |
4160 | (window_frozen_p): New function. | |
4161 | (redisplay_window): Use it. | |
4162 | ||
94fcd171 PE |
4163 | 2013-08-12 Paul Eggert <eggert@cs.ucla.edu> |
4164 | ||
4165 | Fix some fd issues when running subprocesses (Bug#15035). | |
4166 | Fix bugs that can leak files or file descriptors on errors. | |
4167 | Don't unlink open temp files, as that's hard for users to diagnose | |
4168 | when things go awry (e.g., temp disk exhausted). | |
4169 | Don't bother to lock temp files. Check for invalid recursion. | |
4170 | * callproc.c (synch_process_fd): Remove. All uses removed. | |
4171 | (synch_process_tempfile): New var or macro. | |
4172 | (CALLPROC_STDOUT, CALLPROC_STDERR, CALLPROC_PIPEREAD, CALLPROC_FDS): | |
4173 | New constants. | |
4174 | (record_kill_process): New arg, the temp name. All callers changed. | |
4175 | (delete_temp_file): Now just a simple wrapper around unlink. | |
4176 | (call_process_kill): New arg, the call_process_fd array. | |
4177 | Close them all. Clear synch_process_pid. Remove the temp file, | |
4178 | or arrange for it to be removed. | |
4179 | (call_process_cleanup) [MSDOS]: Arg no longer contains file name; | |
4180 | that's been moved to synch_process_tempfile. Caller changed. | |
4181 | Do not remove the tempfile; that's now call_process_kill's | |
4182 | responsibility. | |
4183 | (call_process_cleanup) [!MSDOS]: Do not record unwind-protect for | |
4184 | call_process_kill; the caller now does that. | |
4185 | (call_process_cleanup): Do not close the process fd; that's now | |
4186 | call_process_kill's responsibility. | |
4187 | (Fcall_process): Implement via new function call_process, which | |
4188 | has most of the old body of Fcall_process, but with a different API. | |
4189 | (call_process): New function that does not open or close filefd if | |
4190 | it is nonnegative. Record which fds need to be closed, and let | |
4191 | call_process_kill close (and remove the tempfile, on MSDOS) on error. | |
4192 | Signal an error if invoked recursively (could be done via a hook). | |
4193 | Simplify creation of the tempfile in the MSDOS case. | |
4194 | Don't create the output file until after checking for the executable. | |
4195 | Report any failure to open /dev/null. | |
4196 | Don't open /dev/null for writing twice; once is enough. | |
4197 | Don't create pipe if all output is being discarded or sent to file. | |
4198 | Don't worry about setting up the coding system or reading from the | |
4199 | pipe if all output is being discarded. | |
4200 | Hoist fd_error local into top level, to lessen block nesting. | |
4201 | Don't record deleted pid here; now done by Fcall_process_region. | |
4202 | (Fcall_process) [MSDOS]: Report mktemp failure immediately, | |
4203 | and note its success in synch_process_tempfile. | |
4204 | Do not leak resources when child_setup fails. | |
4205 | (Fcall_process) [!MSDOS && !WINDOWSNT]: Remove duplicate assignment | |
4206 | to child_errno. Remove unnecessary close of fd0; it's close-on-exec. | |
4207 | (create_temp_file): Now returns open fd, with an additional | |
4208 | Lisp_Object * argument to return the name. All callers changed. | |
4209 | Do not close the file; rewind it instead, and leave it open for | |
4210 | the caller. Do not lock the temp file. Unwind-protect the file | |
4211 | and the file-descriptor. | |
4212 | (Fcall_process_region): If the input is /dev/null, unwind-protect it. | |
4213 | If an asynchrounous process, record it here, not in call_process. | |
4214 | (syms_of_callproc) [MSDOS]: Initialize synch_process_tempfile. | |
4215 | * eval.c (set_unwind_protect): New function. | |
4216 | * fileio.c (write_region): New function, generalized from the | |
4217 | old Fwrite_region. Do not lock temp files. | |
4218 | (Fwrite_region): Use it. | |
4219 | * lisp.h (set_unwind_protect, write_region): New decls. | |
4220 | * process.c: Include <verify.h>. | |
4221 | (make_process): Mark fds as initially closed. | |
4222 | (deleted_pid_list): Now a list of pid-filename pairs. | |
4223 | All uses changed. | |
4224 | (close_process_fd): New function. | |
4225 | (SUBPROCESS_STDIN, WRITE_TO_SUBPROCESS, READ_FROM_SUBPROCESS) | |
4226 | (SUBPROCESS_STDOUT, READ_FROM_EXEC_MONITOR, EXEC_MONITOR_OUTPUT): | |
4227 | New constants. Verify that their number matches PROCESS_OPEN_FDS. | |
4228 | (create_process, create_pty, Fmake_serial_process) | |
4229 | (server_accept_connection): Record which fds need to be closed, | |
4230 | and let deactivate_process close them. | |
4231 | (Fmake_network_process): Do not discard the unwind-protect | |
4232 | until it's safe to do so. | |
4233 | (deactivate_process): Close the fds opened by create_process etc. | |
4234 | (Fprocess_send_eof): Adjust to new way of recording open fds. | |
4235 | Report an error if /dev/null can't be opened, instead of aborting. | |
4236 | * process.h (PROCESS_OPEN_FDS): New constant. | |
4237 | (struct Lisp_Process): New member open_fds. | |
4238 | (record_kill_process, record_deleted_pid): Adjust signatures. | |
4239 | (record_deleted_pid): Move decl here ... | |
4240 | * syswait.h (record_deleted_pid): ... from here. | |
4241 | ||
d0e615c3 PE |
4242 | 2013-08-11 Paul Eggert <eggert@cs.ucla.edu> |
4243 | ||
4244 | * decompress.c: Fix bugs with large buffers and weird inputs. | |
4245 | Tune a bit. Reindent as per usual Emacs style. | |
4246 | (BUFFER_SIZE): Remove. | |
4247 | (Fdecompress_gzipped_region): Do not mishandle input buffers with | |
4248 | more than UINT_MAX bytes. Decompress into the gap instead of into | |
4249 | an auto buffer, as this should avoid copying. Return nil if | |
4250 | 'inflate' returns Z_NEED_DICT, as we have no dictionary. Do not | |
4251 | set immediate_quit; we shouldn't trust zlib code that much. | |
4252 | ||
313546eb LMI |
4253 | 2013-08-11 Lars Magne Ingebrigtsen <larsi@gnus.org> |
4254 | ||
99a32242 LMI |
4255 | * decompress.c (Fdecompress_gzipped_region): Respect all zlib |
4256 | errors, and really move the gap to where we want it. | |
4257 | ||
313546eb LMI |
4258 | * lisp.h: Include decompress.c support. |
4259 | ||
4260 | * emacs.c (main): Include decompress.c support. | |
4261 | ||
4262 | * Makefile.in: Include -lz if present. | |
4263 | ||
d2d699ac JD |
4264 | 2013-08-11 Jan Djärv <jan.h.d@swipnet.se> |
4265 | ||
f90e3ebd JD |
4266 | * nsmenu.m (ns_update_menubar): Call fillWithWidgetValue:frame: |
4267 | (initWithTitle:): Initialize frame to 0. | |
4268 | (fillWithWidgetValue:): Call fillWithWidgetValue:frame. | |
068f9124 | 4269 | (fillWithWidgetValue:frame:): Rename from |
f90e3ebd JD |
4270 | fillWithWidgetValue:setDelegate, call initWithTile:frame: if f. |
4271 | ||
4272 | * nsterm.h (EmacsMenu): fillWithWidgetValue:setDelegate renamed to | |
4273 | fillWithWidgetValue:frame: | |
4274 | ||
423d3b3f JD |
4275 | * nsfns.m (Fns_convert_utf8_nfd_to_nfc): Allocate and release pool to |
4276 | remove memory leak warnings. | |
4277 | ||
d2d699ac JD |
4278 | * nsterm.m (menu_pending_title, ns_get_pending_menu_title): Remove. |
4279 | (ns_check_menu_open): Handle menu == nil. Remove assignment to | |
4280 | menu_pending_title. | |
4281 | ||
4282 | * nsmenu.m (ns_update_menubar): Call fillWithWidgetValue:setDelegate. | |
4283 | (x_activate_menubar): Update the whole menu. | |
4284 | (trackingNotification:): Call ns_check_menu_open if tracking ends. | |
4285 | (menuWillOpen:): Increment trackingMenu. For OSX <= 10.6, exit if | |
4286 | current event is not NSSystemDefined (Bug#15001). | |
4287 | Call ns_check_menu_open only if trackingMenu is 2. | |
4288 | (menuDidClose:): New method, decrease trackingMenu. | |
4289 | (fillWithWidgetValue:setDelegate:): New method. | |
4290 | (fillWithWidgetValue:): Call the above. | |
4291 | ||
4292 | * nsterm.h (EmacsMenu): Add fillWithWidgetValue:setDelegate: | |
4293 | ||
7d652d97 PE |
4294 | 2013-08-11 Paul Eggert <eggert@cs.ucla.edu> |
4295 | ||
4296 | Omit some unnecessary casts. | |
4297 | Many of these go back to the old pre-C89 days, when they may have | |
4298 | been needed, but we've been assuming C89 or later for a while now. | |
4299 | * alloc.c (live_string_p, live_cons_p, live_symbol_p) | |
4300 | (live_float_p, live_misc_p, live_vector_p): | |
4301 | * buffer.c (compare_overlays, cmp_for_strings, mmap_find) | |
4302 | (mmap_alloc, alloc_buffer_text, enlarge_buffer_text) | |
4303 | (defvar_per_buffer): | |
4304 | * callint.c (Fcall_interactively): | |
4305 | * doc.c (Fsubstitute_command_keys): | |
4306 | * filelock.c (get_boot_time): | |
4307 | * frame.c (xrdb_get_resource): | |
4308 | * gtkutil.c (hierarchy_ch_cb, qttip_cb, style_changed_cb) | |
4309 | (delete_cb, xg_dialog_response_cb, xg_maybe_add_timer) | |
4310 | (xg_get_file_name_from_selector, menuitem_destroy_callback) | |
4311 | (menuitem_highlight_callback, menu_destroy_callback) | |
4312 | (xg_update_menu_item, xg_modify_menubar_widgets, menubar_map_cb) | |
4313 | (xg_tool_bar_callback, xg_get_tool_bar_widgets) | |
4314 | (xg_tool_bar_detach_callback, xg_tool_bar_attach_callback) | |
4315 | (xg_tool_bar_help_callback, tb_size_cb): | |
4316 | * image.c (xpm_alloc_color, png_read_from_memory) | |
4317 | (png_read_from_file, png_load_body, our_memory_skip_input_data) | |
4318 | (jpeg_memory_src, jpeg_file_src, imagemagick_load_image) | |
4319 | (syms_of_image): | |
4320 | * keymap.c (describe_map): | |
4321 | * nsfns.m (Fns_display_monitor_attributes_list): | |
4322 | * nsmenu.m (process_dialog:): | |
4323 | * nsterm.m (hold_event): | |
4324 | * process.c (wait_reading_process_output): | |
4325 | * regex.c (REGEX_REALLOCATE, re_set_registers, re_exec, regexec): | |
4326 | * scroll.c (do_direct_scrolling, scrolling_1): | |
4327 | * termcap.c (tgetent): | |
4328 | * window.c (check_window_containing, add_window_to_list) | |
4329 | (freeze_window_starts): | |
4330 | * xdisp.c (compare_overlay_entries, vmessage): | |
4331 | * xfns.c (x_window, x_get_monitor_attributes_xinerama) | |
4332 | (x_get_monitor_attributes_xrandr) | |
4333 | (Fx_display_monitor_attributes_list, x_display_info_for_name) | |
4334 | (Fx_open_connection, file_dialog_cb, file_dialog_unmap_cb): | |
4335 | * xfont.c (xfont_match, xfont_open): | |
4336 | * xmenu.c (x_menu_wait_for_event, menu_highlight_callback) | |
4337 | (menubar_selection_callback, menu_position_func) | |
4338 | (popup_selection_callback, create_and_show_popup_menu) | |
4339 | (dialog_selection_callback, create_and_show_dialog): | |
4340 | * xrdb.c (x_get_string_resource): | |
4341 | (main) [TESTRM]: | |
4342 | * xsmfns.c (x_session_check_input): | |
4343 | * xterm.c (x_draw_glyphless_glyph_string_foreground) | |
4344 | (xm_scroll_callback, xg_scroll_callback, xg_end_scroll_callback) | |
4345 | (xaw_jump_callback, xaw_scroll_callback): | |
4346 | Omit unnecessary casts. | |
4347 | ||
9acc1074 PE |
4348 | 2013-08-10 Paul Eggert <eggert@cs.ucla.edu> |
4349 | ||
4350 | Minor string-length refactoring. | |
4351 | * alloc.c (xstrdup): Use memcpy, not strcpy, since the length's known. | |
4352 | * frame.c (make_monitor_attribute_list): | |
4353 | Prefer build_string to strlen + make_string. | |
4354 | ||
361c0eb8 JD |
4355 | 2013-08-10 Jan Djärv <jan.h.d@swipnet.se> |
4356 | ||
4357 | * xterm.c (x_error_handler): Also ignore BadWindow for X_SetInputFocus, | |
4358 | don't check minor_code (Bug#14417). | |
4359 | ||
14ba0822 EZ |
4360 | 2013-08-09 Eli Zaretskii <eliz@gnu.org> |
4361 | ||
4362 | * xdisp.c (draw_glyphs): Don't compare row pointers, compare row | |
4363 | vertical positions instead. This avoids calling MATRIX_ROW with | |
4364 | row numbers that are possibly beyond valid limits. (Bug#15064) | |
4365 | ||
309f24d1 DA |
4366 | 2013-08-09 Dmitry Antipov <dmantipov@yandex.ru> |
4367 | ||
4368 | Use xstrdup and build_unibyte_string where applicable. | |
4369 | * alloc.c (xstrdup): Tiny cleanup. Add eassert. | |
4370 | * xfns.c (x_window): | |
4371 | * xrdb.c (x_get_customization_string): | |
4372 | * xterm.c (xim_initialize): | |
4373 | * w32fns.c (w32_window): Use xstrdup. | |
4374 | (w32_display_monitor_attributes_list): | |
4375 | * emacs.c (init_cmdargs): | |
4376 | * keyboard.c (PUSH_C_STR): | |
4377 | * nsfont.m (nsfont_open): | |
4378 | * sysdep.c (system_process_attributes): | |
4379 | * w32.c (system_process_attributes): | |
4380 | * xdisp.c (message1, message1_nolog): Use build_unibyte_string. | |
4381 | ||
55902276 EZ |
4382 | 2013-08-09 Eli Zaretskii <eliz@gnu.org> |
4383 | ||
4384 | * w32.c (PEXCEPTION_POINTERS, PEXCEPTION_RECORD, PCONTEXT): Define | |
4385 | variables of these types so that GDB would know about them, as aid | |
4386 | for debugging fatal exceptions. (Bug#15024) See also | |
4387 | http://sourceware.org/ml/gdb/2013-08/msg00010.html for related | |
4388 | discussions. | |
4389 | ||
10bf7f5a JD |
4390 | 2013-08-08 Jan Djärv <jan.h.d@swipnet.se> |
4391 | ||
4392 | * nsterm.m (ns_update_begin): Don't change clip path if it would be | |
4393 | larger than the NSWindow (Bug#14934). | |
4394 | ||
65620264 DA |
4395 | 2013-08-08 Dmitry Antipov <dmantipov@yandex.ru> |
4396 | ||
4397 | Redesign redisplay interface to drop global variable updated_window. | |
4398 | Always pass currently updated window as a parameter to update routines. | |
4399 | * dispextern.h (updated_window): Remove declaration. | |
4400 | (struct redisplay_interface): Pass window parameter to | |
4401 | write_glyphs, insert_glyphs, clear_end_of_line, cursor_to | |
4402 | and after_update_window_hook. | |
4403 | (x_write_glyphs, x_insert_glyphs, x_clear_end_of_line, x_cursor_to): | |
4404 | Adjust prototypes. | |
4405 | * dispnew.c (updated_window): Remove. | |
4406 | (redraw_overlapped_rows, update_marginal_area, update_text_area) | |
4407 | (update_window_line): Adjust to match redisplay interface changes. | |
4408 | * nsterm.m (ns_update_window_begin, ns_update_window_end) | |
4409 | (ns_scroll_run, ns_after_update_window_line): | |
4410 | * w32term.c (x_update_window_begin, x_update_window_end) | |
4411 | (x_after_update_window_line, x_scroll_run): | |
4412 | * xterm.c (x_update_window_begin, x_update_window_end) | |
4413 | (x_after_update_window_line, x_scroll_run): | |
4414 | * xdisp.c (x_write_glyphs, x_insert_glyphs, x_clear_end_of_line): | |
4415 | Likewise. Adjust comments where appropriate. | |
4416 | (x_cursor_to): Simplify because this is always called during window | |
4417 | update (but install debugging check anyway). | |
4418 | (expose_window): Check must_be_updated_p flag to see whether this | |
4419 | function is called during window update. | |
4420 | ||
628fdc56 DA |
4421 | 2013-08-08 Dmitry Antipov <dmantipov@yandex.ru> |
4422 | ||
4423 | Do not reset window modification event counters excessively. | |
4424 | These leftovers and poor man's tricky methods to catch extra | |
4425 | redisplay's attention are no longer needed. | |
4426 | * frame.c (set_menu_bar_lines_1): | |
4427 | * minibuf.c (read_minibuf_unwind): | |
4428 | * window.c (Fset_window_start, set_window_buffer, window_resize_apply) | |
4429 | (grow_mini_window, shrink_mini_window, window_scroll_pixel_based) | |
4430 | (window_scroll_line_based, Fset_window_configuration): | |
4431 | * xdisp.c (redisplay_window): Do not reset last_modified and | |
4432 | last_overlay_modified counters. | |
4433 | ||
8fd9c92e JD |
4434 | 2013-08-07 Jan Djärv <jan.h.d@swipnet.se> |
4435 | ||
4436 | * xselect.c (x_send_client_event): Set send_event and serial, memset | |
4437 | data.l as it might be bigger than data.b. Use 24 bit mask to | |
4438 | XSendEvent (Bug#15034). | |
4439 | ||
0ee18172 EZ |
4440 | 2013-08-07 Eli Zaretskii <eliz@gnu.org> |
4441 | ||
4442 | * xdisp.c (prepare_menu_bars): Don't call x_consider_frame_title | |
4443 | for TTY frames that are not the top frame on their console. | |
4444 | (Bug#14616) | |
4445 | ||
16ddd1a6 MR |
4446 | 2013-08-07 Martin Rudalics <rudalics@gmx.at> |
4447 | ||
4448 | * w32term.c (w32fullscreen_hook): Really maximize frame when | |
4449 | asked for (Bug#14841). | |
4450 | ||
d2a95ffb DA |
4451 | 2013-08-07 Dmitry Antipov <dmantipov@yandex.ru> |
4452 | ||
4453 | Prefer selected_window to Fselected_window, likewise for frames. | |
4454 | * buffer.c (Fbuffer_swap_text): | |
4455 | * data.c (Fvariable_binding_locus): | |
4456 | * window.c (run_window_configuration_change_hook): Adjust users. | |
4457 | * w16select.c (Fw16_set_clipboard_data, Fw16_get_clipboard_data): | |
4458 | Use decode_live_frame. | |
4459 | ||
170da1ec DA |
4460 | 2013-08-07 Dmitry Antipov <dmantipov@yandex.ru> |
4461 | ||
4462 | Be more careful if selected window shows the buffer other than current, | |
4463 | use window_outdated only if this is not so. This change should also | |
4464 | address some weird issues discussed in Bug#13012. | |
4465 | * window.h (window_outdated): New prototype. | |
4466 | * window.c (window_outdated): Now here. Convert from static and | |
4467 | always assume window's buffer. | |
4468 | (Fwindow_end, Fwindow_line_height): Use it. | |
4469 | * xdisp.c (reconsider_clip_changes): Remove prototype, drop 2nd arg | |
4470 | and always assume window's buffer. | |
4471 | (redisplay_window): Adjust user. | |
e5eefe9b | 4472 | (redisplay_internal): Call to reconsider_clip_changes once and |
170da1ec DA |
4473 | check whether mode line should be updated only if selected window |
4474 | shows current buffer. | |
4475 | (run_window_scroll_functions): Use eassert for debugging check. | |
4476 | (Fmove_point_visually, note_mouse_highlight): Use window_outdated. | |
4477 | ||
56b5d5b1 DA |
4478 | 2013-08-06 Dmitry Antipov <dmantipov@yandex.ru> |
4479 | ||
4480 | * window.c (window_scroll, window_scroll_pixel_based) | |
4481 | (window_scroll_line_based): Use bool for booleans. | |
4482 | ||
2878ba7e PE |
4483 | 2013-08-06 Paul Eggert <eggert@cs.ucla.edu> |
4484 | ||
4485 | * process.c: Fix minor off-by-one issues in descriptor counts. | |
4486 | This shouldn't fix any real bugs, but it cleans up the code a bit. | |
4487 | (max_process_desc, max_input_desc): -1, not 0, means none. | |
4488 | All uses changed. | |
4489 | (delete_input_desc): New function. | |
4490 | (delete_write_fd, delete_keyboard_wait_descriptor): Use it. | |
4491 | (deactivate_process): Scan backwards when recomuting max_process_desc; | |
4492 | that should be faster. | |
4493 | (init_process_emacs): Initialize max_input_desc. | |
4494 | ||
e30b79c1 DA |
4495 | 2013-08-06 Dmitry Antipov <dmantipov@yandex.ru> |
4496 | ||
4497 | Use region cache to speedup bidi_find_paragraph_start. | |
4498 | * buffer.h (struct buffer): New member bidi_paragraph_cache. | |
4499 | Rename cache_long_line_scans to cache_long_scans. | |
4500 | * buffer.c (bset_cache_long_line_scans): Rename to | |
4501 | bset_cache_long_scans. | |
4502 | (Fget_buffer_create, Fmake_indirect_buffer, Fkill_buffer) | |
4503 | (Fbuffer_swap_text, init_buffer_once): Take bidi_paragraph_cache | |
4504 | into account. | |
4505 | (syms_of_buffer): Rename cache-long-line-scans to | |
4506 | cache-long-scans. Adjust docstring. | |
4507 | * search.c (newline_cache_on_off): | |
4508 | * indent.c (width_run_cache_on_off): Adjust users. | |
4509 | * bidi.c (bidi_paragraph_cache_on_off): New function. | |
4510 | (bidi_find_paragraph_start): Use bidi_paragraph_cache if needed. | |
068f9124 SM |
4511 | * insdel.c (prepare_to_modify_buffer): |
4512 | Invalidate bidi_paragraph_cache if enabled. | |
e30b79c1 | 4513 | |
00012b86 DA |
4514 | 2013-08-06 Dmitry Antipov <dmantipov@yandex.ru> |
4515 | ||
4516 | Invalidate region caches only if buffer text is going to be changed. | |
4517 | * lisp.h (modify_region_1): Remove 3rd arg and rename to... | |
4518 | (modify_text): ...new prototype. | |
4519 | (prepare_to_modify_buffer_1): New prototype. | |
4520 | * textprop.c (modify_region): Rename to... | |
4521 | (modify_text_properties): ...new function. | |
4522 | (add_text_properties_1, set_text_properties, Fremove_text_properties) | |
4523 | (Fremove_list_of_text_properties): Adjust users. | |
4524 | * insdel.c (modify_region_1): Remove 3rd arg and reimplement as... | |
4525 | (modify_text): ...new function. | |
4526 | (prepare_to_modify_buffer): Reimplement mostly as a wrapper for... | |
4527 | (prepare_to_modify_buffer_1): ...new function. | |
4528 | * casefiddle.c (casify_region): | |
4529 | * editfns.c (Fsubst_char_in_region, Ftranslate_region_internal) | |
4530 | (Ftranspose_regions): Use modify_text. | |
4531 | ||
dc6c0eda SM |
4532 | 2013-08-05 Stefan Monnier <monnier@iro.umontreal.ca> |
4533 | ||
4534 | * lisp.mk (lisp): Add nadvice.elc. | |
4535 | ||
8f3a2c26 DA |
4536 | 2013-08-05 Dmitry Antipov <dmantipov@yandex.ru> |
4537 | ||
4538 | New macro to iterate over live buffers similar to frames. | |
4539 | * buffer.h (FOR_EACH_LIVE_BUFFER): New macro. | |
4540 | (Vbuffer_alist, Qpriority, Qbefore_string, Qafter_string): | |
4541 | Declare buffer-related variables here to offload lisp.h. | |
4542 | * buffer.c (Vbuffer_alist): Adjust comment. | |
4543 | (Fget_file_buffer, get_truename_buffer, Fother_buffer) | |
4544 | (other_buffer_safely): | |
4545 | * data.c (store_symval_forwarding): | |
4546 | * dispnew.c (Fframe_or_buffer_changed_p): | |
4547 | * fileio.c (Fdo_auto_save): | |
4548 | * filelock.c (unlock_all_files): | |
4549 | * minibuf.c (read_minibuf): Use FOR_EACH_LIVE_BUFFER. | |
4550 | ||
e0fdb694 PE |
4551 | 2013-08-04 Paul Eggert <eggert@cs.ucla.edu> |
4552 | ||
4553 | Fix some minor races in hosts lacking mkostemp (Bug#15015). | |
4554 | * callproc.c (create_temp_file): | |
4555 | * filelock.c (create_lock_file): | |
4556 | Assume mkostemp, since it's now provided by Gnulib. | |
4557 | ||
63f5c6c2 EZ |
4558 | 2013-08-04 Eli Zaretskii <eliz@gnu.org> |
4559 | ||
4560 | * w32.c (mkostemp): New function. | |
4561 | (mktemp): Remove, no longer used. Most of the code reused in | |
4562 | mkostemp. (Bug#15015) | |
484ab239 | 4563 | (mktemp): Don't undef. |
63f5c6c2 | 4564 | |
f0b79313 DA |
4565 | 2013-08-04 Dmitry Antipov <dmantipov@yandex.ru> |
4566 | ||
4567 | * dispnew.c (glyph_matrix_count, glyph_pool_count): | |
4568 | Move under GLYPH_DEBUG and ENABLE_CHECKING. | |
4569 | (new_glyph_matrix, free_glyph_matrix, new_glyph_pool) | |
4570 | (free_glyph_pool, check_glyph_memory): Likewise for | |
4571 | all users. Adjust comments where appropriate. | |
4572 | ||
98f638d6 PE |
4573 | 2013-08-03 Paul Eggert <eggert@cs.ucla.edu> |
4574 | ||
4575 | * composite.h: Minor fixups. | |
4576 | (composition_registered_p): Rename from COMPOSITION_REGISTERD_P | |
4577 | to fix a misspelling, and change it to an inline function while | |
4578 | we're at it (it need not be a macro). All uses changed. | |
4579 | (composition_method, composition_valid_p): | |
4580 | Rewrite to avoid assignments in if-conditions. | |
4581 | ||
75c59fb3 DA |
4582 | 2013-08-03 Dmitry Antipov <dmantipov@yandex.ru> |
4583 | ||
4584 | Do not use global Lisp_Object in composition macros. | |
4585 | * composite.h (composition_temp): Remove declaration. | |
4586 | (COMPOSITION_METHOD, COMPOSITION_VALID_P): Replace with... | |
4587 | (composition_method, composition_valid_p): ...inline functions. | |
416a3e01 | 4588 | (compose_region): Remove the leftover. |
75c59fb3 DA |
4589 | * composite.c (composition_temp): Remove. |
4590 | (run_composition_function, update_compositions) | |
4591 | (composition_compute_stop_pos, composition_adjust_point) | |
4592 | (Ffind_composition_internal): | |
4593 | * coding.c (handle_composition_annotation): | |
4594 | * xdisp.c (handle_composition_prop, check_point_in_composition): | |
4595 | Related users changed. | |
4596 | ||
a10c8269 DA |
4597 | 2013-08-03 Dmitry Antipov <dmantipov@yandex.ru> |
4598 | ||
4599 | Drop FRAME_PTR typedef. | |
4600 | * composite.c, font.c, font.h, fontset.c, fontset.h, frame.c, frame.h: | |
4601 | * ftfont.c, ftxfont.c, gtkutil.c, gtkutil.h, image.c, keyboard.c: | |
4602 | * menu.c, menu.h, msdos.c, nsfns.m, nsfont.m, nsmenu.m, nsterm.h: | |
4603 | * nsterm.m, scroll.c, term.c, w32fns.c, w32font.c, w32font.h: | |
4604 | * w32inevt.c, w32inevt.h, w32menu.c, w32notify.c, w32term.c, w32term.h: | |
4605 | * w32uniscribe.c, w32xfns.c, widget.c, window.c, xdisp.c, xfaces.c: | |
4606 | * xfns.c, xfont.c, xftfont.c, xmenu.c, xselect.c, xterm.c: | |
4607 | All related users changed. | |
4608 | ||
a104f656 SM |
4609 | 2013-08-02 Stefan Monnier <monnier@iro.umontreal.ca> |
4610 | ||
4611 | * eval.c (default_toplevel_binding): New function. | |
4612 | (Fdefvar): Use it. | |
4613 | (unbind_to, backtrace_eval_unrewind): Do a bit of CSE simplification. | |
4614 | (Fdefault_toplevel_value, Fset_default_toplevel_value): New subrs. | |
4615 | (syms_of_eval): Export them. | |
4616 | * data.c (Fdefault_value): Micro cleanup. | |
4617 | * term.c (init_tty): Use "false". | |
4618 | ||
4b5c9326 DA |
4619 | 2013-08-02 Dmitry Antipov <dmantipov@yandex.ru> |
4620 | ||
4621 | Fix X GC leak in GTK and raw (no toolkit) X ports. | |
4622 | * xterm.c (x_free_frame_resources): If white and black relief | |
4623 | GCs are allocated, always free them here. | |
4624 | * xfns.c (x_make_gc): Omit redundant initialization. | |
4625 | * widget.c (create_frame_gcs): Remove the leftover. | |
4626 | (EmacsFrameDestroy): Do nothing because all GCs are now freed | |
4627 | in x_free_frame_resources. | |
4628 | ||
b19aa636 JD |
4629 | 2013-08-02 Jan Djärv <jan.h.d@swipnet.se> |
4630 | ||
4631 | * nsterm.m (windowWillResize:toSize:): Only change title if | |
4632 | ! maximizing_resize && FULLSCREEN_NONE (Bug#15005). strdup title before | |
4633 | modifying it. | |
4634 | (viewDidEndLiveResize): New method. | |
4635 | ||
4636 | * nsterm.h (EmacsView): Add maximizing_resize, put it and old_title | |
4637 | inside NS_IMPL_COCOA. | |
4638 | ||
af1f7e06 DA |
4639 | 2013-08-02 Dmitry Antipov <dmantipov@yandex.ru> |
4640 | ||
4641 | * insdel.c (adjust_after_replace, replace_range, del_range_2): | |
4642 | Do not check whether undo is enabled because record_insert and | |
4643 | record_delete does that themselves. | |
4644 | ||
65b02bb9 DA |
4645 | 2013-08-02 Dmitry Antipov <dmantipov@yandex.ru> |
4646 | ||
4647 | * xterm.h (struct x_output) [HAVE_X_I18N]: Remove xic_base_fontname | |
4648 | member which is not really used any more. | |
4649 | (FRAME_XIC_BASE_FONTNAME): Remove. | |
4650 | * xfns.c (xic_free_fontset): Adjust user. | |
4651 | * xmenu.c (mouse_position_for_popup, x_activate_menubar) | |
4652 | (update_frame_menubar, set_frame_menubar, free_frame_menubar) | |
4653 | (create_and_show_popup_menu, xmenu_show, create_and_show_dialog) | |
4654 | (xdialog_show): Use eassert for debugging check. | |
7ee0f047 | 4655 | * w32term.c (x_unfocus_frame): Remove unused dummy function. |
65b02bb9 | 4656 | |
6318cde0 PE |
4657 | 2013-08-01 Paul Eggert <eggert@cs.ucla.edu> |
4658 | ||
4659 | * fileio.c, fns.c (merge): Move extern decl from here ... | |
4660 | * lisp.h (merge): ... to here. | |
4661 | ||
6c1a09ba DA |
4662 | 2013-08-01 Dmitry Antipov <dmantipov@yandex.ru> |
4663 | ||
4664 | Fix last font-related change. | |
4665 | * w32font.h (w32font_list_internal, w32font_match_internal): | |
4666 | Fix prototype. | |
4667 | * w32uniscribe.c (uniscribe_list, uniscribe_match): | |
4668 | (uniscribe_list_family): Adjust to match font API change. | |
4669 | MS-Windows breakage reported by Juanma Barranquero <lekktu@gmail.com> | |
4670 | at http://lists.gnu.org/archive/html/emacs-devel/2013-08/msg00006.html. | |
4671 | ||
f8c20208 DA |
4672 | 2013-08-01 Dmitry Antipov <dmantipov@yandex.ru> |
4673 | ||
4674 | * frame.h (FRAME_MOUSE_UPDATE): | |
4675 | * nsterm.m (ns_frame_up_to_date): Omit redundant check | |
4676 | whether hlinfo->mouse_face_mouse_frame is non-NULL. | |
4677 | ||
fdb396e2 DA |
4678 | 2013-08-01 Dmitry Antipov <dmantipov@yandex.ru> |
4679 | ||
4680 | Avoid redundant Lisp_Object <-> struct frame conversions in font API. | |
4681 | * font.h (struct font_driver): Change list, match, and list_family | |
4682 | functions to accept struct frame * as first arg. | |
068f9124 SM |
4683 | * font.c (font_score, font_compare, font_sort_entities): |
4684 | Remove prototypes. | |
fdb396e2 DA |
4685 | (font_sort_entities, font_list_entities, font_select_entity): |
4686 | (font_find_for_lface, Flist_fonts, Ffont_family_list): Adjust to | |
4687 | match font API change. | |
4688 | * xfont.c (xfont_list, xfont_match, xfont_list_family): | |
4689 | * ftfont.c (ftfont_list, ftfont_match, ftfont_list_family): | |
4690 | * ftxfont.c (ftxfont_list, ftxfont_match): | |
4691 | * xftfont.c (xftfont_list, xftfont_match): | |
4692 | * nsfont.m (nsfont_list, nsfont_match, nsfont_list_family): | |
4693 | * w32font.c (w32font_list, w32font_match, w32font_list): | |
4694 | (w32font_list_internal, w32_font_match_internal): Likewise. | |
4695 | * xfaces.c (Fx_family_fonts): Adjust user. | |
4696 | ||
52b8a085 DA |
4697 | 2013-08-01 Dmitry Antipov <dmantipov@yandex.ru> |
4698 | ||
4699 | Do not use pure Xism x_wm_set_icon_position in non-X ports. | |
4700 | * frame.c (x_set_frame_parameters): Call to x_wm_set_icon_position | |
4701 | only if HAVE_X_WINDOWS is in use. | |
4702 | * frame.h (x_set_frame_parameters): Move under HAVE_X_WINDOWS. | |
4703 | * nsterm.m (x_wm_set_icon_position): Remove no-op. | |
4704 | * w32term.c (x_wm_set_icon_position): Likewise. | |
4705 | * w32fns.c (x_icon): Adjust user. | |
4706 | ||
c791c18e DA |
4707 | 2013-08-01 Dmitry Antipov <dmantipov@yandex.ru> |
4708 | ||
4709 | * xterm.c (last_mouse_press_frame): Remove the | |
4710 | leftover which is not really used any more. | |
4711 | (handle_one_xevent, syms_of_xterm): Adjust users. | |
1ca6cc28 DA |
4712 | (x_flush): Call XFlush once per each X display, not frame. |
4713 | This is better because this code always unconditionally skips | |
4714 | non-X frames in Vframe_list and issues the only XFlush if we | |
4715 | have more than one X frame on the same X display. | |
2f935d86 DA |
4716 | (any_help_event_p, x_draw_glyph_string_background, x_display_ok): |
4717 | Use bool for booleans. | |
4718 | (x_draw_glyph_string_background, cvt_string_to_pixel): | |
4719 | (cvt_pixel_dtor): Drop unnecessary prototypes. | |
4720 | * xterm.h (x_display_ok): Adjust prototype. | |
c791c18e | 4721 | |
f435830e DA |
4722 | 2013-07-31 Dmitry Antipov <dmantipov@yandex.ru> |
4723 | ||
4724 | Drop unnecessary functions that deals with frame pixel size. | |
4725 | * frame.h, msdos.h, w32term.h, xterm.h (x_pixel_width) | |
4726 | (x_pixel_height): Drop prototypes. | |
4727 | * msdos.c, nsfns.m, w32fns.c, xfns.c (x_pixel_width) | |
4728 | (x_pixel_height): Drop implementations. | |
4729 | * frame.c (Fframe_pixel_height): Use FRAME_PIXEL_HEIGHT | |
4730 | which should be always valid for window frame. | |
4731 | (Frame_pixel_width): Likewise with FRAME_PIXEL_WIDTH. | |
4732 | * w32menu.c (Fx_popup_dialog): | |
4733 | * xmenu.c (Fx_popup_dialog): Likewise for both. | |
4734 | ||
84231434 DA |
4735 | 2013-07-31 Dmitry Antipov <dmantipov@yandex.ru> |
4736 | ||
4737 | * frame.c (Fmake_terminal_frame): Use store_in_alist to setup | |
4738 | frame parameters and call to Fmodify_frame_parameters just once. | |
4c131798 DA |
4739 | (Fset_frame_height, Fset_frame_width): Mention nil frame in docstring. |
4740 | (Fset_frame_size, Fset_frame_position): Use decode_live_frame | |
4741 | and mention nil frame in docstring. | |
84231434 | 4742 | |
959067a1 DA |
4743 | 2013-07-31 Dmitry Antipov <dmantipov@yandex.ru> |
4744 | ||
4745 | * frame.c (make_frame, x_set_frame_parameters): Use bool for boolean. | |
4746 | (x_figure_window_size): Likewise. Adjust to return long. | |
4747 | (syms_of_frame): Do not DEFSYM Qterminal_live_p. | |
4748 | (toplevel): Move Qterminal_live_p to... | |
4749 | * terminal.c (toplevel): ...here, make it static, and... | |
4750 | (syms_of_terminal): ...DEFSYM here. | |
4751 | * frame.h (Qterminal_live_p): Remove declaration. | |
4752 | (make_frame, x_figure_window_size): Adjust prototype. | |
4753 | * nsfns.m (Fx_create_frame): Use long for window flags. | |
4754 | ||
f4b169ce PE |
4755 | 2013-07-30 Paul Eggert <eggert@cs.ucla.edu> |
4756 | ||
4757 | Fix tempfile bug on platforms lacking mkostemp and mkstemp (Bug#14986). | |
4758 | * callproc.c (create_temp_file) [! (HAVE_MKOSTEMP || HAVE_MKSTEMP)]: | |
4759 | Do not assume that emacs_close (INT_MAX) is a no-op. | |
4760 | ||
bee6a2c7 DA |
4761 | 2013-07-30 Dmitry Antipov <dmantipov@yandex.ru> |
4762 | ||
4763 | * xfaces.c (make_face_cache): For struct face_cache, prefer | |
4764 | xmalloc to xzalloc and so avoid redundant call to memset. | |
4765 | (Finternal_set_lisp_face_attribute): Fix comment typo and style. | |
4766 | ||
d7e6881a DA |
4767 | 2013-07-30 Dmitry Antipov <dmantipov@yandex.ru> |
4768 | ||
4769 | * fringe.c (draw_window_fringes, update_window_fringes) | |
4770 | (compute_fringe_widths): | |
4771 | * w32term.c (x_draw_glyph_string): | |
4772 | * window.c (candidate_window_p, Frecenter): | |
4773 | * xfaces.c (realize_basic_faces, realize_default_face) | |
4774 | (Fbitmap_space_p, Finternal_set_lisp_face_attribute) | |
4775 | (x_update_menu_appearance, face_attr_equal_p, lface_equal_p): | |
4776 | * xfns.c (x_set_cursor_color, xic_free_xfontset): | |
4777 | * xmenu.c (Fx_menu_bar_open_internal): | |
4778 | * xselect.c (x_reply_selection_request, Fx_get_atom_name): | |
4779 | * xsettings.c (xft_settings_event): | |
4780 | * xterm.c (x_draw_glyph_string, x_had_errors_p): | |
4781 | Use bool for booleans. Adjust style and comments where | |
4782 | appropriate. | |
4783 | * dispextern.h (draw_window_fringes, update_window_fringes) | |
4784 | (compute_fringe_widths): | |
4785 | * xterm.h (x_had_errors_p): Adjust prototype. | |
4786 | ||
ec3058af DA |
4787 | 2013-07-30 Dmitry Antipov <dmantipov@yandex.ru> |
4788 | ||
4789 | * frame.c (Fmodify_frame_parameters): Always check 2nd arg with | |
4790 | CHECK_LIST. Rewrite the loop to avoid useless local variable. | |
4791 | ||
218e0637 DA |
4792 | 2013-07-29 Dmitry Antipov <dmantipov@yandex.ru> |
4793 | ||
4794 | * fns.c (toplevel): Remove comment before Fsafe_length because | |
4795 | it checks for QUIT. | |
4796 | ||
e560aba9 PE |
4797 | 2013-07-28 Paul Eggert <eggert@cs.ucla.edu> |
4798 | ||
4799 | * frame.c (delete_frame): Avoid unnecessary 'this_f' test (Bug#14970). | |
4800 | ||
2e5ce5de EZ |
4801 | 2013-07-28 Eli Zaretskii <eliz@gnu.org> |
4802 | ||
4803 | * w32fns.c (w32_wnd_proc) <WM_IME_STARTCOMPOSITION>: Make sure the | |
4804 | frame which got the message is still alive, before dereferencing | |
4805 | its pointer. (Bug#14970) | |
4806 | ||
4807 | * frame.c (delete_frame): Test "this" frame's minibuffer window to | |
4808 | be a live window, before using it as such. (Bug#14970) | |
4809 | ||
e95da6d3 EZ |
4810 | 2013-07-27 Eli Zaretskii <eliz@gnu.org> |
4811 | ||
4812 | * w32term.c (w32_read_socket) <WM_KILLFOCUS>: Call | |
4813 | w32_detect_focus_change instead of doing part of its job by hand. | |
4814 | This fixes the problem whereby FOCUS_OUT events were not sent to | |
4815 | the event queue. | |
4816 | ||
a8f93651 EZ |
4817 | 2013-07-26 Eli Zaretskii <eliz@gnu.org> |
4818 | ||
fec92060 EZ |
4819 | * process.c (Fprocess_list): Doc fix. |
4820 | ||
a8f93651 EZ |
4821 | * w32term.c (w32_read_socket) <WM_EMACS_PAINT>: Warn about frame |
4822 | being re-exposed only if it didn't ask to become visible. | |
4823 | <WM_SIZE>: Under SIZE_RESTORED, only set the frame visible if it | |
4824 | was previously iconified. (Bug#14841) | |
4825 | (x_iconify_frame): Mark the frame iconified. | |
4826 | ||
d5a7a9d9 PE |
4827 | 2013-07-26 Paul Eggert <eggert@cs.ucla.edu> |
4828 | ||
4829 | Fix minor problems found by static checking. | |
4830 | * eval.c (get_backtrace_frame, backtrace_eval_unrewind): Now static. | |
4831 | (backtrace_eval_unrewind): ';' -> '{}' to pacify GCC. | |
4832 | ||
56ea7291 SM |
4833 | 2013-07-26 Stefan Monnier <monnier@iro.umontreal.ca> |
4834 | ||
4835 | * eval.c (set_specpdl_old_value): New function. | |
4836 | (unbind_to): Minor simplification. | |
4837 | (get_backtrace_frame): New function. | |
4838 | (Fbacktrace_frame): Use it. Add `base' argument. | |
4839 | (backtrace_eval_unrewind, Fbacktrace_eval): New functions. | |
4840 | (syms_of_eval): Export backtrace-eval. | |
4841 | * xterm.c (x_focus_changed): Simplify. | |
4842 | ||
9d611ffe PE |
4843 | 2013-07-25 Paul Eggert <eggert@cs.ucla.edu> |
4844 | ||
4845 | * fileio.c (Finsert_file_contents): Avoid double-close (Bug#14936). | |
4846 | ||
999c74e3 EZ |
4847 | 2013-07-24 Eli Zaretskii <eliz@gnu.org> |
4848 | ||
4849 | * xdisp.c (redisplay_window): Instead of moving point out of | |
4850 | scroll margin, reject the force_start method, and try scrolling | |
4851 | instead. (Bug#14780) | |
4852 | ||
198fa217 KB |
4853 | 2013-07-24 Ken Brown <kbrown@cornell.edu> |
4854 | ||
4855 | * alloc.c (make_save_ptr): Define if HAVE_NTGUI is defined | |
4856 | (Bug#14944). | |
4857 | ||
53840e55 PE |
4858 | 2013-07-24 Paul Eggert <eggert@cs.ucla.edu> |
4859 | ||
4860 | * eval.c (Fprogn): Do not check that BODY is a proper list. | |
4861 | This undoes the previous change. The check slows down the | |
4862 | interpreter, and is not needed to prevent a crash. See | |
4863 | <http://lists.gnu.org/archive/html/emacs-devel/2013-07/msg00693.html>. | |
4864 | ||
60967f56 GM |
4865 | 2013-07-23 Glenn Morris <rgm@gnu.org> |
4866 | ||
4867 | * Makefile.in ($(etc)/DOC, temacs$(EXEEXT)): Ensure etc/ exists. | |
4868 | ||
9ca960e2 PE |
4869 | 2013-07-23 Paul Eggert <eggert@cs.ucla.edu> |
4870 | ||
a29c3e6d PE |
4871 | Port to GNU/Linux systems with tinfo but not ncurses. |
4872 | * dispnew.c (init_display): Depend on USE_NCURSES, not GNU_LINUX, | |
4873 | to decide whether ncurses is being used. Without this change, | |
4874 | GCC complains about tgetent not being declared, on a system | |
4875 | that has tinfo installed but ncurses not installed. | |
4876 | ||
f274311c PE |
4877 | * eval.c (Fprogn): Check that BODY is a proper list. |
4878 | ||
16b0520a PE |
4879 | Tune UNEVALLED functions by using XCAR instead of Fcar, etc. |
4880 | * data.c (Fsetq_default): | |
4881 | * eval.c (Fif, Fcond, Fprog1, Fsetq, Fquote, Ffunction, Fdefvar) | |
4882 | (Fdefconst, FletX, Flet, Fwhile, Fcatch, Funwind_protect) | |
4883 | (Fcondition_case): | |
4884 | Tune by taking advantage of the fact that ARGS is always a list | |
4885 | when a function is declared to have UNEVALLED args. | |
4886 | ||
9ca960e2 PE |
4887 | * emacsgtkfixed.c: Port to GCC 4.6. |
4888 | GCC 4.6 complains about -Wunused-local-typedefs, introduced in 4.7. | |
4889 | ||
afacaa1b JB |
4890 | 2013-07-23 Juanma Barranquero <lekktu@gmail.com> |
4891 | ||
4892 | * callproc.c (child_setup)[!WINDOWSNT]: Move exec_errno and pid | |
4893 | here to silence compiler warnings. | |
4894 | ||
368a85a4 PE |
4895 | 2013-07-22 Paul Eggert <eggert@cs.ucla.edu> |
4896 | ||
4897 | * sysdep.c (frame) [__FreeBSD__]: #define to freebsd_frame | |
4898 | when including <sys/user.h>, to prevent Sparc/ARM machine/frame.h | |
4899 | from messing up Emacs's 'struct frame' (Bug#14923). | |
4900 | ||
f4e891b5 PE |
4901 | 2013-07-21 Paul Eggert <eggert@cs.ucla.edu> |
4902 | ||
4903 | * alloc.c (make_save_ptr_ptr): Define this function. | |
4904 | It was inadvertently omitted. It's needed only if | |
4905 | HAVE_MENUS && ! (USE_X_TOOLKIT || USE_GTK). | |
4906 | ||
96c8b65e JD |
4907 | 2013-07-21 Jan Djärv <jan.h.d@swipnet.se> |
4908 | ||
4909 | * nsterm.m (sendEvent:): Skip mouse moved if no dialog and no Emacs | |
4910 | frame have focus (Bug#14895). | |
4911 | ||
ee010797 PE |
4912 | 2013-07-21 Paul Eggert <eggert@cs.ucla.edu> |
4913 | ||
4914 | Avoid vfork-related deadlock more cleanly. | |
4915 | * callproc.c (child_setup): When the child's exec fails, output | |
4916 | the program name, as that's more useful. Use O_NONBLOCK to avoid | |
4917 | deadlock. | |
4918 | * process.c (create_process_1): Remove; no longer needed. | |
4919 | (create_process): Remove timer hack; no longer needed, now that | |
4920 | the child avoids deadlock. | |
4921 | ||
f0398ec1 | 4922 | 2013-07-20 Glenn Morris <rgm@gnu.org> |
8bfcc21a GM |
4923 | |
4924 | * image.c (Fimage_flush): Fix doc typo. | |
4925 | ||
b2a069c2 PE |
4926 | 2013-07-20 Paul Eggert <eggert@cs.ucla.edu> |
4927 | ||
6496aec9 PE |
4928 | Fix array bounds violation when pty allocation fails. |
4929 | * process.c (PTY_NAME_SIZE): New constant. | |
4930 | (pty_name): Remove static variable; it's now auto. | |
4931 | (allocate_pty): Define even if !HAVE_PTYS; that's simpler. | |
4932 | Take pty_name as an arg rather than using a static variable. | |
4933 | All callers changed. | |
4934 | (create_process): Recover pty_flag from process, not from volatile local. | |
4935 | (create_pty): Stay inside array even when pty allocation fails. | |
4936 | (Fmake_serial_process): Omit unnecessary initializaiton of pty_flag. | |
4937 | ||
b2a069c2 PE |
4938 | * lread.c (Fload): Avoid initialization only when lint checking. |
4939 | Mention that it's needed only for older GCCs. | |
4940 | ||
99107004 KH |
4941 | 2013-07-20 Kenichi Handa <handa@gnu.org> |
4942 | ||
4943 | * coding.c (CODING_ISO_FLAG_LEVEL_4): New macro. | |
4944 | (decode_coding_iso_2022): Check the single-shift area. (Bug#8522) | |
4945 | ||
6b1b199d AS |
4946 | 2013-07-20 Andreas Schwab <schwab@linux-m68k.org> |
4947 | ||
4948 | * lread.c (Fload): Avoid uninitialized warning. | |
4949 | ||
4195afc3 PE |
4950 | 2013-07-19 Paul Eggert <eggert@cs.ucla.edu> |
4951 | ||
3f5bef16 PE |
4952 | Fix some minor file descriptor leaks and related glitches. |
4953 | * filelock.c (create_lock_file) [!O_CLOEXEC]: Use fcntl with FD_CLOEXEC. | |
4954 | (create_lock_file): Use write, not emacs_write. | |
4955 | * image.c (slurp_file, png_load_body): | |
4956 | * process.c (Fnetwork_interface_list, Fnetwork_interface_info) | |
4957 | (server_accept_connection): | |
4958 | Don't leak an fd on memory allocation failure. | |
4959 | * image.c (slurp_file): Add a cheap heuristic for growing files. | |
4960 | * xfaces.c (Fx_load_color_file): Block input around the fopen too, | |
4961 | as that's what the other routines do. Maybe input need not be | |
4962 | blocked at all, but it's better to be consistent. | |
4963 | Avoid undefined behavior when strlen is zero. | |
4964 | ||
4195afc3 PE |
4965 | * alloc.c (staticpro): Avoid buffer overrun on repeated calls. |
4966 | (NSTATICS): Now a constant; doesn't need to be a macro. | |
4967 | ||
a1aeeffe RS |
4968 | 2013-07-19 Richard Stallman <rms@gnu.org> |
4969 | ||
4970 | * coding.c (decode_coding_utf_8): Add simple loop for fast | |
4971 | processing of ASCII characters. | |
4972 | ||
63b34baa PE |
4973 | 2013-07-19 Paul Eggert <eggert@cs.ucla.edu> |
4974 | ||
4975 | * conf_post.h (RE_TRANSLATE_P) [emacs]: Remove obsolete optimization. | |
4976 | ||
621dd9ac EZ |
4977 | 2013-07-19 Eli Zaretskii <eliz@gnu.org> |
4978 | ||
4979 | * keyboard.c (kbd_buffer_get_event): Use Display_Info instead of | |
4980 | unportable 'struct x_display_info'. | |
4981 | (DISPLAY_LIST_INFO): Delete macro: not needed, since Display_Info | |
4982 | is a portable type. | |
4983 | ||
1396ac86 PE |
4984 | 2013-07-19 Paul Eggert <eggert@cs.ucla.edu> |
4985 | ||
ab9980cd PE |
4986 | * sysdep.c [GNU_LINUX]: Fix fd and memory leaks and similar issues. |
4987 | (procfs_ttyname): Don't use uninitialized storage if emacs_fopen | |
4988 | or fscanf fails. | |
4989 | (system_process_attributes): Prefer plain char to unsigned char | |
4990 | when either will do. Clean up properly if interrupted or if | |
068f9124 SM |
4991 | memory allocations fail. Don't assume sscanf succeeds. |
4992 | Remove no-longer-needed workaround to stop GCC from whining. | |
4993 | Read command-line once, instead of multiple times. Check read status a | |
ab9980cd PE |
4994 | bit more carefully. |
4995 | ||
1396ac86 PE |
4996 | Fix obscure porting bug with varargs functions. |
4997 | The code assumed that int is treated like ptrdiff_t in a vararg | |
4998 | function, which is not a portable assumption. There was a similar | |
4999 | -- though these days less likely -- porting problem with various | |
5000 | assumptions that pointers of different types all smell the same as | |
5001 | far as vararg functions is conserved. To make this problem less | |
5002 | likely in the future, redo the API to use varargs functions. | |
5003 | * alloc.c (make_save_value): Remove this vararg function. | |
5004 | All uses changed to ... | |
5005 | (make_save_int_int_int, make_save_obj_obj_obj_obj) | |
5006 | (make_save_ptr_int, make_save_funcptr_ptr_obj, make_save_memory): | |
5007 | New functions. | |
5008 | (make_save_ptr): Rename from make_save_pointer, for consistency with | |
5009 | the above. Define only on platforms that need it. All uses changed. | |
5010 | ||
4d19d194 PE |
5011 | 2013-07-18 Paul Eggert <eggert@cs.ucla.edu> |
5012 | ||
5013 | * keyboard.c: Try to fix typos in previous change. | |
5014 | (DISPLAY_LIST_INFO): New macro. | |
5015 | (kbd_buffer_get_event): Do not access members that are not present | |
c7064f05 | 5016 | in X11. Revert inadvertent change of "!=" to "=". |
4d19d194 | 5017 | |
945c5bb1 JB |
5018 | 2013-07-18 Juanma Barranquero <lekktu@gmail.com> |
5019 | ||
5020 | * keyboard.c (kbd_buffer_get_event): | |
5021 | * w32term.c (x_focus_changed): Port FOCUS_(IN|OUT)_EVENT changes to W32. | |
5022 | Followup to 2013-07-16T11:41:06Z!jan.h.d@swipnet.se. | |
5023 | ||
f4b1eb36 PE |
5024 | 2013-07-18 Paul Eggert <eggert@cs.ucla.edu> |
5025 | ||
5e679a2c PE |
5026 | * filelock.c: Fix unlikely file descriptor leaks. |
5027 | (get_boot_time_1): Rework to avoid using emacs_open. | |
5028 | This doesn't actually fix a leak, but is better anyway. | |
5029 | (read_lock_data): Use read, not emacs_read. | |
5030 | ||
a8cd4836 PE |
5031 | * doc.c: Fix minor memory and file descriptor leaks. |
5032 | * doc.c (get_doc_string): Fix memory leak when doc file absent. | |
5033 | (get_doc_string, Fsnarf_documentation): | |
5034 | Fix file descriptor leak on error. | |
5035 | ||
ef30e638 PE |
5036 | * term.c: Fix minor fdopen-related file descriptor leaks. |
5037 | * term.c (Fresume_tty) [!MSDOS]: Close fd if fdopen (fd) fails. | |
5038 | (init_tty) [!DOS_NT]: Likewise. Also close fd if isatty (fd) fails. | |
5039 | ||
f4b1eb36 PE |
5040 | * charset.c: Fix file descriptor leaks and errno issues. |
5041 | Include <errno.h>. | |
5042 | (load_charset_map_from_file): Don't leak file descriptor on error. | |
5043 | Use plain record_xmalloc since the allocation is larger than | |
5044 | MAX_ALLOCA; that's simpler here. Simplify test for exhaustion | |
5045 | of entries. | |
5046 | * eval.c (record_unwind_protect_nothing): | |
5047 | * fileio.c (fclose_unwind): | |
5048 | New functions. | |
5049 | * lread.c (load_unwind): Remove. All uses replaced by fclose_unwind. | |
5050 | The replacement doesn't block input, but that no longer seems | |
5051 | necessary. | |
5052 | ||
b648c163 PE |
5053 | 2013-07-17 Paul Eggert <eggert@cs.ucla.edu> |
5054 | ||
a0931322 PE |
5055 | * lread.c: Fix file descriptor leaks and errno issues. |
5056 | (Fload): Close some races that leaked fds or streams when 'load' | |
5057 | was interrupted. | |
5058 | (Fload, openp): Report error number of last nontrivial failure to open. | |
5059 | ENOENT counts as trivial. | |
5060 | * eval.c (do_nothing, clear_unwind_protect, set_unwind_protect_ptr): | |
5061 | New functions. | |
5062 | * fileio.c (close_file_unwind): No need to test whether FD is nonnegative, | |
5063 | now that the function is always called with a nonnegative arg. | |
5064 | * lisp.h (set_unwind_protect_ptr, set_unwind_protect_int): Remove. | |
5065 | All uses replaced with ... | |
5066 | (clear_unwind_protect, set_unwind_protect_ptr): New decls. | |
5067 | ||
b648c163 PE |
5068 | A few more minor file errno-reporting bugs. |
5069 | * callproc.c (Fcall_process): | |
5070 | * doc.c (Fsnarf_documentation): | |
5071 | * fileio.c (Frename_file, Fadd_name_to_file, Fmake_symbolic_link): | |
5072 | * process.c (set_socket_option): | |
5073 | Don't let a constructor trash errno. | |
5074 | * doc.c: Include <errno.h>. | |
5075 | ||
b1dc4084 JB |
5076 | 2013-07-16 Juanma Barranquero <lekktu@gmail.com> |
5077 | ||
5078 | * w32fns.c (unwind_create_tip_frame): Fix declaration. | |
5079 | ||
c43843aa PE |
5080 | 2013-07-16 Paul Eggert <eggert@cs.ucla.edu> |
5081 | ||
50a30cce PE |
5082 | Fix w32 bug with call-process-region (Bug#14885). |
5083 | * callproc.c (Fcall_process_region): Pass nil, not "/dev/null", | |
5084 | to Fcall_process when the input is empty. This simplifies the | |
5085 | code a bit. It makes no difference on POSIXish platforms but | |
5086 | apparently it fixes a bug on w32. | |
5087 | ||
44e18199 | 5088 | Fix bug where insert-file-contents closes a file twice (Bug#14839). |
41d48a42 PE |
5089 | * fileio.c (close_file_unwind): Don't close if FD is negative; |
5090 | this can happen when unwinding a zapped file descriptor. | |
5091 | (Finsert_file_contents): Unwind-protect the fd before the point marker, | |
5092 | in case Emacs runs out of memory between the two unwind-protects. | |
5093 | Don't trash errno when closing FD. | |
5094 | Zap the FD in the specpdl when closing it, instead of deferring | |
5095 | the removal of the unwind-protect; this fixes a bug where a child | |
5096 | function unwinds the stack past us. | |
5097 | ||
27e498e6 PE |
5098 | New unwind-protect flavors to better type-check C callbacks. |
5099 | This also lessens the need to write wrappers for callbacks, | |
5100 | and the need for make_save_pointer. | |
5101 | * alloca.c (free_save_value): | |
5102 | * atimer.c (run_all_atimers): | |
5103 | Now extern. | |
5104 | * alloc.c (safe_alloca_unwind): | |
5105 | * atimer.c (unwind_stop_other_atimers): | |
5106 | * keyboard.c (cancel_hourglass_unwind) [HAVE_WINDOW_SYSTEM]: | |
5107 | * menu.c (cleanup_popup_menu) [HAVE_NS]: | |
5108 | * minibuf.c (choose_minibuf_frame_1): | |
5109 | * process.c (make_serial_process_unwind): | |
5110 | * xdisp.h (pop_message_unwind): | |
5111 | * xselect.c (queue_selection_requests_unwind): | |
5112 | Remove no-longer-needed wrapper. All uses replaced by the wrappee. | |
5113 | * alloca.c (record_xmalloc): | |
5114 | Prefer record_unwind_protect_ptr to record_unwind_protect with | |
5115 | make_save_pointer. | |
5116 | * alloca.c (Fgarbage_collect): | |
5117 | Prefer record_unwind_protect_void to passing a dummy. | |
5118 | * buffer.c (restore_buffer): | |
5119 | * window.c (restore_window_configuration): | |
5120 | * xfns.c, w32fns.c (do_unwind_create_frame) | |
5121 | New wrapper. All record-unwind uses of wrappee changed. | |
5122 | * buffer.c (set_buffer_if_live): | |
5123 | * callproc.c (call_process_cleanup, delete_temp_file): | |
5124 | * coding.c (code_conversion_restore): | |
5125 | * dired.c (directory_files_internal_w32_unwind) [WINDOWSNT]: | |
5126 | * editfns.c (save_excursion_restore) | |
5127 | (subst_char_in_region_unwind, subst_char_in_region_unwind_1) | |
5128 | (save_restriction_restore): | |
5129 | * eval.c (restore_stack_limits, un_autoload): | |
5130 | * fns.c (require_unwind): | |
5131 | * keyboard.c (recursive_edit_unwind, tracking_off): | |
5132 | * lread.c (record_load_unwind, load_warn_old_style_backquotes): | |
5133 | * macros.c (pop_kbd_macro, restore_menu_items): | |
5134 | * nsfns.m (unwind_create_frame): | |
5135 | * print.c (print_unwind): | |
5136 | * process.c (start_process_unwind): | |
5137 | * search.c (unwind_set_match_data): | |
5138 | * window.c (select_window_norecord, select_frame_norecord): | |
5139 | * xdisp.c (unwind_with_echo_area_buffer, unwind_format_mode_line) | |
5140 | (fast_set_selected_frame): | |
5141 | * xfns.c, w32fns.c (unwind_create_tip_frame): | |
5142 | Return void, not a dummy Lisp_Object. All uses changed. | |
5143 | * buffer.h (set_buffer_if_live): Move decl here from lisp.h. | |
5144 | * callproc.c (call_process_kill): | |
5145 | * fileio.c (restore_point_unwind, decide_coding_unwind) | |
5146 | (build_annotations_unwind): | |
5147 | * insdel.c (Fcombine_after_change_execute_1): | |
5148 | * keyboard.c (read_char_help_form_unwind): | |
5149 | * menu.c (unuse_menu_items): | |
5150 | * minibuf.c (run_exit_minibuf_hook, read_minibuf_unwind): | |
5151 | * sound.c (sound_cleanup): | |
5152 | * xdisp.c (unwind_redisplay): | |
5153 | * xfns.c (clean_up_dialog): | |
5154 | * xselect.c (x_selection_request_lisp_error, x_catch_errors_unwind): | |
5155 | Accept no args and return void, instead of accepting and returning | |
5156 | a dummy Lisp_Object. All uses changed. | |
5157 | * cygw32.c (fchdir_unwind): | |
5158 | * fileio.c (close_file_unwind): | |
5159 | * keyboard.c (restore_kboard_configuration): | |
5160 | * lread.c (readevalllop_1): | |
5161 | * process.c (wait_reading_process_output_unwind): | |
5162 | Accept int and return void, rather than accepting an Emacs integer | |
5163 | and returning a dummy object. In some cases this fixes an | |
5164 | unlikely bug when the corresponding int is outside Emacs integer | |
5165 | range. All uses changed. | |
5166 | * dired.c (directory_files_internal_unwind): | |
5167 | * fileio.c (do_auto_save_unwind): | |
5168 | * gtkutil.c (pop_down_dialog): | |
5169 | * insdel.c (reset_var_on_error): | |
5170 | * lread.c (load_unwind): | |
5171 | * xfns.c (clean_up_file_dialog): | |
5172 | * xmenu.c, nsmenu.m (pop_down_menu): | |
5173 | * xmenu.c (cleanup_widget_value_tree): | |
5174 | * xselect.c (wait_for_property_change_unwind): | |
5175 | Accept pointer and return void, rather than accepting an Emacs | |
5176 | save value encapsulating the pointer and returning a dummy object. | |
5177 | All uses changed. | |
5178 | * editfns.c (Fformat): Update the saved pointer directly via | |
5179 | set_unwind_protect_ptr rather than indirectly via make_save_pointer. | |
5180 | * eval.c (specpdl_func): Remove. All uses replaced by definiens. | |
5181 | (unwind_body): New function. | |
5182 | (record_unwind_protect): First arg is now a function returning void, | |
5183 | not a dummy Lisp_Object. | |
5184 | (record_unwind_protect_ptr, record_unwind_protect_int) | |
5185 | (record_unwind_protect_void): New functions. | |
5186 | (unbind_to): Support SPECPDL_UNWIND_PTR etc. | |
5187 | * fileio.c (struct auto_save_unwind): New type. | |
5188 | (do_auto_save_unwind): Use it. | |
5189 | (do_auto_save_unwind_1): Remove; subsumed by new do_auto_save_unwind. | |
5190 | * insdel.c (struct rvoe_arg): New type. | |
5191 | (reset_var_on_error): Use it. | |
5192 | * lisp.h (SPECPDL_UNWIND_PTR, SPECPDL_UNWIND_INT, SPECPDL_UNWIND_VOID): | |
5193 | New constants. | |
5194 | (specbinding_func): Remove; there are now several such functions. | |
5195 | (union specbinding): New members unwind_ptr, unwind_int, unwind_void. | |
5196 | (set_unwind_protect_ptr): New function. | |
5197 | * xselect.c: Remove unnecessary forward decls, to simplify maintenance. | |
5198 | ||
4e604a5d PE |
5199 | Be simpler and more consistent about reporting I/O errors. |
5200 | * fileio.c (Fcopy_file, Finsert_file_contents, Fwrite_region): | |
5201 | Say "Read error" and "Write error", rather than "I/O error", or | |
5202 | "IO error reading", or "IO error writing", when a read or write | |
5203 | error occurs. | |
5204 | * process.c (Fmake_network_process, wait_reading_process_output) | |
5205 | (send_process, Fprocess_send_eof, wait_reading_process_output): | |
5206 | Capitalize diagnostics consistently. Put "failed foo" at the | |
5207 | start of the diagnostic, so that we don't capitalize the | |
5208 | function name "foo". Consistently say "failed" for such | |
5209 | diagnostics. | |
5210 | * sysdep.c, w32.c (serial_open): Now accepts Lisp string, not C string. | |
5211 | All callers changed. This is so it can use report_file_error. | |
5212 | * sysdep.c (serial_open, serial_configure): Capitalize I/O | |
5213 | diagnostics consistently as above. | |
5214 | ||
a9757f6a PE |
5215 | * fileio.c (report_file_errno): Fix errno reporting bug. |
5216 | If the file name is neither null nor a pair, package it up as a | |
5217 | singleton list. All callers changed, both to this function and to | |
5218 | report_file_error. This fixes a bug where the memory allocator | |
5219 | invoked by list1 set errno so that the immediately following | |
5220 | report_file_error reported the wrong errno value. | |
5221 | ||
c43843aa PE |
5222 | Fix minor problems found by --enable-gcc-warnings. |
5223 | * frame.c (Fhandle_focus_in, Fhandle_focus_out): Return a value. | |
5224 | * keyboard.c (kbd_buffer_get_event): Remove unused local. | |
5225 | ||
18c26d81 JD |
5226 | 2013-07-16 Jan Djärv <jan.h.d@swipnet.se> |
5227 | ||
5228 | * xterm.c (x_focus_changed): Always generate FOCUS_IN_EVENT. | |
5229 | Set event->arg to Qt if switch-event shall be generated. | |
5230 | Generate FOCUS_OUT_EVENT for FocusOut if this is the focused frame. | |
5231 | ||
5232 | * termhooks.h (enum event_kind): Add FOCUS_OUT_EVENT. | |
5233 | ||
5234 | * nsterm.m (windowDidResignKey): If this is the focused frame, generate | |
5235 | FOCUS_OUT_EVENT. | |
5236 | ||
5237 | * keyboard.c (Qfocus_in, Qfocus_out): New static objects. | |
5238 | (make_lispy_focus_in, make_lispy_focus_out): Declare and define. | |
5239 | (kbd_buffer_get_event): For FOCUS_IN, make a focus_in event if no | |
5240 | switch frame event is made. Check ! NILP (event->arg) if X11 (moved | |
44e18199 | 5241 | from xterm.c). Make focus_out event for FOCUS_OUT_EVENT if NS or X11 |
18c26d81 JD |
5242 | and there is a focused frame. |
5243 | (head_table): Add focus-in and focus-out. | |
5244 | (keys_of_keyboard): Add focus-in and focus-out to Vspecial_event_map, | |
5245 | bind to handle-focus-in/out. | |
5246 | ||
5247 | * frame.c (Fhandle_focus_in, Fhandle_focus_out): New functions. | |
5248 | (Fhandle_switch_frame): Call Fhandle_focus_in. | |
5249 | (syms_of_frame): defsubr handle-focus-in/out. | |
5250 | ||
6c6f1994 PE |
5251 | 2013-07-16 Paul Eggert <eggert@cs.ucla.edu> |
5252 | ||
c7ddc792 PE |
5253 | Fix porting bug to older POSIXish platforms (Bug#14862). |
5254 | * sysdep.c (emacs_pipe): New function, that implements | |
5255 | pipe2 (fd, O_CLOEXEC) even on hosts that lack O_CLOEXEC. | |
5256 | This should port better to CentOS 5 and to Mac OS X 10.6. | |
5257 | All calls to pipe2 changed. | |
5258 | ||
6c6f1994 PE |
5259 | Prefer list1 (X) to Fcons (X, Qnil) when building lists. |
5260 | This makes the code easier to read and the executable a bit smaller. | |
5261 | Do not replace all calls to Fcons that happen to create lists, | |
5262 | just calls that are intended to create lists. For example, when | |
5263 | creating an alist that maps FOO to nil, use list1 (Fcons (FOO, Qnil)) | |
5264 | rather than list1 (list1 (FOO)) or Fcons (Fcons (FOO, Qnil), Qnil). | |
5265 | Similarly for list2 through list5. | |
5266 | * buffer.c (Fget_buffer_create, Fmake_indirect_buffer): | |
5267 | * bytecode.c (exec_byte_code): | |
5268 | * callint.c (quotify_arg, Fcall_interactively): | |
5269 | * callproc.c (Fcall_process, create_temp_file): | |
5270 | * charset.c (load_charset_map_from_file) | |
5271 | (Fdefine_charset_internal, init_charset): | |
5272 | * coding.c (get_translation_table, detect_coding_system) | |
5273 | (Fcheck_coding_systems_region) | |
5274 | (Fset_terminal_coding_system_internal) | |
5275 | (Fdefine_coding_system_internal, Fdefine_coding_system_alias): | |
5276 | * composite.c (update_compositions, Ffind_composition_internal): | |
5277 | * dired.c (directory_files_internal, file_name_completion) | |
5278 | (Fsystem_users): | |
5279 | * dispnew.c (Fopen_termscript, bitch_at_user, init_display): | |
5280 | * doc.c (Fsnarf_documentation): | |
5281 | * editfns.c (Fmessage_box): | |
5282 | * emacs.c (main): | |
5283 | * eval.c (do_debug_on_call, signal_error, maybe_call_debugger) | |
5284 | (Feval, eval_sub, Ffuncall, apply_lambda): | |
5285 | * fileio.c (make_temp_name, Fcopy_file, Faccess_file) | |
5286 | (Fset_file_selinux_context, Fset_file_acl, Fset_file_modes) | |
5287 | (Fset_file_times, Finsert_file_contents) | |
5288 | (Fchoose_write_coding_system, Fwrite_region): | |
5289 | * fns.c (Flax_plist_put, Fyes_or_no_p, syms_of_fns): | |
5290 | * font.c (font_registry_charsets, font_parse_fcname) | |
5291 | (font_prepare_cache, font_update_drivers, Flist_fonts): | |
5292 | * fontset.c (Fset_fontset_font, Ffontset_info, syms_of_fontset): | |
5293 | * frame.c (make_frame, Fmake_terminal_frame) | |
5294 | (x_set_frame_parameters, x_report_frame_params) | |
5295 | (x_default_parameter, Fx_parse_geometry): | |
5296 | * ftfont.c (syms_of_ftfont): | |
5297 | * image.c (gif_load): | |
5298 | * keyboard.c (command_loop_1): | |
5299 | * keymap.c (Fmake_keymap, Fmake_sparse_keymap, access_keymap_1) | |
5300 | (Fcopy_keymap, append_key, Fcurrent_active_maps) | |
5301 | (Fminor_mode_key_binding, accessible_keymaps_1) | |
5302 | (Faccessible_keymaps, Fwhere_is_internal): | |
5303 | * lread.c (read_emacs_mule_char): | |
5304 | * menu.c (find_and_return_menu_selection): | |
5305 | * minibuf.c (get_minibuffer): | |
5306 | * nsfns.m (Fns_perform_service): | |
5307 | * nsfont.m (ns_script_to_charset): | |
5308 | * nsmenu.m (ns_popup_dialog): | |
5309 | * nsselect.m (ns_get_local_selection, ns_string_from_pasteboard) | |
5310 | (Fx_own_selection_internal): | |
5311 | * nsterm.m (append2): | |
5312 | * print.c (Fredirect_debugging_output) | |
5313 | (print_prune_string_charset): | |
5314 | * process.c (Fdelete_process, Fprocess_contact) | |
5315 | (Fformat_network_address, set_socket_option) | |
5316 | (read_and_dispose_of_process_output, write_queue_push) | |
5317 | (send_process, exec_sentinel): | |
5318 | * sound.c (Fplay_sound_internal): | |
5319 | * textprop.c (validate_plist, add_properties) | |
5320 | (Fput_text_property, Fadd_face_text_property) | |
5321 | (copy_text_properties, text_property_list, syms_of_textprop): | |
5322 | * unexaix.c (report_error): | |
5323 | * unexcoff.c (report_error): | |
5324 | * unexsol.c (unexec): | |
5325 | * xdisp.c (redisplay_tool_bar, store_mode_line_string) | |
5326 | (Fformat_mode_line, syms_of_xdisp): | |
5327 | * xfaces.c (set_font_frame_param) | |
5328 | (Finternal_lisp_face_attribute_values) | |
5329 | (Finternal_merge_in_global_face, syms_of_xfaces): | |
5330 | * xfns.c (x_default_scroll_bar_color_parameter) | |
5331 | (x_default_font_parameter, x_create_tip_frame): | |
5332 | * xfont.c (xfont_supported_scripts): | |
5333 | * xmenu.c (Fx_popup_dialog, xmenu_show, xdialog_show) | |
5334 | (menu_help_callback, xmenu_show): | |
5335 | * xml.c (make_dom): | |
5336 | * xterm.c (set_wm_state): | |
5337 | Prefer list1 (FOO) to Fcons (FOO, Qnil) when creating a list, | |
5338 | and similarly for list2 through list5. | |
5339 | ||
bafe80ce PE |
5340 | 2013-07-15 Paul Eggert <eggert@cs.ucla.edu> |
5341 | ||
5342 | * callproc.c (Fcall_process_region): Fix minor race and tune. | |
5343 | (create_temp_file): New function, with the temp-file-creation part | |
5344 | of the old Fcall_process_region. Use Fcopy_sequence to create the | |
5345 | temp file name, rather than alloca + build_string, for simplicity. | |
5346 | Don't bother to block input around the temp file creation; | |
068f9124 SM |
5347 | shouldn't be needed. Simplify use of mktemp. |
5348 | Use record_unwind_protect immediately after creating the temp file; | |
bafe80ce PE |
5349 | this closes an unlikely race where the temp file was not removed. |
5350 | Use memcpy rather than an open-coded loop. | |
5351 | (Fcall_process_region): Use the new function. If the input is | |
5352 | empty, redirect from /dev/null rather than from a newly created | |
5353 | empty temp file; this avoids unnecessary file system traffic. | |
5354 | ||
4700b5a5 PE |
5355 | 2013-07-14 Paul Eggert <eggert@cs.ucla.edu> |
5356 | ||
5c97beae PE |
5357 | * filelock.c (create_lock_file) [!HAVE_MKOSTEMP && !HAVE_MKSTEMP]: |
5358 | Simplify by making this case like the other two. This is a bit | |
5359 | slower on obsolete hosts, but the extra complexity isn't worth it. | |
5360 | ||
4700b5a5 PE |
5361 | * callproc.c (child_setup, relocate_fd) [!DOS_NT]: |
5362 | * process.c (create_process) [!DOS_NT]: | |
5363 | Remove now-unnecessary calls to emacs_close. | |
5364 | ||
f9a74c4c EZ |
5365 | 2013-07-13 Eli Zaretskii <eliz@gnu.org> |
5366 | ||
922ae7ee EZ |
5367 | * w32term.c (x_draw_hollow_cursor): Delete the brush object when |
5368 | returning early. (Bug#14850) | |
5369 | ||
f9a74c4c EZ |
5370 | * coding.c (syms_of_coding): Set up inhibit-null-byte-detection |
5371 | and inhibit-iso-escape-detection attributes of 'undecided'. | |
5372 | (Bug#14822) | |
5373 | ||
5e301d76 PE |
5374 | 2013-07-13 Paul Eggert <eggert@cs.ucla.edu> |
5375 | ||
69e0e5ee PE |
5376 | * deps.mk (sysdep.o): Remove dependency on ../lib/ignore-value.h. |
5377 | Reported by Herbert J. Skuhra in | |
5378 | <http://lists.gnu.org/archive/html/emacs-devel/2013-07/msg00455.html>. | |
5379 | ||
5e301d76 PE |
5380 | Don't lose top specpdl entry when memory is exhausted. |
5381 | * eval.c (grow_specpdl): Increment specpdl top by 1 and check for | |
5382 | specpdl overflow here, to simplify callers; all callers changed. | |
5383 | Always reserve an unused entry at the stack top; this avoids | |
5384 | losing the top entry's information when memory is exhausted. | |
5385 | ||
7e649856 PE |
5386 | 2013-07-12 Paul Eggert <eggert@cs.ucla.edu> |
5387 | ||
a773ed9a PE |
5388 | Clean up errno reporting and fix some errno-reporting bugs. |
5389 | * callproc.c (Fcall_process): | |
5390 | * fileio.c (Fcopy_file, Finsert_file_contents, Fwrite_region): | |
5391 | * process.c (create_process, Fmake_network_process): | |
5392 | * unexaix.c (report_error): | |
5393 | * unexcoff.c (report_error): | |
5394 | Be more careful about reporting the errno of failed operations. | |
5395 | The code previously reported the wrong errno sometimes. | |
5396 | Also, prefer report_file_errno to setting errno + report_file_error. | |
5397 | (Fcall_process): Look at openp return value rather than at path, | |
5398 | as that's a bit faster and clearer when there's a numeric predicate. | |
5399 | * fileio.c (report_file_errno): New function, with most of the | |
5400 | old contents of report_file_error. | |
5401 | (report_file_error): Use it. | |
5402 | (Ffile_exists_p, Ffile_accessible_directory_p): | |
5403 | Set errno to 0 when it is junk. | |
5404 | * fileio.c (Faccess_file): | |
5405 | * image.c (x_create_bitmap_from_file): | |
5406 | Use faccessat rather than opening the file, to avoid the hassle of | |
5407 | having a file descriptor open. | |
5408 | * lisp.h (report_file_errno): New decl. | |
5409 | * lread.c (Flocate_file_internal): File descriptor 0 is valid, too. | |
5410 | ||
7e649856 PE |
5411 | Minor EBADF fixes. |
5412 | * process.c (create_process, wait_reading_process_output) [AIX]: | |
5413 | Remove obsolete SIGHUP-related code, as Emacs no longer disables | |
5414 | SIGHUP, so EBADF is no longer acceptable here (it wouldn't work in | |
5415 | a multithreaded environment anyway). | |
5416 | * sysdep.c (emacs_close): It's not dangerous to invoke emacs_close (-1). | |
5417 | ||
f6774c1a AS |
5418 | 2013-07-12 Andreas Schwab <schwab@linux-m68k.org> |
5419 | ||
5420 | * image.c (x_find_image_file): Don't close a remote file handle. | |
5421 | ||
bacba3c2 PE |
5422 | 2013-07-12 Paul Eggert <eggert@cs.ucla.edu> |
5423 | ||
5424 | Fix races with threads and file descriptors. | |
5425 | * callproc.c (Fcall_process_region): | |
5426 | * dired.c (open_directory): | |
5427 | * emacs.c (main, Fdaemon_initialized): | |
5428 | * image.c (x_find_image_file): | |
5429 | * inotify.c (Finotify_rm_watch): | |
5430 | * lread.c (Flocate_file_internal): | |
5431 | * process.c (Fnetwork_interface_list, Fnetwork_interface_info): | |
5432 | * term.c (term_mouse_moveto, init_tty): | |
5433 | * termcap.c (tgetent): | |
5434 | * unexaix.c, unexcoff.c (report_error, report_error_1, adjust_lnnoptrs) | |
5435 | * unexaix.c, unexcoff.c, unexcw.c, unexelf.c (unexec): | |
5436 | * unexhp9k800.c, unexmacosx.c (unexec): | |
5437 | * callproc.c (Fcall_process_region): | |
5438 | Use emacs_close, not close. | |
5439 | * sysdep.c (POSIX_CLOSE_RESTART, posix_close) [!POSIX_CLOSE_RESTART]: | |
5440 | New macro and function, which emulates the POSIX_CLOSE_RESTART macro | |
5441 | and posix_close function on current platforms (which all lack them). | |
5442 | (emacs_close): Use it. This should fix the races on GNU/Linux and | |
5443 | on AIX and on future platforms that support POSIX_CLOSE_RESTART, | |
5444 | and it should avoid closing random victim file descriptors on | |
5445 | other platforms. | |
5446 | ||
653d4f43 PE |
5447 | 2013-07-11 Paul Eggert <eggert@cs.ucla.edu> |
5448 | ||
c8536ec4 PE |
5449 | * inotify.c (uninitialized): Remove. All uses replaced by -1. |
5450 | (Finotify_add_watch): Simplify, since -1 means uninitialized now. | |
5451 | Touch up doc a bit. | |
5452 | ||
9c203066 PE |
5453 | * eval.c (backtrace_function, backtrace_args): Now EXTERNALLY_VISIBLE. |
5454 | This is for .gdbinit xbacktrace. | |
5455 | ||
653d4f43 PE |
5456 | * sysdep.c, term.c, termcap.c, terminal.c: Integer-related minor fixes. |
5457 | * sysdep.c (emacs_get_tty): Return void, since nobody uses the value. | |
5458 | (emacs_set_tty): Now static. | |
5459 | * sysdep.c (emacs_set_tty, tabs_safe_p, emacs_close): | |
5460 | * term.c (tty_capable_p, tty_default_color_capabilities) | |
5461 | (get_tty_terminal, term_mouse_movement) | |
5462 | (handle_one_term_event, init_tty, maybe_fatal): | |
5463 | * termcap.c (tgetst1, struct termcap_buffer, valid_filename_p) | |
5464 | (tgetent, scan_file, name_match, compare_contin): | |
5465 | * terminal.c (get_terminal): | |
5466 | Use bool for boolean. | |
5467 | * sysdep.c (init_system_name): Don't overflow stack on huge hostname. | |
5468 | Prefer char to unsigned char if either will do. | |
5469 | * term.c (OUTPUT, turn_on_face): Omit unnecessary casts to int. | |
5470 | (tty_write_glyphs): Prefer int to unsigned. | |
5471 | (produce_glyphless_glyph): Remove 2nd (unused) int arg. | |
5472 | All callers changed. | |
5473 | * termcap.c (tprint, main) [TEST]: Remove non-working test. | |
5474 | ||
45b683a1 PE |
5475 | 2013-07-10 Paul Eggert <eggert@cs.ucla.edu> |
5476 | ||
29abe551 PE |
5477 | Port to C89. |
5478 | * bytecode.c (BYTE_CODE_THREADED): Do not define if __STRICT_ANSI__. | |
5479 | (B__dummy__): New dummy symbol, to pacify C89. | |
5480 | * dbusbind.c (XD_DEBUG_MESSAGE): Omit debugging on C89 hosts, since | |
5481 | they can't grok varargs macros. | |
5482 | * dispnew.c (add_window_display_history) | |
5483 | (add_frame_display_history): | |
5484 | * print.c (print_object): | |
5485 | * xdisp.c (debug_method_add): | |
5486 | Use %p printf format only for void pointers. | |
5487 | * emacs.c (usage_message): New constant, replacing ... | |
5488 | (USAGE1, USAGE2, USAGE3): Remove; they were too long for C89. | |
5489 | (main): Adjust to usage reorg. | |
5490 | * fns.c (syms_of_fns): | |
5491 | * profiler.c (syms_of_profiler): | |
5492 | Don't use non-constant struct initializers. | |
5493 | * gnutls.h (gnutls_initstage_t): | |
5494 | * lisp.h (enum Lisp_Fwd_Type): | |
5495 | * lread.c (lisp_file_lexically_bound_p): | |
5496 | * xsettings.c (anonymous enum): | |
5497 | Remove trailing comma. | |
5498 | * xsettings.c (apply_xft_settings): Use %f, not %lf; %lf is a C99ism. | |
5499 | * lisp.h (ENUM_BF): Use unsigned if pedantic. | |
5500 | (DEFUN_FUNCTION_INIT): New macro, that falls back on a cast if pre-C99. | |
5501 | (DEFUN): Use it. | |
5502 | * regex.c (const_re_char): New type, to pacify strict C89. | |
5503 | All uses of 'const re_char' replaced to use it. | |
5504 | * regex.h (_Restrict_): Rename from __restrict, to avoid clash | |
5505 | with glibc when strict C89. This change is imported from gnulib. | |
5506 | All uses changed. | |
5507 | (_Restrict_arr_): Rename from __restrict_arr, similarly. | |
5508 | * sysdep.c (time_from_jiffies) [!HAVE_LONG_LONG_INT]: | |
5509 | Omit GNU_LINUX implementation, since it requires long long. | |
5510 | * xterm.c (x_draw_underwave): | |
5511 | Do not assume the traditional order of struct's members. | |
5512 | (x_term_init): Rewrite to avoid the need for non-constant structure | |
5513 | initializers. | |
5514 | ||
45b683a1 | 5515 | Syntax cleanup, mostly replacing macros with functions. |
763a086d | 5516 | This removes the need for the syntax_temp hack. |
45b683a1 PE |
5517 | * search.c: Include syntax.h after buffer.h, since syntax.h uses BVAR. |
5518 | * syntax.c (SYNTAX_INLINE): New macro. | |
5519 | (SYNTAX_FLAGS_COMSTART_FIRST, SYNTAX_FLAGS_COMSTART_SECOND) | |
5520 | (SYNTAX_FLAGS_COMEND_FIRST, SYNTAX_FLAGS_COMEND_SECOND) | |
5521 | (SYNTAX_FLAGS_PREFIX, SYNTAX_FLAGS_COMMENT_STYLEB) | |
5522 | (SYNTAX_FLAGS_COMMENT_STYLEC, SYNTAX_FLAGS_COMMENT_STYLEC2) | |
5523 | (SYNTAX_FLAGS_COMMENT_NESTED, SYNTAX_FLAGS_COMMENT_STYLE) | |
5524 | (SYNTAX_COMEND_FIRST): Now functions, not macros. | |
5525 | (ST_COMMENT_STYLE, ST_STRING_STYLE, INTERVALS_AT_ONCE): | |
5526 | Now constants, not macros. | |
5527 | (syntax_temp) [!__GNUC__]: Remove. | |
5528 | (SYNTAX_PREFIX): Remove; all uses replaced by syntax_prefix_flag_p. | |
5529 | (syntax_prefix_flag_p): Move implementation of SYNTAX_PREFIX here. | |
5530 | (SET_RAW_SYNTAX_ENTRY, SET_RAW_SYNTAX_ENTRY_RANGE, SYNTAX_MATCH) | |
5531 | (SETUP_SYNTAX_TABLE, SETUP_SYNTAX_TABLE_FOR_OBJECT): | |
5532 | Move here from syntax.h; now functions, not macros. Except for the | |
5533 | last function, these are static since only syntax.c uses them. | |
5534 | (syntax_multibyte): Rename from SYNTAX_WITH_MULTIBYTE_CHECK. | |
5535 | All uses changed. Now a function, not a macro; use this fact | |
5536 | to simplify the code. | |
5537 | (scan_lists, scan_sexps_forward): Remove workarounds for ancient | |
5538 | compiler bugs; no longer relevant. | |
5539 | * syntax.h: Use INLINE_HEADER_BEGIN, INLINE_HEADER_END. | |
5540 | (SYNTAX_INLINE): New macro. | |
5541 | (struct gl_state_s, gl_state): Move earlier, so that it's in scope | |
5542 | for the new functions. Use bool for boolean member. | |
5543 | (SYNTAX_ENTRY, SYNTAX, SYNTAX_WITH_FLAGS, SYNTAX_MATCH) | |
5544 | (SYNTAX_TABLE_BYTE_TO_CHAR, UPDATE_SYNTAX_TABLE_FORWARD) | |
5545 | (UPDATE_SYNTAX_TABLE_BACKWARD, UPDATE_SYNTAX_TABLE) | |
5546 | (SETUP_BUFFER_SYNTAX_TABLE): | |
5547 | Now extern inline functions, not macros. | |
5548 | (CURRENT_SYNTAX_TABLE, SYNTAX_ENTRY_INT): | |
5549 | Remove; all uses replaced by implementation. | |
5550 | (syntax_temp) [!__GNUC__]: Remove decl. | |
5551 | (SETUP_SYNTAX_TABLE_FOR_OBJECT): New decl. | |
5552 | ||
29be4a50 JD |
5553 | 2013-07-10 Jan Djärv <jan.h.d@swipnet.se> |
5554 | ||
5555 | * emacs.c (main): Fix syntax error. | |
5556 | ||
954b166e PE |
5557 | 2013-07-10 Paul Eggert <eggert@cs.ucla.edu> |
5558 | ||
5559 | Timestamp fixes for undo (Bug#14824). | |
5560 | * atimer.c (schedule_atimer): | |
5561 | * fileio.c (Ffile_newer_than_file_p): | |
5562 | Minor cleanup: use EMACS_TIME_LT so that we can remove EMACS_TIME_GT. | |
5563 | * buffer.c (buffer-undo-list): Document (t . 0) and (t . -1). | |
5564 | * fileio.c (Fclear_visited_file_modtime): Move to lisp/files.el. | |
5565 | (syms_of_fileio): Remove Sclear_visited_file_name. | |
5566 | (Fvisited_file_modtime): Return -1, not (-1 ...), when the visited | |
5567 | file doesn't exist; this avoids an ambiguity with negative timestamps. | |
5568 | (Fset_visited_file_modtime): Accept -1 and 0 as time-list arg. | |
5569 | * systime.h (make_emacs_time, invalid_emacs_time): | |
5570 | Don't assume struct timespec layout; POSIX doesn't guarantee it. | |
5571 | (EMACS_TIME_NE, EMACS_TIME_GT, EMACS_TIME_GE): Remove. | |
5572 | * undo.c (record_first_change): Push (visited-file-modtime) onto | |
5573 | undo list rather than reimplementing it by hand, incorrectly. | |
5574 | ||
d74647c3 KB |
5575 | 2013-07-09 Ken Brown <kbrown@cornell.edu> |
5576 | ||
5577 | * sheap.c (STATIC_HEAP_SIZE) [__x86_64__]: Increase to 18MB. | |
5578 | ||
3c51b96b JB |
5579 | 2013-07-09 Juanma Barranquero <lekktu@gmail.com> |
5580 | ||
5581 | * makefile.w32-in ($(BLD)/emacs.$(O), $(BLD)/sysdep.$(O)): Update. | |
5582 | ||
4ebbdd67 PE |
5583 | 2013-07-09 Paul Eggert <eggert@cs.ucla.edu> |
5584 | ||
5585 | Handle errno and exit status a bit more carefully. | |
5586 | * callproc.c (child_setup) [!DOS_NT]: Don't try to stuff an error | |
5587 | number into an exit status. Instead, use EXIT_CANCELED. | |
5588 | (child_setup) [!MSDOS]: Avoid possible deadlock with vfork. | |
5589 | * callproc.c (relocate_fd): | |
5590 | * emacs.c (close_output_streams, main): | |
5591 | * process.c (create_process): | |
5592 | * sysdep.c (sys_subshell) [!DOS_NT || !WINDOWSNT]: | |
5593 | Use emacs_perror for simplicity. | |
5594 | * callproc.c (relocate_fd, main): | |
5595 | * sysdep.c (sys_subshell): | |
5596 | Exit with EXIT_CANCELED etc., not 1, when exec setup fails. | |
5597 | (shut_down_emacs): Use emacs_write, not write. | |
5598 | * emacs.c, sysdep.c: Don't include <ignore-value.h>. | |
5599 | * fileio.c (Fcopy_file, e_write): | |
5600 | * nsterm.m (ns_select): | |
5601 | * process.c (send_process): | |
5602 | * sound.c (vox_write): | |
5603 | Use emacs_write_sig, not emacs_write. | |
5604 | * lisp.h (emacs_write_sig, emacs_perror): New decls. | |
5605 | * process.h (EXIT_CANCELED), EXIT_CANNOT_INVOKE, EXIT_ENOENT): | |
5606 | New constants. | |
5607 | * sysdep.c (emacs_backtrace): Use emacs_write, not ignore_value | |
5608 | of write. | |
5609 | (emacs_full_write): New function. | |
5610 | (emacs_write): Rewrite to use it. | |
5611 | (emacswrite_sig, emacs_perror): New functions. | |
5612 | * xrdb.c (fatal): Don't invoke perror, since errno might be garbage. | |
5613 | ||
44e18199 | 5614 | 2013-07-08 Magnus Henoch <magnus.henoch@gmail.com> (tiny change) |
e4b1e5af JD |
5615 | |
5616 | * image.c (imagemagick_load_image): Do not use MagickExportImagePixels | |
5617 | on NS even if it is present. Pixmap on NS is a void*. | |
5618 | ||
9caab067 PE |
5619 | 2013-07-07 Paul Eggert <eggert@cs.ucla.edu> |
5620 | ||
5621 | Port to Ubuntu 10 (Bug#14803). | |
5622 | Problem reported by T.V. Raman. | |
5623 | * process.c (close_on_exec, accept4, process_socket): | |
5624 | Define these if !HAVE_ACCEPT4, not if !SOCK_CLOEXEC. | |
5625 | ||
1d442672 EZ |
5626 | 2013-07-07 Eli Zaretskii <eliz@gnu.org> |
5627 | ||
5628 | * w32.c (sys_dup): Declare prototype. | |
5629 | ||
5630 | * filelock.c: | |
5631 | * emacs.c: | |
5632 | * callproc.c [WINDOWSNT]: Include sys/socket.h. | |
5633 | ||
067428c1 PE |
5634 | 2013-07-07 Paul Eggert <eggert@cs.ucla.edu> |
5635 | ||
5636 | Make file descriptors close-on-exec when possible (Bug#14803). | |
5637 | This simplifies Emacs a bit, since it no longer needs to worry | |
5638 | about closing file descriptors by hand in some cases. | |
5639 | It also fixes some unlikely races. Not all such races, as | |
5640 | libraries often open files internally without setting | |
5641 | close-on-exec, but it's an improvement. | |
5642 | * alloc.c (valid_pointer_p) [!WINDOWSNT]: | |
5643 | * callproc.c (Fcall_process) [!MSDOS]: | |
5644 | * emacs.c (main) [!DOS_NT]: | |
5645 | * nsterm.m (ns_term_init): | |
5646 | * process.c (create_process): | |
5647 | Use 'pipe2' with O_CLOEXEC instead of 'pipe'. | |
5648 | * emacs.c (Fcall_process_region) [HAVE_MKOSTEMP]: | |
5649 | * filelock.c (create_lock_file) [HAVE_MKOSTEMP]: | |
5650 | Prefer mkostemp with O_CLOEXEC to mkstemp. | |
5651 | * callproc.c (relocate_fd) [!WINDOWSNT]: | |
5652 | * emacs.c (main): Use F_DUPFD_CLOEXEC, not plain F_DUPFD. | |
5653 | No need to use fcntl (..., F_SETFD, FD_CLOEXEC), since we're | |
5654 | now using pipe2. | |
5655 | * filelock.c (create_lock_file) [! HAVE_MKOSTEMP]: | |
5656 | Make the resulting file descriptor close-on-exec. | |
5657 | * lisp.h, lread.c, process.c (close_load_descs, close_process_descs): | |
5658 | * lread.c (load_descriptor_list, load_descriptor_unwind): | |
5659 | Remove; no longer needed. All uses removed. | |
5660 | * process.c (SOCK_CLOEXEC): Define to 0 if not supplied by system. | |
5661 | (close_on_exec, accept4, process_socket) [!SOCK_CLOEXEC]: | |
5662 | New functions. | |
5663 | (socket) [!SOCK_CLOEXEC]: Supply a substitute. | |
5664 | (Fmake_network_process, Fnetwork_interface_list): | |
5665 | (Fnetwork_interface_info, server_accept_connection): | |
5666 | Make newly-created socket close-on-exec. | |
5667 | * sysdep.c (emacs_open, emacs_fopen): | |
5668 | Make new-created descriptor close-on-exec. | |
5669 | * w32.c (fcntl): Support F_DUPFD_CLOEXEC well enough for Emacs. | |
5670 | * w32.c, w32.h (pipe2): Rename from 'pipe', with new flags arg. | |
5671 | ||
0da857dd JD |
5672 | 2013-07-07 Jan Djärv <jan.h.d@swipnet.se> |
5673 | ||
5674 | * nsterm.m (sendEvent:): Propagate keyboard events to modal windows | |
5675 | for NS_IMPL_GNUSTEP. | |
5676 | ||
5f86adcd PE |
5677 | 2013-07-07 Paul Eggert <eggert@cs.ucla.edu> |
5678 | ||
5679 | Fix openp errno handling. | |
5680 | * callproc.c (Fcall_process): Preserve openp errno around close. | |
5681 | * lread.c (openp): Set errno when returning -1, as some callers | |
5682 | expect this. | |
5683 | ||
1afb1d07 JD |
5684 | 2013-07-06 Jan Djärv <jan.h.d@swipnet.se> |
5685 | ||
5686 | * nsterm.m (sendEvent:): Handle NSAPP_DATA2_RUNFILEDIALOG. | |
5687 | ||
5688 | * nsterm.h (NSSavePanel): Update comment. | |
5689 | (NSAPP_DATA2_RUNFILEDIALOG): Define. | |
5690 | (ns_run_file_dialog): Declare. | |
5691 | ||
5692 | * nsfns.m: Remove panelOK. | |
5693 | (ns_fd_data): New. | |
5694 | (ns_run_file_dialog): New function. | |
5695 | (Fns_read_file_name): Fill in ns_fd_data, post an event and start the | |
5696 | event loop, so file dialog is popped up by ns_run_file_dialog, called | |
5697 | by sendEvent (Bug#14578). | |
5698 | (EmacsSavePanel, EmacsOpenPanel): Remove ok and cancel methods. | |
5699 | ||
3323c263 EZ |
5700 | 2013-07-06 Eli Zaretskii <eliz@gnu.org> |
5701 | ||
fdda0220 EZ |
5702 | * xdisp.c (default_line_pixel_height): New function. |
5703 | (pos_visible_p, move_it_vertically_backward, try_scrolling) | |
5704 | (try_cursor_movement, redisplay_window, try_window) | |
5705 | (try_window_id): Use it instead of FRAME_LINE_HEIGHT. (Bug#14771) | |
5706 | ||
068f9124 SM |
5707 | * window.c (window_scroll_pixel_based): |
5708 | use default_line_pixel_height. | |
fdda0220 EZ |
5709 | |
5710 | * dispextern.h (default_line_pixel_height): Add prototype. | |
5711 | ||
5712 | * frame.c (x_set_line_spacing): Accept a float value for | |
5713 | line-spacing parameter, per the documentation. | |
5714 | ||
3323c263 EZ |
5715 | * data.c (Fmultibyte_string_p): Doc fix. |
5716 | ||
47ba6d43 PE |
5717 | 2013-07-05 Paul Eggert <eggert@cs.ucla.edu> |
5718 | ||
406af475 PE |
5719 | Use emacs_open more consistently when opening files. |
5720 | This handles EINTR more consistently now, and makes it easier | |
5721 | to introduce other uniform changes to file descriptor handling. | |
5722 | * src/systdio.h: New file. | |
5723 | * src/buffer.c (mmap_init): | |
5724 | * cygw32.c (chdir_to_default_directory): | |
5725 | * dispnew.c (Fopen_termscript): | |
5726 | * emacs.c (Fdaemon_initialized): | |
5727 | * fileio.c (Fdo_auto_save): | |
5728 | * image.c (slurp_file, png_load_body, jpeg_load_body): | |
5729 | * keyboard.c (Fopen_dribble_file): | |
5730 | * lread.c (Fload): | |
5731 | * print.c (Fredirect_debugging_output): | |
5732 | * sysdep.c (get_up_time, procfs_ttyname, procfs_get_total_memory): | |
5733 | * termcap.c (tgetent): | |
5734 | * unexaix.c, unexcoff.c (unexec, adjust_lnnoptrs): | |
5735 | * unexcw.c, unexelf.c, unexhp9k800.c, unexmacosx.c (unexec): | |
5736 | * w32term.c (w32_initialize) [CYGWIN]: | |
5737 | * xfaces.c (Fx_load_color_file): | |
5738 | Use emacs_open instead of plain open, and emacs_fopen instead of | |
5739 | plain fopen. | |
5740 | * dispnew.c, fileio.c, image.c, keyboard.c, lread.c, print.c, sysdep.c: | |
5741 | * xfaces.c: Include sysstdio.h rather than stdio.h, for emacs_fopen. | |
5742 | * callproc.c (default_output_mode): New constant. | |
5743 | (Fcall_process): Use it to call emacs_open instead of plain creat. | |
5744 | * dispnew.c (Fopen_termscript): Fix minor race in opening termscript. | |
5745 | * sysdep.c (emacs_open): Add commentary and don't call file name "path". | |
5746 | (emacs_fopen): New function. | |
5747 | * unexaix.c, unexcoff.c, unexelf.c, unexhp9k800.c, unexmacosx.c: | |
5748 | Include <lisp.h>, for emacs_open. | |
5749 | * unexelf.c (fatal): Remove decl; not needed with <lisp.h> included. | |
5750 | ||
47ba6d43 PE |
5751 | Remove duplicate #include directives. |
5752 | * alloc.c [GC_MARK_STACK == GC_USE_GCPROS_CHECK_ZOMBIES]: | |
5753 | * xfaces.c: | |
5754 | Don't include stdio.h twice. | |
5755 | * buffer.c [USE_MMAP_FOR_BUFFERS]: | |
5756 | Don't include sys/types.h or stdio.h twice. | |
5757 | * fileio.c [WINDOWSNT | MSDOS]: Don't include fcntl.h twice. | |
5758 | * lread.c: Don't include coding.h twice. | |
5759 | * nsfont.m: Don't include frame.h twice. | |
5760 | * process.c [HAVE_RES_INIT]: Don't include <netinet/in.h> twice. | |
5761 | * ralloc.c: Don't include <unistd.h> twice. | |
5762 | * xdisp.c: Don't include font.h twice. | |
5763 | * xterm.c: Don't include fontset.h twice. | |
5764 | * xterm.h [USE_X_TOOLKIT]: Don't include X11/StringDefs.h twice. | |
5765 | ||
b9ed53d5 PE |
5766 | 2013-07-04 Paul Eggert <eggert@cs.ucla.edu> |
5767 | ||
5768 | Scale ImageMagick images more carefully. | |
5769 | * image.c (scale_image_size) [HAVE_IMAGEMAGICK]: New function. | |
5770 | (compute_image_size): Use it. Define only if HAVE_IMAGEMAGICK. | |
5771 | Be more careful about avoiding undefined behavior after | |
5772 | integer overflow and division by zero. | |
5773 | ||
cf13177e YM |
5774 | 2013-07-04 YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp> |
5775 | ||
5776 | * w32fns.c (Qgeometry, Qworkarea, Qmm_size, Qframes): New variables. | |
5777 | (syms_of_w32fns): DEFSYM them. | |
5778 | (MONITORINFOF_PRIMARY, SM_XVIRTUALSCREEN, SM_YVIRTUALSCREEN) | |
5779 | (CCHDEVICENAME): Define macros if not defined. | |
5780 | (struct MONITOR_INFO_EX): New struct. | |
5781 | (MonitorEnum_Proc, EnumDisplayMonitors_Proc): New prototypes. | |
5782 | (enum_display_monitors_fn): New variable. | |
5783 | (globals_of_w32fns): Initialize it. | |
5784 | (Fx_display_pixel_width, Fx_display_pixel_height) | |
5785 | (Fx_display_mm_height, Fx_display_mm_width): Mention behavior on | |
5786 | multi-monitor setups in docstrings. | |
5787 | (Fx_display_mm_height, Fx_display_mm_width): Approximate whole | |
5788 | screen size by primary monitor's millimeter per pixel. | |
5789 | (w32_monitor_enum, w32_display_monitor_attributes_list) | |
5790 | (w32_display_monitor_attributes_list_fallback) | |
5791 | (Fw32_display_monitor_attributes_list): New functions. | |
5792 | (syms_of_w32fns): Defsubr Sw32_display_monitor_attributes_list. | |
5793 | ||
5794 | * w32term.c (SM_CXVIRTUALSCREEN, SM_CYVIRTUALSCREEN): Define macros | |
5795 | if not defined. | |
5796 | (x_display_pixel_height, x_display_pixel_width): Use GetSystemMetrics. | |
5797 | ||
86dfb7a8 MA |
5798 | 2013-07-04 Michael Albinus <michael.albinus@gmx.de> |
5799 | ||
5800 | * fileio.c (Qfile_notify_error): New error symbol. | |
5801 | ||
5802 | * gfilenotify.c (Fgfile_add_watch, Fgfile_rm_watch): | |
5803 | * inotify.c (inotify_callback, symbol_to_inotifymask) | |
5804 | (Finotify_add_watch, Finotify_rm_watch): Use it. | |
5805 | (inotifyevent_to_event): Exchange order of cookie and file name. | |
5806 | (Finotify_add_watch): Adapt docstring. | |
5807 | ||
5808 | * lisp.h (Qfile_notify_error): Declare. | |
5809 | ||
2c1c974b PE |
5810 | 2013-07-04 Paul Eggert <eggert@cs.ucla.edu> |
5811 | ||
5812 | Try again to fix FreeBSD bug re multithreaded memory alloc (Bug#14569). | |
5813 | * emacs.c (main) [HAVE_PTHREAD && !SYSTEM_MALLOC && !DOUG_LEA_MALLOC]: | |
5814 | Do not clear _malloc_thread_enabled_p, undoing the previous change, | |
5815 | which did not work (see <http://bugs.gnu.org/14569#307>). | |
5816 | (main): Do not invoke malloc_enable_thread if (! CANNOT_DUMP | |
5817 | && (!noninteractive || initialized)). This attempts to thread | |
5818 | the needle between the Scylla of FreeBSD and the Charybdis of Cygwin. | |
5819 | ||
7a35b20f JB |
5820 | 2013-07-04 Juanma Barranquero <lekktu@gmail.com> |
5821 | ||
5822 | * image.c (x_to_xcolors) [HAVE_NTGUI]: Remove unused var `hdc'. | |
5823 | (x_build_heuristic_mask) [HAVE_NTGUI]: Remove unused var `frame_dc'. | |
5824 | ||
1ce5cd04 PE |
5825 | 2013-07-04 Paul Eggert <eggert@cs.ucla.edu> |
5826 | ||
5827 | Try to fix FreeBSD bug re multithreaded memory allocation (Bug#14569). | |
5828 | * emacs.c (main) [HAVE_PTHREAD && !SYSTEM_MALLOC && !DOUG_LEA_MALLOC]: | |
5829 | Clear _malloc_thread_enabled_p at startup. Reported by Ashish SHUKLA in | |
5830 | <http://lists.gnu.org/archive/html/emacs-devel/2013-07/msg00088.html>. | |
5831 | ||
57f8c490 PE |
5832 | 2013-07-02 Paul Eggert <eggert@cs.ucla.edu> |
5833 | ||
5834 | * sysdep.c (sys_siglist) [HAVE_DECL___SYS_SIGLIST]: | |
5835 | Define to __sys_siglist. | |
5836 | ||
bcffb5ca EZ |
5837 | 2013-07-02 Eli Zaretskii <eliz@gnu.org> |
5838 | ||
5839 | * xdisp.c (IT_OVERFLOW_NEWLINE_INTO_FRINGE): Don't disallow | |
5840 | word-wrap, so that overflow-newline-into-fringe would work in | |
5841 | visual-line-mode. (Bug#2749) | |
5842 | (move_it_in_display_line_to): When the last scanned display | |
5843 | element fits exactly on the display line, and | |
5844 | overflow-newline-into-fringe is non-nil, but wrap_it is valid, | |
5845 | don't return MOVE_NEWLINE_OR_CR, but instead back up to the last | |
5846 | wrap point and return MOVE_LINE_CONTINUED. Fixes problems with | |
5847 | finding buffer position that corresponds to pixel coordinates, | |
5848 | e.g. in buffer_posn_from_coords. | |
5849 | ||
2c41e781 JD |
5850 | 2013-07-02 Jan Djärv <jan.h.d@swipnet.se> |
5851 | ||
5852 | * process.c (handle_child_signal): Call catch_child_signal if | |
5853 | NS_IMPL_GNUSTEP. | |
5854 | ||
c2418359 PE |
5855 | 2013-07-02 Paul Eggert <eggert@cs.ucla.edu> |
5856 | ||
52a9bcae PE |
5857 | Don't convert function pointers to void * and back. |
5858 | It isn't portable C, and it's easy enough to avoid. | |
5859 | * alloc.c: Verify SAVE_FUNCPOINTER bits, too. | |
5860 | (make_save_value): Add support for SAVE_FUNCPOINTER. | |
5861 | * keymap.c (map_keymap_char_table_item, map_keymap_internal): | |
5862 | * print.c (print_object): | |
5863 | Distinguish function from object pointers. | |
5864 | * lisp.h (SAVE_FUNCPOINTER): New constant. | |
5865 | (SAVE_SLOT_BITS): Adjust to it. | |
5866 | (SAVE_TYPE_FUNCPTR_PTR_OBJ): New constant, replacing | |
5867 | SAVE_TYPE_PTR_PTR_OBJ. Change the only use. | |
5868 | (voidfuncptr): New typedef. | |
5869 | (struct Lisp_Save_Value): New member data[0].funcpointer. | |
5870 | (XSAVE_FUNCPOINTER): New function. | |
5871 | ||
c2418359 PE |
5872 | Simplify buildobj processing. |
5873 | * Makefile.in (buildobj.h): Make it a sequence of strings each | |
5874 | followed by comma, rather than a single string. Put it into a | |
5875 | .tmp file in case there's an error while generating it. | |
5876 | (gl-stamp): Use .tmp for temp files. | |
5877 | (mostlyclean): Clean .tmp files. | |
5878 | * doc.c (buildobj): Move to just the routine that needs it. | |
5879 | It's now an array of strings, so processing is simpler. | |
5880 | ||
8f43ce49 PE |
5881 | 2013-07-01 Paul Eggert <eggert@cs.ucla.edu> |
5882 | ||
5883 | Fix bug re noninteractive multithreaded memory allocation (Bug#14569). | |
5884 | * emacs.c (malloc_enable_thread): Hoist extern decl to top level. | |
5885 | (main) [HAVE_PTHREAD && !SYSTEM_MALLOC && !DOUG_LEA_MALLOC]: | |
5886 | Invoke malloc_enable_thread even when not interactive. | |
5887 | Problem reported by Ken Brown in <http://bugs.gnu.org/14569#275>. | |
5888 | * process.c (init_process_emacs) [CYGWIN]: Tickle glib even | |
5889 | in this case, since the underlying bug has now been fixed. | |
5890 | ||
24827db9 JB |
5891 | 2013-07-01 Juanma Barranquero <lekktu@gmail.com> |
5892 | ||
5893 | * emacs.c (Fkill_emacs): Expand Vauto_save_list_file_name before | |
5894 | unlinking it (bug#14691). | |
5895 | ||
ef099a94 MN |
5896 | 2013-06-30 Michal Nazarewicz <mina86@mina86.com> |
5897 | ||
5898 | * buffer.c (FKill_buffer): Run `kill-buffer-query-functions' | |
5899 | before checking whether buffer is modified. This lets | |
5900 | `kill-buffer-query-functions' cancel killing of the buffer or save | |
5901 | its content before `kill-buffer' asks user the "Buffer %s | |
5902 | modified; kill anyway?" question. | |
5903 | ||
9d3f2fc2 JD |
5904 | 2013-06-30 Jan Djärv <jan.h.d@swipnet.se> |
5905 | ||
5906 | * nsfns.m (handlePanelKeys): Don't process Command+Function keys. | |
5907 | Let the super performKeyEquivalent deal with them (Bug#14747). | |
5908 | ||
e6c6c8c7 PE |
5909 | 2013-06-30 Paul Eggert <eggert@cs.ucla.edu> |
5910 | ||
1d71c1d9 PE |
5911 | * widget.c (resize_cb): Remove unused local. |
5912 | ||
8f5f35cc PE |
5913 | Do not use GTK 3 if it exists but cannot be compiled. |
5914 | * xmenu.c (x_menu_wait_for_event) [!USE_GTK]: | |
5915 | * xterm.c (x_error_handler) [!USE_GTK]: | |
5916 | Do not use GTK 3. | |
5917 | ||
e6c6c8c7 PE |
5918 | * intervals.c (get_local_map): Actually clip POSITION (Bug#14753). |
5919 | ||
0ba54312 EZ |
5920 | 2013-06-30 Eli Zaretskii <eliz@gnu.org> |
5921 | ||
5d1c3286 EZ |
5922 | * intervals.c (get_local_map): Instead of aborting, clip POSITION |
5923 | to the valid range of values. (Bug#14753) | |
5924 | ||
0ba54312 EZ |
5925 | * xdisp.c (Fmove_point_visually): Invalidate the cursor position |
5926 | when moving point by using the current glyph matrix. This avoids | |
5927 | the need to force redisplay when this function is called in a | |
5928 | loop. | |
5929 | ||
9c90cc06 PE |
5930 | 2013-06-29 Paul Eggert <eggert@cs.ucla.edu> |
5931 | ||
5932 | Fix minor problems found by static checking. | |
5933 | * coding.c (encode_inhibit_flag, inhibit_flag): New functions. | |
5934 | Redo the latter's body to sidestep GCC parenthesization warnings. | |
5935 | (setup_coding_system, detect_coding, detect_coding_system): Use them. | |
5936 | * coding.c (detect_coding, detect_coding_system): | |
5937 | * coding.h (struct undecided_spec): | |
5938 | Use bool for boolean. | |
5939 | * image.c (QCmax_width, QCmax_height): Now static. | |
5940 | * xdisp.c (Fmove_point_visually): Remove unused local. | |
5941 | ||
4c672a0f EZ |
5942 | 2013-06-29 Eli Zaretskii <eliz@gnu.org> |
5943 | ||
5944 | * xdisp.c (Fmove_point_visually): New function. | |
5945 | ||
c1ea3abf JB |
5946 | 2013-06-28 Kenichi Handa <handa@gnu.org> |
5947 | ||
5948 | * coding.h (define_coding_undecided_arg_index): New enum. | |
5949 | (coding_attr_index): New members | |
5950 | coding_attr_undecided_inhibit_null_byte_detection, | |
5951 | coding_attr_undecided_inhibit_iso_escape_detection, | |
5952 | coding_attr_undecided_prefer_utf_8. | |
5953 | (undecided_spec): New struct. | |
5954 | (struct coding_system): New member `undecided' of the member | |
5955 | `spec'. | |
5956 | ||
5957 | * coding.c (setup_coding_system): Handle CODING->spec.undecided. | |
5958 | (detect_coding): Likewise. | |
5959 | (detect_coding_system): Likewise. | |
5960 | (Fdefine_coding_system_internal): New coding system properties | |
5961 | :inhibit-null-byte-detection, :inhibit-iso-escape-detection, and | |
5962 | :prefer-utf-8. | |
5963 | (syms_of_coding): Adjust for coding_arg_undecided_max. | |
5964 | ||
ba3de9e6 PE |
5965 | 2013-06-28 Paul Eggert <eggert@cs.ucla.edu> |
5966 | ||
5967 | * image.c (x_from_xcolors): Remove unused local. | |
5968 | ||
547c9269 YM |
5969 | 2013-06-28 YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp> |
5970 | ||
5971 | Defer image data transfer between X client and server until actual | |
5972 | display happens. | |
5973 | ||
5974 | * dispextern.h (struct image) [HAVE_X_WINDOWS]: New members `ximg' | |
5975 | and `mask_img'. | |
5976 | ||
5977 | * image.c (Destroy_Image): Remove. | |
5978 | (x_clear_image_1): New arg `flags' instead of 3 bools `pixmap_p', | |
5979 | `mask_p', and `colors_p'. All uses changed. | |
5980 | (x_clear_image_1) [HAVE_X_WINDOWS]: Destroy `ximg' and `mask_img'. | |
ef099a94 MN |
5981 | (CLEAR_IMAGE_PIXMAP, CLEAR_IMAGE_MASK, CLEAR_IMAGE_COLORS): |
5982 | New macros for `flags' arg to x_clear_image_1. | |
547c9269 YM |
5983 | (postprocess_image, xpm_load_image, x_build_heuristic_mask) |
5984 | (png_load_body): Use x_clear_image_1 instead of Free_Pixmap. | |
04b66ce7 | 5985 | (ZPixmap, XGetImage) [HAVE_NS]: Remove. |
547c9269 YM |
5986 | (image_get_x_image_or_dc, image_unget_x_image_or_dc) |
5987 | (image_get_x_image, image_unget_x_image): New functions or macros. | |
5988 | (image_background, image_background_transparent, x_to_xcolors) | |
5989 | (x_build_heuristic_mask): Use image_get_x_image_or_dc instead of | |
5990 | XGetImage or CreateCompatibleDC. Use image_unget_x_image_or_dc | |
5991 | instead of Destroy_Image. | |
5992 | (image_create_x_image_and_pixmap, image_put_x_image): New functions. | |
5993 | (xpm_load_image, x_from_xcolors, x_build_heuristic_mask, pbm_load) | |
5994 | (png_load_body, jpeg_load_body, tiff_load, gif_load) | |
5995 | (imagemagick_load_image, svg_load_image): Use them instead of | |
5996 | x_create_x_image_and_pixmap, and x_put_x_image followed by | |
5997 | x_destroy_x_image, respectively. | |
5998 | (xpm_load) [HAVE_XPM && !HAVE_NTGUI]: Use XpmReadFileToImage and | |
5999 | XpmCreateImageFromBuffer instead of XpmReadFileToPixmap and | |
6000 | XpmCreatePixmapFromBuffer. Create pixmaps. Fill background and | |
6001 | background_transparent fields. | |
6002 | (image_sync_to_pixmaps) [HAVE_X_WINDOWS]: New function. | |
6003 | (prepare_image_for_display, x_disable_image) [HAVE_X_WINDOWS]: Use it. | |
6004 | ||
dae2f5ef PE |
6005 | 2013-06-27 Paul Eggert <eggert@cs.ucla.edu> |
6006 | ||
6007 | Do not tickle glib SIGCHLD handling if Cygwin (Bug#14569). | |
6008 | This mostly consists of undoing recent changes. | |
6009 | * callproc.c (Fcall_process): | |
6010 | * process.c (create_process): | |
6011 | Do not worry about catching SIGCHLD here, undoing previous change. | |
6012 | * nsterm.m (ns_term_init): Re-catch SIGCHLD, undoing previous change. | |
6013 | * process.c, process.h (catch_child_signal): | |
6014 | No longer extern if !NS_IMPL_GNUSTEP, undoing 06-22 change. | |
6015 | * process.c (catch_child_handler): Don't worry about being called | |
6016 | lazily and do not assume caller has blocked SIGCHLD, undoing | |
6017 | previous change. Move first-time stuff back to | |
6018 | init_process_emacs, undoing 06-22 change. If CYGWIN, do not | |
6019 | tickle glib, as that causes Cygwin bootstrap to fail. Do not | |
6020 | set lib_child_handler if it's already initialized, which may | |
6021 | help avoid problems on GNUStep. | |
6022 | ||
fa55d2aa PE |
6023 | 2013-06-23 Paul Eggert <eggert@cs.ucla.edu> |
6024 | ||
6025 | A more-conservative workaround for Cygwin SIGCHLD issues (Bug#14569). | |
6026 | * callproc.c (Fcall_process): | |
6027 | * process.c (create_process): | |
6028 | Make sure SIGCHLD is caught before we fork, | |
6029 | since Emacs startup no arranges to catch SIGCHLD. | |
6030 | * process.c (lib_child_handler): Initialize to null, not to | |
6031 | dummy_handler. | |
6032 | (catch_child_signal): Allow self to be called lazily. | |
6033 | Do nothing if it's already been called. | |
6034 | Assume caller has blocked SIGCHLD (all callers do now). | |
6035 | * emacs.c (main): Do not catch SIGCHLD here; defer it until | |
6036 | just before it's really needed. | |
6037 | * nsterm.m (ns_term_init): No need to re-catch SIGCHLD here, | |
6038 | since it hasn't been caught yet. | |
6039 | ||
f3f9606c LMI |
6040 | 2013-06-23 Lars Magne Ingebrigtsen <larsi@gnus.org> |
6041 | ||
6042 | * image.c (compute_image_size): New function to implement | |
6043 | :max-width and :max-height. | |
6044 | (imagemagick_load_image): Use it. | |
6045 | ||
c7041908 PE |
6046 | 2013-06-23 Paul Eggert <eggert@cs.ucla.edu> |
6047 | ||
6048 | Try to avoid malloc SEGVs on Cygwin (Bug#14569). | |
6049 | * callproc.c, process.h (block_child_signal, unblock_child_signal): | |
6050 | Now extern. | |
6051 | * emacs.c (main): Catch SIGCHLD just before initializing gfilenotify. | |
6052 | * process.c (catch_child_signal): Block SIGCHLD while futzing with | |
6053 | the SIGCHLD handler, since the code is not atomic and (due to glib) | |
6054 | signals may be arriving now. | |
6055 | * sysdep.c (init_signals): Do not catch child signals here; | |
6056 | 'main' now does that later, at a safer time. | |
6057 | ||
f86852b4 PE |
6058 | 2013-06-22 Paul Eggert <eggert@cs.ucla.edu> |
6059 | ||
0dfeed58 PE |
6060 | Clean up SIGCHLD handling a bit (Bug#14569). |
6061 | * process.c, process.h (catch_child_signal): | |
6062 | Now always extern, even if !NS_IMPL_GNUSTEP. | |
6063 | * process.c (catch_child_signal): Move glib tickler here from | |
6064 | init_process_emacs, so that it's done earlier in Emacs | |
6065 | initialization. Also move the noninteractive && !initialized | |
6066 | check here from init_process_emacs. This is all a bit cleaner for | |
6067 | GNUish platforms, and I hope it works around the Cygwin bug. | |
6068 | * sysdep.c (init_signals): Invoke catch_child_signal here, so | |
6069 | that glib signal handling is tickled before glib creates threads. | |
6070 | ||
f86852b4 PE |
6071 | * process.c (wait_reading_process_output): Avoid int overflow |
6072 | when reading more than 2 GiB total from a process. | |
6073 | ||
cbd6509c PE |
6074 | 2013-06-21 Paul Eggert <eggert@cs.ucla.edu> |
6075 | ||
6076 | * process.c (create_process): Handle a couple more cases, | |
6077 | i.e., work even if new_argv and wait_child_setup[i] are cached. | |
6078 | Use Fcall_process's style for volatile vars. | |
6079 | ||
9de1114a AS |
6080 | 2013-06-21 Andreas Schwab <schwab@linux-m68k.org> |
6081 | ||
6082 | * process.c (create_process): Mark PROCESS volatile. | |
6083 | ||
fbe9e0b9 PE |
6084 | 2013-06-21 Paul Eggert <eggert@cs.ucla.edu> |
6085 | ||
6086 | Use C99-style flexible array members if available. | |
6087 | This avoids some subtle aliasing issues, which typically | |
6088 | aren't a problem with GCC but may be a problem elsewhere. | |
6089 | * alloc.c (sdata): New typedef, replacing the old struct sdata. | |
6090 | It is a struct if GC_CHECK_STRING_BYTES, a union otherwise. | |
6091 | In either case, it uses a flexible array member rather than | |
6092 | the old struct hack. All uses changed. | |
6093 | (SDATA_NBYTES, sweep_strings) [!GC_CHECK_STRING_BYTES]: | |
6094 | Adjust to sdata reorganization. | |
6095 | * alloc.c (VBLOCK_BYTES_MIN, allocate_vectorlike, Fgarbage_collect): | |
6096 | Use offsetof (struct, flex_array_member), not sizeof (struct), as | |
6097 | that ports better to pre-C99 non-GCC. | |
6098 | * chartab.c (Fmake_char_table, make_sub_char_table, copy_char_table): | |
6099 | Use CHAR_TABLE_STANDARD_SLOTS rather than its definition, | |
6100 | as the latter has changed. | |
6101 | * conf_post.h (FLEXIBLE_ARRAY_MEMBER): Move here from w32.c, | |
6102 | and port better to pre-C99 GCC. | |
6103 | * image.c (struct xpm_cached_color): | |
6104 | * lisp.h (struct Lisp_Vector, struct Lisp_Bool_Vector) | |
6105 | (struct Lisp_Char_Table, struct Lisp_Sub_Char_Table): | |
6106 | Use FLEXIBLE_ARRAY_MEMBER. | |
6107 | * lisp.h (string_bytes) [GC_CHECK_STRING_BYTES]: | |
6108 | Move decl to top level so it gets checked against implementation. | |
6109 | (CHAR_TABLE_STANDARD_SLOTS): Adjust to struct Lisp_Char_Table change. | |
6110 | * w32.c (FLEXIBLE_ARRAY_MEMBER): Move to conf_post.h. | |
6111 | ||
1fc71008 PE |
6112 | 2013-06-20 Paul Eggert <eggert@cs.ucla.edu> |
6113 | ||
6114 | * syntax.c: Integer cleanups. | |
6115 | (SYNTAX_FLAGS_COMMENT_STYLEC): Return a boolean, not 0-or-2. | |
6116 | All uses that need 0-or-2 changed to: | |
6117 | (SYNTAX_FLAGS_COMMENT_STYLEC2): New macro, with the same semantics | |
6118 | as the old SYNTAX_FLAGS_COMMENT_STYLEC. | |
6119 | (struct lisp_parse_state, syntax_prefix_flag_p, update_syntax_table) | |
6120 | (char_quoted, prev_char_comend_first, back_comment) | |
6121 | (Finternal_describe_syntax_value, skip_chars, skip_syntaxes) | |
6122 | (in_classes, forw_comment, scan_lists, scan_sexps_forward): | |
6123 | Use bool for boolean. | |
6124 | (update_syntax_table, skip_chars, skip_syntaxes): | |
6125 | Prefer int to unsigned when either will do. | |
6126 | (back_comment): Return boolean success flag, like forw_comment, | |
6127 | instead of positive-or-minus-1 (which might have overflowed int anyway). | |
6128 | Don't stuff ptrdiff_t into int. | |
6129 | (syntax_spec_code, syntax_code_spec): Now const. | |
6130 | (Fmatching_paren, scan_lists, scan_sexps_forward): | |
6131 | Use enum syntaxcode for syntax code. | |
6132 | (Fmatching_paren): Check that arg is a character, not just an integer. | |
6133 | (Fstring_to_syntax): Don't assume 0377 fits in enum syntaxcode. | |
6134 | (Finternal_describe_syntax_value): Omit no-longer-needed | |
6135 | comparison to 0. | |
6136 | (skip_chars): Use char, not unsigned char, when the distinction | |
6137 | doesn't matter. | |
6138 | (forw_comment, scan_lists): Prefer A |= B to A = A || B when B's cheap. | |
6139 | * bytecode.c (exec_byte_code): | |
6140 | * syntax.c (syntax_spec_code, Fchar_syntax) | |
6141 | (Finternal_describe_syntax_value, skip_chars, skip_syntaxes) | |
6142 | (init_syntax_once): | |
6143 | * syntax.h (SYNTAX_WITH_FLAGS): | |
6144 | Omit unnecessary casts. | |
6145 | ||
b932cad7 EZ |
6146 | 2013-06-20 Eli Zaretskii <eliz@gnu.org> |
6147 | ||
6148 | * w32fns.c (w32_wnd_proc): Don't compute the header line and mode | |
6149 | line dimensions here, to avoid race conditions with the main | |
6150 | thread. (Bug#14062, bug#14630, bug#14669) | |
6151 | ||
6152 | * w32term.c (w32_draw_window_cursor): Compute the header line and | |
6153 | mode line dimensions here. | |
6154 | <w32_system_caret_window, w32_system_caret_hdr_height>: | |
6155 | <w32_system_caret_mode_height>: New variables. | |
6156 | ||
6157 | * w32term.h: Declare them. | |
6158 | ||
89561f72 PE |
6159 | 2013-06-20 Paul Eggert <eggert@cs.ucla.edu> |
6160 | ||
5013fc08 PE |
6161 | * alloc.c (die): Move "assertion failed" string here ... |
6162 | * lisp.h (eassert): ... from here. Also, suppress evaluation of | |
6163 | COND when SUPPRESS_CHECKING. This shrinks the executable text | |
6164 | size by 0.8% to 2.2% when configured with --enable-checking, | |
6165 | depending on optimization flags (GCC 4.8.1 x86-64). | |
6166 | ||
89561f72 PE |
6167 | * floatfns.c (Flog10): Move to Lisp (marked obsolete there). |
6168 | ||
763a086d | 6169 | 2013-06-20 Rüdiger Sonderfeld <ruediger@c-plusplus.de> |
89561f72 PE |
6170 | |
6171 | * floatfns.c (Flog) [HAVE_LOG2]: Use log2 if available and if the | |
6172 | base is 2; this is more accurate. | |
6173 | ||
983aeb9a JB |
6174 | 2013-06-19 Juanma Barranquero <lekktu@gmail.com> |
6175 | ||
6176 | * sound.c (string_default): Move to !WINDOWSNT section. | |
6177 | (Fplay_sound_internal) [WINDOWSNT]: Remove i_result to avoid warning. | |
6178 | ||
178ba3e6 PE |
6179 | 2013-06-19 Paul Eggert <eggert@cs.ucla.edu> |
6180 | ||
bbc51b15 PE |
6181 | * sound.c: Integer cleanups. |
6182 | Remove unnecessary forward decls. | |
6183 | (struct sound_device): The 'file' member is now a Lisp_Object, not | |
6184 | a char *, so that we needn't invoke alloca on a huge size. | |
6185 | (Fplay_sound_internal): Adjust to this. | |
6186 | (string_default): New function. | |
6187 | (vox_open, vox_init, alsa_open, alsa_configure, alsa_init): | |
6188 | Use it to adjust to the struct sound_device change. | |
6189 | (parse_sound, wav_init, au_init, alsa_init): Use bool for booleans. | |
6190 | (be2hs) [0]: Remove. | |
6191 | ||
178ba3e6 PE |
6192 | * syntax.c (skip_chars): Don't use uninitialized storage |
6193 | when searching a multibyte buffer for characters that are not in a | |
6194 | unibyte string that contains non-ASCII characters. | |
6195 | ||
69f60cdc JD |
6196 | 2013-06-18 Jan Djärv <jan.h.d@swipnet.se> |
6197 | ||
6198 | * process.c: Include xgselect.h if HAVE_GLIB. Include glib.h | |
6199 | if HAVE_GLIB && ! WINDOWSNT (Bug#14654). | |
6200 | ||
0d6224d4 PE |
6201 | 2013-06-18 Paul Eggert <eggert@cs.ucla.edu> |
6202 | ||
6203 | * conf_post.h: Add comments for INLINE, EXTERN_INLINE, etc. | |
6204 | ||
3c542890 KH |
6205 | 2013-06-18 Kenichi Handa <handa@gnu.org> |
6206 | ||
f7e3f7cd KH |
6207 | * font.c (Ffont_spec): Signal an error for an invalid font name |
6208 | (Bug#14648). | |
3c542890 | 6209 | |
9349e5f7 PE |
6210 | 2013-06-18 Paul Eggert <eggert@cs.ucla.edu> |
6211 | ||
6212 | Porting fixes for merged specpdl and backtrace stacks (Bug#14643). | |
6213 | In particular this ports to 32-bit sparc Sun cc. | |
6214 | * eval.c (init_eval_once, grow_specpdl): Allocate a specbinding | |
6215 | array with a dummy element at specpdl[-1], so that its address can | |
6216 | be taken portably. | |
6217 | (unbind_to): Do not copy the binding; not needed, now that we | |
6218 | copy old_value in the one place where the copy is needed. | |
6219 | * fileio.c (Fwrite_region): Use ptrdiff_t, not int, for specpdl count. | |
6220 | * lisp.h (BITS_PER_PTRDIFF_T): Remove; no longer needed. | |
6221 | (union specbinding): Rename from struct specbinding. Redo layout | |
6222 | to avoid the need for 'ptrdiff_t nargs : BITS_PER_PTRDIFF_T - 1;', | |
6223 | which is not portable. With Sun C 5.12 32-bit sparc, the | |
6224 | declaration causes nargs to be an unsigned bitfield, a behavior | |
6225 | that the C standard allows; but Emacs wants nargs to be signed. | |
6226 | The overall type is now a union of structures rather than a | |
6227 | structure of union of structures, and the 'kind' member is now a | |
6228 | bitfield, so that the overall type doesn't grow. All uses changed. | |
6229 | * process.c (Fmake_serial_process): Remove unnecessary initialization. | |
6230 | ||
0a4df6a5 PE |
6231 | 2013-06-17 Paul Eggert <eggert@cs.ucla.edu> |
6232 | ||
ec6ecaad PE |
6233 | * frame.c (x_report_frame_params): Cast parent_desc to uintptr_t. |
6234 | Needed if HAVE_NTGUI. Reported by Juanma Barranquero. | |
6235 | ||
0a4df6a5 PE |
6236 | * nsfont.m (ns_registry_to_script): Parenthesize while expression. |
6237 | ||
7bfe8dbc EZ |
6238 | 2013-06-17 Eli Zaretskii <eliz@gnu.org> |
6239 | ||
6240 | * w32fns.c (w32_wnd_proc): Don't call WINDOW_HEADER_LINE_HEIGHT | |
6241 | unless we know that the window w's frame is a frame object. | |
6242 | Another attempt at solving bug#14062 and bug#14630. | |
6243 | ||
708e05f6 LMI |
6244 | 2013-06-17 Lars Magne Ingebrigtsen <larsi@gnus.org> |
6245 | ||
6246 | * textprop.c (property_set_type): New enum. | |
6247 | (add_properties): Allow appending/prepending text properties. | |
6248 | (add_text_properties_1): Factored out of Fadd_text_properties. | |
ef099a94 | 6249 | (Fadd_text_properties): Move all the code into |
708e05f6 LMI |
6250 | add_text_properties_1. |
6251 | (Fadd_face_text_property): New function that calls | |
6252 | add_text_properties_1. | |
6253 | ||
84575e67 PE |
6254 | 2013-06-17 Paul Eggert <eggert@cs.ucla.edu> |
6255 | ||
6256 | Move functions from lisp.h to individual modules when possible. | |
6257 | From a suggestion by Andreas Schwab in <http://bugs.gnu.org/11935#68>. | |
6258 | * alloc.c (XFLOAT_INIT, set_symbol_name): | |
6259 | * buffer.c (CHECK_OVERLAY): | |
6260 | * chartab.c (CHECK_CHAR_TABLE, set_char_table_ascii) | |
6261 | (set_char_table_parent): | |
6262 | * coding.c (CHECK_NATNUM_CAR, CHECK_NATNUM_CDR): | |
6263 | * data.c (BOOLFWDP, INTFWDP, KBOARD_OBJFWDP, OBJFWDP, XBOOLFWD) | |
6264 | (XKBOARD_OBJFWD, XINTFWD, XOBJFWD, CHECK_SUBR, set_blv_found) | |
6265 | (blv_value, set_blv_value, set_blv_where, set_blv_defcell) | |
6266 | (set_blv_valcell): | |
6267 | * emacs.c (setlocale) [!HAVE_SETLOCALE]: | |
6268 | * eval.c (specpdl_symbol, specpdl_old_value, specpdl_where) | |
6269 | (specpdl_arg, specpdl_func, backtrace_function, backtrace_nargs) | |
6270 | (backtrace_args, backtrace_debug_on_exit): | |
6271 | * floatfns.c (CHECK_FLOAT): | |
6272 | * fns.c (CHECK_HASH_TABLE, CHECK_LIST_END) | |
6273 | (set_hash_key_and_value, set_hash_next, set_hash_next_slot) | |
6274 | (set_hash_hash, set_hash_hash_slot, set_hash_index) | |
6275 | (set_hash_index_slot): | |
6276 | * keymap.c (CHECK_VECTOR_OR_CHAR_TABLE): | |
6277 | * marker.c (CHECK_MARKER): | |
6278 | * textprop.c (CHECK_STRING_OR_BUFFER): | |
6279 | * window.c (CHECK_WINDOW_CONFIGURATION): | |
6280 | Move here from lisp.h, and make these functions static rather than | |
6281 | extern inline. | |
6282 | * buffer.c (Qoverlayp): | |
6283 | * data.c (Qsubrp): | |
6284 | * fns.c (Qhash_table_p): | |
6285 | * window.c (Qwindow_configuration_p): | |
6286 | Now static. | |
6287 | * lisp.h: Remove the abovementioned defns and decls. | |
6288 | ||
44e18199 | 6289 | Use functions, not macros, for XINT etc (Bug#11935). |
84575e67 PE |
6290 | In lisp.h, prefer functions to function-like macros, and |
6291 | constants to object-like macros, when either will do. This: | |
6292 | . simplifies use, as there's no more need to worry about | |
6293 | arguments' side effects being evaluated multiple times. | |
6294 | . makes the code easier to debug on some platforms. | |
6295 | However, when using gcc -O0, keep using function-like macros | |
6296 | for a few critical operations, for performance reasons. | |
6297 | This sort of thing isn't needed with gcc -Og, but -Og | |
6298 | is a GCC 4.8 feature and isn't widely-enough available yet. | |
6299 | * alloc.c (gdb_make_enums_visible) [USE_LSB_TAG]: | |
6300 | Remove enum lsb_bits; no longer needed. | |
6301 | (allocate_misc, free_misc): Don't use XMISCTYPE as an lvalue. | |
6302 | * buffer.c (Qoverlap): | |
6303 | * data.c (Qsubrp): | |
6304 | * fns.c (Qhash_table_p): | |
6305 | Now extern, so lisp.h can use these symbols. | |
6306 | * dispextern.h: Include character.h, for MAX_CHAR etc. | |
6307 | (GLYPH, GLYPH_CHAR, GLYPH_FACE, SET_GLYPH_CHAR, SET_GLYPH_FACE) | |
6308 | (SET_GLYPH, GLYPH_CODE_CHAR, GLYPH_CODE_FACE) | |
6309 | (SET_GLYPH_FROM_GLYPH_CODE, GLYPH_MODE_LINE_FACE, GLYPH_CHAR_VALID_P) | |
6310 | (GLYPH_CODE_P): Move here from lisp.h. | |
6311 | (GLYPH_CHAR, GLYPH_FACE, GLYPH_CODE_CHAR, GLYPH_CODE_FACE) | |
6312 | (GLYPH_CHAR_VALID_P, GLYPH_CODE_P): Now functions, not macros. | |
6313 | (GLYPH_MODE_LINE_FACE): Now enums, not macros. | |
6314 | * eval.c (Fautoload): Cast XUNTAG output to intptr_t, since | |
6315 | XUNTAG now returns void *. | |
6316 | * lisp.h (lisp_h_XLI, lisp_h_XIL, lisp_h_CHECK_LIST_CONS) | |
6317 | (lisp_h_CHECK_NUMBER CHECK_SYMBOL, lisp_h_CHECK_TYPE) | |
6318 | (lisp_h_CONSP, lisp_h_EQ, lisp_h_FLOATP, lisp_h_INTEGERP) | |
6319 | (lisp_h_MARKERP, lisp_h_MISCP, lisp_h_NILP) | |
6320 | (lisp_h_SET_SYMBOL_VAL, lisp_h_SYMBOL_CONSTANT_P) | |
6321 | (lisp_h_SYMBOL_VAL, lisp_h_SYMBOLP, lisp_h_VECTORLIKEP) | |
6322 | (lisp_h_XCAR, lisp_h_XCDR, lisp_h_XCONS, lisp_h_XHASH) | |
6323 | (lisp_h_XPNTR, lisp_h_XSYMBOL): | |
6324 | New macros, renamed from their sans-lisp_h_ counterparts. | |
6325 | (XLI, XIL, CHECK_LIST_CONS, CHECK_NUMBER CHECK_SYMBOL) | |
6326 | (CHECK_TYPE, CONSP, EQ, FLOATP, INTEGERP, MARKERP) | |
6327 | (MISCP, NILP, SET_SYMBOL_VAL, SYMBOL_CONSTANT_P, SYMBOL_VAL, SYMBOLP) | |
6328 | (VECTORLIKEP, XCAR, XCDR, XCONS, XHASH, XPNTR, XSYMBOL): | |
6329 | If compiling via GCC without optimization, define these as macros | |
6330 | in addition to inline functions. | |
6331 | To disable this, compile with -DINLINING=0. | |
6332 | (LISP_MACRO_DEFUN, LISP_MACRO_DEFUN_VOID): New macros. | |
6333 | (check_cons_list) [!GC_CHECK_CONS_LIST]: Likewise. | |
6334 | (make_number, XFASTINT, XINT, XTYPE, XUNTAG): Likewise, but | |
6335 | hand-optimize only in the USE_LSB_TAG case, as GNUish hosts do that. | |
6336 | (INTMASK, VALMASK): Now macros, since static values cannot be | |
6337 | accessed from extern inline functions. | |
6338 | (VALMASK): Also a constant, for benefit of old GDB. | |
6339 | (LISP_INT_TAG_P): Remove; no longer needed as the only caller | |
6340 | is INTEGERP, which can fold it in. | |
5165d44a | 6341 | (XLI, XIL, XHASH, XTYPE, XINT, XFASTINT, XUINT) |
84575e67 PE |
6342 | (make_number, XPNTR, XUNTAG, EQ, XCONS, XVECTOR, XSTRING, XSYMBOL) |
6343 | (XFLOAT, XPROCESS, XWINDOW, XTERMINAL, XSUBR, XBUFFER, XCHAR_TABLE) | |
6344 | (XSUB_CHAR_TABLE, XBOOL_VECTOR, make_lisp_ptr, CHECK_TYPE) | |
6345 | (CHECK_STRING_OR_BUFFER, XCAR, XCDR, XSETCAR, XSETCDR, CAR, CDR) | |
6346 | (CAR_SAFE, CDR_SAFE, STRING_MULTIBYTE, SDATA, SSDATA, SREF, SSET) | |
6347 | (SCHARS, STRING_BYTES, SBYTES, STRING_SET_CHARS, STRING_COPYIN, AREF) | |
6348 | (ASIZE, ASET, CHAR_TABLE_REF_ASCII, CHAR_TABLE_REF) | |
6349 | (CHAR_TABLE_SET, CHAR_TABLE_EXTRA_SLOTS, SYMBOL_VAL, SYMBOL_ALIAS) | |
6350 | (SYMBOL_BLV, SYMBOL_FWD, SET_SYMBOL_VAL, SET_SYMBOL_ALIAS) | |
6351 | (SET_SYMBOL_BLV, SET_SYMBOL_FWD, SYMBOL_NAME, SYMBOL_INTERNED_P) | |
6352 | (SYMBOL_INTERNED_IN_INITIAL_OBARRAY_P, SYMBOL_CONSTANT_P) | |
6353 | (XHASH_TABLE, HASH_TABLE_P, CHECK_HASH_TABLE, HASH_KEY, HASH_VALUE) | |
6354 | (HASH_NEXT, HASH_HASH, HASH_INDEX, HASH_TABLE_SIZE) | |
6355 | (XMISC, XMISCANY, XMARKER, XOVERLAY, XSAVE_VALUE, XFWDTYPE) | |
6356 | (XINTFWD, XBOOLFWD, XOBJFWD, XBUFFER_OBJFWD, XKBOARD_OBJFWD) | |
6357 | (XFLOAT_DATA, XFLOAT_INIT, NILP, NUMBERP, NATNUMP) | |
6358 | (RANGED_INTEGERP, CONSP, FLOATP, MISCP, STRINGP, SYMBOLP) | |
6359 | (INTEGERP, VECTORLIKEP, VECTORP, OVERLAYP) | |
6360 | (MARKERP, SAVE_VALUEP, AUTOLOADP, INTFWDP, BOOLFWDP, OBJFWDP) | |
6361 | (BUFFER_OBJFWDP, KBOARD_OBJFWDP, PSEUDOVECTOR_TYPEP) | |
6362 | (PSEUDOVECTORP, WINDOW_CONFIGURATIONP, PROCESSP, WINDOWP) | |
6363 | (TERMINALP, SUBRP, COMPILEDP, BUFFERP, CHAR_TABLE_P) | |
6364 | (SUB_CHAR_TABLE_P, BOOL_VECTOR_P, FRAMEP, IMAGEP, ARRAYP) | |
6365 | (CHECK_LIST, CHECK_LIST_CONS, CHECK_LIST_END, CHECK_STRING) | |
6366 | (CHECK_STRING_CAR, CHECK_CONS, CHECK_SYMBOL, CHECK_CHAR_TABLE) | |
6367 | (CHECK_VECTOR, CHECK_VECTOR_OR_STRING, CHECK_ARRAY) | |
6368 | (CHECK_VECTOR_OR_CHAR_TABLE, CHECK_BUFFER, CHECK_WINDOW) | |
6369 | (CHECK_WINDOW_CONFIGURATION, CHECK_PROCESS, CHECK_SUBR) | |
6370 | (CHECK_NUMBER, CHECK_NATNUM, CHECK_MARKER, XFLOATINT) | |
6371 | (CHECK_FLOAT, CHECK_NUMBER_OR_FLOAT, CHECK_OVERLAY) | |
6372 | (CHECK_NUMBER_CAR, CHECK_NUMBER_CDR, CHECK_NATNUM_CAR) | |
6373 | (CHECK_NATNUM_CDR, FUNCTIONP, SPECPDL_INDEX, LOADHIST_ATTACH) | |
6374 | Now functions. | |
6375 | (check_cons_list) [!GC_CHECK_CONS_LIST]: New empty function. | |
6376 | (LISP_MAKE_RVALUE, TYPEMASK): Remove; no longer needed. | |
6377 | (VALMASK): Define in one place rather than in two, merging the | |
6378 | USE_LSB_TAG parts; this is simpler. | |
6379 | (aref_addr, gc_aset, MOST_POSITIVE_FIXNUM, MOST_NEGATIVE_FIXNUM) | |
6380 | (max, min, struct Lisp_String, UNSIGNED_CMP, ASCII_CHAR_P): | |
6381 | Move up, to avoid use before definition. | |
6382 | Also include "globals.h" earlier, for the same reason. | |
6383 | (make_natnum): New function. | |
6384 | (XUNTAG): Now returns void *, not intptr_t, as this means fewer casts. | |
6385 | (union Lisp_Fwd, BOOLFWDP, BOOL_VECTOR_P, BUFFER_OBJFWDP, BUFFERP) | |
6386 | (CHAR_TABLE_P, CHAR_TABLE_REF_ASCII, CONSP, FLOATP, INTEGERP, INTFWDP) | |
6387 | (KBOARD_OBJFWDP, MARKERP, MISCP, NILP, OBJFWDP, OVERLAYP, PROCESSP) | |
6388 | (PSEUDOVECTORP, SAVE_VALUEP, STRINGP, SUB_CHAR_TABLE_P, SUBRP, SYMBOLP) | |
6389 | (VECTORLIKEP, WINDOWP, Qoverlayp, char_table_ref, char_table_set) | |
6390 | (char_table_translate, Qarrayp, Qbufferp, Qbuffer_or_string_p) | |
6391 | (Qchar_table_p, Qconsp, Qfloatp, Qintegerp, Qlambda, Qlistp, Qmarkerp) | |
6392 | (Qnil, Qnumberp, Qsubrp, Qstringp, Qsymbolp, Qvectorp) | |
6393 | (Qvector_or_char_table_p, Qwholenump, Ffboundp, wrong_type_argument) | |
6394 | (initialized, Qhash_table_p, extract_float, Qprocessp, Qwindowp) | |
6395 | (Qwindow_configuration_p, Qimage): New forward declarations. | |
6396 | (XSETFASTINT): Simplify by rewriting in terms of make_natnum. | |
6397 | (STRING_COPYIN): Remove; unused. | |
6398 | (XCAR_AS_LVALUE, XCDR_AS_LVALUE): Remove these macros, replacing with ... | |
6399 | (xcar_addr, xcdr_addr): New functions. All uses changed. | |
6400 | (IEEE_FLOATING_POINT): Now a constant, not a macro. | |
6401 | (GLYPH, GLYPH_CHAR, GLYPH_FACE, SET_GLYPH_CHAR, SET_GLYPH_FACE) | |
6402 | (SET_GLYPH, GLYPH_CODE_CHAR, GLYPH_CODE_FACE) | |
6403 | (SET_GLYPH_FROM_GLYPH_CODE, GLYPH_MODE_LINE_FACE, GLYPH_CHAR_VALID_P) | |
6404 | (GLYPH_CODE_P): Move to dispextern.h, to avoid define-before-use. | |
6405 | (TYPE_RANGED_INTEGERP): Simplify. | |
6406 | (Qsubrp, Qhash_table_p, Qoverlayp): New extern decls. | |
6407 | (setlocale, fixup_locale, synchronize_system_messages_locale) | |
6408 | (synchronize_system_time_locale) [!HAVE_SETLOCALE]: | |
6409 | Now empty functions, not macros. | |
6410 | (functionp): Return bool, not int. | |
6411 | * window.c (Qwindow_configuration_p): Now extern, | |
6412 | so window.h can use it. | |
6413 | * window.h (Qwindowp): Move decl back to lisp.h. | |
6414 | ||
9583ec36 EZ |
6415 | 2013-06-15 Eli Zaretskii <eliz@gnu.org> |
6416 | ||
6417 | * xdisp.c (Fline_pixel_height): New function, required for solving | |
6418 | bug #14567. | |
6419 | ||
210272ce PE |
6420 | 2013-06-15 Paul Eggert <eggert@cs.ucla.edu> |
6421 | ||
6422 | * fns.c (Fcopy_sequence): Simplify XTYPE calculation. | |
6423 | ||
de0503df SM |
6424 | 2013-06-13 Stefan Monnier <monnier@iro.umontreal.ca> |
6425 | ||
6426 | * lread.c (syms_of_lread): | |
6427 | * fns.c (Fprovide): Adjust to new format of after-load-alist. | |
6428 | ||
afbfe143 KD |
6429 | 2013-06-13 Kelly Dean <kellydeanch@yahoo.com> (tiny change) |
6430 | ||
6431 | * fileio.c (Fdo_auto_save): Trap errors in auto-save-hook. (Bug#14479) | |
6432 | ||
d177e213 XF |
6433 | 2013-06-12 Xue Fuqiao <xfq.free@gmail.com> |
6434 | ||
6435 | * fileio.c (expand_file_name): Doc fix. | |
6436 | ||
05e3e412 PE |
6437 | 2013-06-11 Paul Eggert <eggert@cs.ucla.edu> |
6438 | ||
f7394b12 PE |
6439 | Tickle glib by waiting for Emacs itself, not for process 0 (Bug#14569). |
6440 | * process.c (init_process_emacs) [HAVE_GLIB && !WINDOWSNT]: | |
6441 | Wait for self, not for 0. This can't hurt on GNU or similar | |
6442 | system, and may help with Cygwin. | |
6443 | ||
05e3e412 PE |
6444 | * keyboard.c: Don't use PROP (...) as an lvalue. |
6445 | (parse_tool_bar_item) [!USE_GTK && !HAVE_NS]: | |
6446 | Use set_prop (A, B), not PROP (A) = B. | |
6447 | ||
17dd3097 EZ |
6448 | 2013-06-10 Eli Zaretskii <eliz@gnu.org> |
6449 | ||
6450 | * xdisp.c (get_it_property): Use it->window instead of generating | |
6451 | a Lisp object from it->w. | |
6452 | ||
52fab9c9 EZ |
6453 | 2013-06-09 Eli Zaretskii <eliz@gnu.org> |
6454 | ||
6455 | * xdisp.c (get_it_property): If it->object is a buffer, pass to | |
6456 | get-char-property the window that is being rendered, instead of | |
6457 | the buffer, to support window-specific overlays. (Bug#14575) | |
ad257d4f EZ |
6458 | (compute_display_string_pos): When W is NULL, use the current |
6459 | buffer as the object to pass to get-char-property. | |
6460 | (Fcurrent_bidi_paragraph_direction): Assign NULL to the window | |
6461 | pointer member of the bidi iterator, since no window is pertinent | |
6462 | to this function. | |
52fab9c9 | 6463 | |
5bf97bfc EZ |
6464 | 2013-06-08 Eli Zaretskii <eliz@gnu.org> |
6465 | ||
6466 | * bidi.c (bidi_fetch_char): Accept additional argument, the window | |
6467 | being displayed, and pass it to compute_display_string_pos. | |
6468 | (bidi_level_of_next_char, bidi_resolve_explicit_1) | |
6469 | (bidi_paragraph_init): All callers changed. | |
6470 | ||
6471 | * xdisp.c (init_from_display_pos, init_iterator) | |
6472 | (handle_single_display_spec, next_overlay_string) | |
6473 | (get_overlay_strings_1, reseat_1, reseat_to_string) | |
e7b41c4c JB |
6474 | (push_prefix_prop, Fcurrent_bidi_paragraph_direction): |
6475 | Set bidi_it.w member from it->w. | |
5bf97bfc EZ |
6476 | (compute_display_string_pos): Accept additional argument, the |
6477 | window being displayed, and pass it to Fget_char_property. | |
6478 | (Bug#14575) | |
6479 | ||
6480 | * dispextern.h (struct bidi_it): New member w, the window being | |
6481 | displayed. | |
6482 | (compute_display_string_pos): Adjust prototype. | |
6483 | ||
5de0e011 JD |
6484 | 2013-06-08 Jan Djärv <jan.h.d@swipnet.se> |
6485 | ||
e7b41c4c | 6486 | * xgselect.c: Remove unneeded include xterm.h. |
b33f93ee JD |
6487 | |
6488 | * process.c (wait_reading_process_output): Check for NS before GLIB. | |
6489 | GLIB may be linked in due to rsvg, but ns_select must be called. | |
6490 | ||
5de0e011 JD |
6491 | * xgselect.c (xg_select): Remove call to window_system_available |
6492 | and g_main_context_pending at the top, so Gdk events (i.e. file | |
6493 | notify) are processed when Emacs is started with -nw. | |
6494 | ||
a822acff EZ |
6495 | 2013-06-07 Eli Zaretskii <eliz@gnu.org> |
6496 | ||
6497 | * Makefile.in (ctagsfiles1, ctagsfiles2): Don't include *.m files. | |
6498 | (ctagsfiles3): New variable, includes only *.m files. | |
6499 | (TAGS): Use an explicit language name in the regular expressions, | |
6500 | to avoid transformation of '/SOMETHING' by MSYS to | |
6501 | 'c:\MSYS\SOMETHING'. | |
6502 | ||
6c0a9ed1 RC |
6503 | 2013-06-07 Richard Copley <rcopley@gmail.com> (tiny change) |
6504 | ||
6505 | * epaths.in: Fix commentary to PATH_SITELOADSEARCH. | |
6506 | ||
9ef6111b EZ |
6507 | 2013-06-06 Eli Zaretskii <eliz@gnu.org> |
6508 | ||
6509 | * xdisp.c (note_mouse_highlight): When mouse-highlight is off, | |
6510 | still need to set the mouse pointer shape and activate help-echo. | |
6511 | (Bug#14558) | |
6512 | ||
7d300d64 PE |
6513 | 2013-06-06 Paul Eggert <eggert@cs.ucla.edu> |
6514 | ||
6515 | A few porting etc. fixes for the new file monitor code. | |
6516 | See the thread containing | |
6517 | <http://lists.gnu.org/archive/html/emacs-devel/2013-06/msg00109.html>. | |
6518 | * gfilenotify.c (dir_monitor_callback, Fgfile_add_watch) | |
6519 | (Fgfile_rm_watch): Don't assume EMACS_INT is the same width as a pointer. | |
6520 | (dir_monitor_callback, Fgfile_rm_watch): | |
6521 | Use assq_no_quit instead of Fassoc, for speed. | |
6522 | (dir_monitor_callback, Fgfile_rm_watch): | |
6523 | eassert that the monitor is a fixnum. | |
6524 | (dir_monitor_callback): No need for CDR_SAFE. | |
6525 | Simplify building of lisp with alternative tails. | |
6526 | (Fgfile_add_watch, Fgfile_rm_watch): | |
6527 | Do not assume glib functions set errno reliably on failure. | |
6528 | (Fgfile_add_watch): Check that the monitor survives the XIL trick, | |
6529 | and signal an error otherwise. | |
6530 | (Fgfile_rm_watch): Prefer CONSP to !NILP. | |
6531 | Use Fdelq instead of Fdelete, for speed. | |
6532 | ||
817ebfcf EZ |
6533 | 2013-06-05 Eli Zaretskii <eliz@gnu.org> |
6534 | ||
6535 | * xdisp.c (handle_tool_bar_click): When mouse-highlight is off, | |
6536 | don't insist on being invoked on a highlighted tool-bar button. | |
6537 | Avoids losing tool-bar functionality when mouse-highlight is nil. | |
6538 | (note_tool_bar_highlight, note_mode_line_or_margin_highlight): | |
6539 | Don't highlight when mouse-highlight is nil. | |
6540 | (note_mouse_highlight): When mouse-highlight is nil, don't return | |
6541 | right away; instead, run tool-bar and mode-line highlight | |
6542 | subroutine, clear any existing highlight, and revert the mouse | |
6543 | pointer to its default shape. (Bug#14558) | |
6544 | ||
55577e7c SM |
6545 | 2013-06-05 Stefan Monnier <monnier@iro.umontreal.ca> |
6546 | ||
6547 | * lisp.mk (lisp): Add prog-mode.el. | |
6548 | ||
f019a684 PE |
6549 | 2013-06-05 Paul Eggert <eggert@cs.ucla.edu> |
6550 | ||
6551 | Chain glib's SIGCHLD handler from Emacs's (Bug#14474). | |
6552 | * process.c (dummy_handler): New function. | |
6553 | (lib_child_handler): New static var. | |
6554 | (handle_child_signal): Invoke it. | |
6555 | (catch_child_signal): If a library has set up a signal handler, | |
6556 | save it into lib_child_handler. | |
6557 | (init_process_emacs): If using glib and not on Windows, tickle glib's | |
6558 | child-handling code so that it initializes its private SIGCHLD handler. | |
6559 | * syssignal.h (SA_SIGINFO): Default to 0. | |
6560 | * xterm.c (x_term_init): Remove D-bus hack that I installed on May | |
6561 | 31; it should no longer be needed now. | |
6562 | ||
90db8702 MA |
6563 | 2013-06-05 Michael Albinus <michael.albinus@gmx.de> |
6564 | ||
6565 | * emacs.c (main) [HAVE_GFILENOTIFY]: Call globals_of_gfilenotify. | |
6566 | ||
6567 | * gfilenotify.c (globals_of_gfilenotify): New function. | |
6568 | (syms_of_gfilenotify): Move global initialization there. | |
6569 | ||
6570 | * lisp.h (globals_of_gfilenotify) [HAVE_GFILENOTIFY]: Add prototype. | |
6571 | ||
bfa3acd6 SM |
6572 | 2013-06-05 Stefan Monnier <monnier@iro.umontreal.ca> |
6573 | ||
6574 | * keymap.c (Fcurrent_active_maps, Fdescribe_buffer_bindings): | |
6575 | * keyboard.c (menu_bar_items, tool_bar_items): | |
6576 | * doc.c (Fsubstitute_command_keys): Voverriding_terminal_local_map does | |
6577 | not override local keymaps any more. | |
6578 | ||
ba59bd80 EZ |
6579 | 2013-06-04 Eli Zaretskii <eliz@gnu.org> |
6580 | ||
6581 | * window.c (Fpos_visible_in_window_p): Doc fix. (Bug#14540) | |
6582 | ||
7f203aa1 EZ |
6583 | 2013-06-03 Eli Zaretskii <eliz@gnu.org> |
6584 | ||
9337e206 EZ |
6585 | * w32console.c (initialize_w32_display): Return the dimensions of |
6586 | the console window via 2 additional arguments, not via the current | |
6587 | frame. This avoids crashes due to overrunning the bounds of | |
6588 | frame's decode_mode_spec_buffer, which is not resized following | |
6589 | the change of the frame dimensions from the initial 10x10. | |
6590 | ||
6591 | * w32term.h (w32_initialize_display_info): Adjust prototype. | |
6592 | ||
6593 | * term.c (init_tty): Take dimensions of the frame from the values | |
6594 | returned by initialize_w32_display. | |
6595 | ||
7f203aa1 EZ |
6596 | * Makefile.in (GFILENOTIFY_CFLAGS, GFILENOTIFY_LIBS): New variables. |
6597 | (ALL_CFLAGS): Add $(GFILENOTIFY_CFLAGS). | |
6598 | (LIBES): Add $(GFILENOTIFY_LIBS). | |
6599 | ||
6600 | * w32inevt.c (handle_file_notifications): Add dummy implementation | |
6601 | for !HAVE_W32NOTIFY. | |
6602 | ||
6603 | * w32term.c: Wrap code with HAVE_W32NOTIFY. | |
6604 | ||
55a87246 JD |
6605 | 2013-06-03 Jan Djärv <jan.h.d@swipnet.se> |
6606 | ||
6607 | * xgselect.c: Replace #if defined ... with #ifdef HAVE_GLIB. | |
6608 | ||
6609 | * process.c (wait_reading_process_output): Call xg_select if HAVE_GLIB. | |
6610 | ||
6611 | * Makefile.in (XGSELOBJ): New, xgselect.o if GLib is used, or empty. | |
6612 | ||
3d5ee10a PE |
6613 | 2013-06-03 Paul Eggert <eggert@cs.ucla.edu> |
6614 | ||
6615 | Fix minor problems found by static checking. | |
6616 | * data.c (pure_write_error): | |
6617 | Use xsignal2, not Fsignal, as Fsignal might return. | |
6618 | * eval.c (set_backtrace_debug_on_exit): Now static. | |
6619 | (backtrace_p, backtrace_top, backtrace_next, record_in_backtrace): | |
6620 | No longer inline. EXTERN_INLINE is needed only for functions | |
6621 | defined in .h files. Reindent function header as per GNU style. | |
6622 | (backtrace_p, backtrace_top, backtrace_next): | |
6623 | Mark EXTERNALLY_VISIBLE so they don't get optimized away by the | |
6624 | compiler or linker. Add extern decls to pacify gcc -Wall. | |
6625 | * frame.c, frame.h (Qgeometry, Qworkarea, Qmm_size, Qframes, Qsource): | |
6626 | Now static. | |
6627 | * frame.c (free_monitors): Define only on platforms that need it. | |
6628 | * nsterm.m (ns_term_init): | |
6629 | * process.c (catch_child_signal): | |
6630 | Don't worry about whether SIGCHLD is defined, as SIGCHLD is | |
6631 | defined on all porting targets these days. | |
6632 | * process.c, process.h (catch_child_signal): | |
6633 | Make it extern only if NS_IMPL_GNUSTEP is defined. | |
6634 | ||
e2d8a6f0 EZ |
6635 | 2013-06-03 Eli Zaretskii <eliz@gnu.org> |
6636 | ||
6637 | * w32.c (gettimeofday): Make the signature identical to prototype | |
6638 | in nt/inc/sys/time.h. | |
6639 | ||
a8a7c5f6 SM |
6640 | 2013-06-03 Stefan Monnier <monnier@iro.umontreal.ca> |
6641 | ||
6642 | * eval.c (backtrace_p, backtrace_top, backtrace_next): Export them to | |
6643 | .gdbinit. | |
6644 | ||
6645 | * keyboard.c (safe_run_hooks_error): Improve error message. | |
6646 | ||
6647 | * data.c (pure_write_error): Add `object' argument. | |
6648 | * puresize.h (CHECK_IMPURE): Use it. | |
6649 | ||
c9628c79 MA |
6650 | 2013-06-03 Michael Albinus <michael.albinus@gmx.de> |
6651 | ||
6652 | * Makefile.in (NOTIFY_OBJ): New variable. | |
6653 | (base_obj): Replace inotify.o by $(NOTIFY_OBJ). | |
6654 | ||
6655 | * emacs.c (main): Use HAVE_W32NOTIFY to wrap respective code. | |
6656 | Call syms_of_gfilenotify. | |
6657 | ||
6658 | * gfilenotify.c: New file. | |
6659 | ||
6660 | * keyboard.c (Qfile_notify): New variable. Replaces Qfile_inotify | |
6661 | and Qfile_w32notify. | |
6662 | (top): Wrap respective code by HAVE_GFILENOTIFY, HAVE_INOTIFY, | |
6663 | HAVE_W32NOTIFY and USE_FILE_NOTIFY. | |
6664 | ||
6665 | * lisp.h: Declare syms_of_gfilenotify. | |
6666 | ||
6667 | * termhooks.h (e): Wrap enum by USE_FILE_NOTIFY. | |
6668 | ||
2f592f95 SM |
6669 | 2013-06-03 Stefan Monnier <monnier@iro.umontreal.ca> |
6670 | ||
6671 | Merge the specpdl and backtrace stacks. Make the structure of the | |
6672 | specpdl entries more obvious via a tagged union of structs. | |
6673 | * lisp.h (BITS_PER_PTRDIFF_T): New constant. | |
6674 | (enum specbind_tag): New enum. | |
6675 | (struct specbinding): Make it a tagged union of structs. | |
6676 | Add a case for backtrace records. | |
6677 | (specpdl_symbol, specpdl_old_value, specpdl_where, specpdl_arg) | |
6678 | (specpdl_func, backtrace_function, backtrace_nargs, backtrace_args) | |
6679 | (backtrace_debug_on_exit): New accessors. | |
6680 | (struct backtrace): Remove. | |
6681 | (struct catchtag): Remove backlist field. | |
6682 | * data.c (let_shadows_buffer_binding_p, let_shadows_global_binding_p): | |
6683 | Move to eval.c. | |
6684 | (Flocal_variable_p): Speed up the common case where the binding is | |
6685 | already loaded. | |
6686 | * eval.c (backtrace_list): Remove. | |
6687 | (set_specpdl_symbol, set_specpdl_old_value): Remove. | |
6688 | (set_backtrace_args, set_backtrace_nargs) | |
6689 | (set_backtrace_debug_on_exit, backtrace_p, backtrace_top) | |
6690 | (backtrace_next): New functions. | |
6691 | (Fdefvaralias, Fdefvar): Adjust to new specpdl format. | |
6692 | (unwind_to_catch, internal_lisp_condition_case) | |
6693 | (internal_condition_case, internal_condition_case_1) | |
6694 | (internal_condition_case_2, internal_condition_case_n): Don't bother | |
6695 | with backtrace_list any more. | |
6696 | (Fsignal): Adjust to new backtrace format. | |
6697 | (grow_specpdl): Move up. | |
6698 | (record_in_backtrace): New function. | |
6699 | (eval_sub, Ffuncall): Use it. | |
6700 | (apply_lambda): Adjust to new backtrace format. | |
6701 | (let_shadows_buffer_binding_p, let_shadows_global_binding_p): Move from | |
6702 | data.c. | |
6703 | (specbind): Adjust to new specpdl format. Simplify. | |
6704 | (record_unwind_protect, unbind_to): Adjust to new specpdl format. | |
6705 | (Fbacktrace_debug, Fbacktrace, Fbacktrace_frame): Adjust to new | |
6706 | backtrace format. | |
6707 | (mark_backtrace): Remove. | |
6708 | (mark_specpdl, get_backtrace, backtrace_top_function): New functions. | |
6709 | * xdisp.c (redisplay_internal): Use record_in_backtrace. | |
6710 | * alloc.c (Fgarbage_collect): Use record_in_backtrace. | |
6711 | Use mark_specpdl. | |
6712 | * profiler.c (record_backtrace): Use get_backtrace. | |
6713 | (handle_profiler_signal): Use backtrace_top_function. | |
6714 | * .gdbinit (xbacktrace, hookpost-backtrace): Use new backtrace | |
6715 | accessor functions. | |
6716 | ||
c0342369 JD |
6717 | 2013-06-02 Jan Djärv <jan.h.d@swipnet.se> |
6718 | ||
6719 | * process.h (catch_child_signal): Declare. | |
6720 | ||
6721 | * process.c (catch_child_signal): New function. | |
6722 | (init_process_emacs): Call it. | |
6723 | ||
6724 | * nsterm.m: Include process.h if NS_IMPL_GNUSTEP. | |
6725 | (ns_menu_bar_is_hidden, menu_will_open_state): Define only if | |
6726 | NS_IMPL_COCOA. | |
6727 | (x_set_cursor_type): Remove declaration. | |
6728 | (ns_update_begin): Only use r and bp if NS_IMPL_COCOA. | |
6729 | (ns_update_end, ns_focus, ns_unfocus): Remove GNUStep specific code. | |
6730 | (x_set_window_size): Remove 3 pixels from toolbar if NS_IMPL_GNUSTEP. | |
6731 | (ns_get_color): Use F suffix on float. | |
6732 | (ns_color_to_lisp, ns_query_color): Use EmacsCGFloat. | |
6733 | (ns_get_rgb_color): Remove. | |
6734 | (x_set_frame_alpha): Move view inside NS_IMPL_COCOA. | |
6735 | (note_mouse_movement): x and y are CGFloat. | |
6736 | (ns_draw_fringe_bitmap): Remove unused rowY. | |
6737 | Change #if to COCOA && >= 10_6. | |
6738 | (ns_draw_window_cursor): Remove unused overspill. | |
6739 | (ns_draw_underwave): width and x are EamcsCGFloat. | |
6740 | (ns_draw_box): thickness is CGFloat. | |
6741 | (ns_dumpglyphs_image): Change #if to COCOA && >= 10_6. | |
6742 | (ns_send_appdefined): When NS_IMPL_GNUSTEP, redirect to main thread | |
6743 | if not in main thread. | |
6744 | (ns_get_pending_menu_title, ns_check_menu_open) | |
6745 | (ns_check_pending_open_menu): Put inside #if COCOA && >= 10_5. | |
6746 | (ns_term_init): Call catch_child_signal if NS_IMPL_GNUSTEP && SIGCHLD. | |
6747 | (sendFromMainThread:): New method. | |
6748 | (changeFont:): size is CGFloat. | |
6749 | (keyDown:): Check for Delete when NS_IMPL_GNUSTEP. | |
6750 | Disable warning about permanent text. | |
6751 | (characterIndexForPoint:): Adjust return type depending on GNUStep | |
6752 | version. | |
6753 | (mouseDown:): delta is CGFloat. | |
6754 | (updateFrameSize): Remove unised variable f. | |
6755 | (initFrameFromEmacs): Move toggleButton inside NS_IMPL_COCOA. | |
6756 | Cast float to EmacsCGFloat. | |
6757 | (windowWillUseStandardFrame:defaultFrame:): Set maximized_height | |
6758 | also to -1 when restoring. | |
6759 | (windowDidExitFullScreen:): Put call to updateCollectionBehaviour | |
6760 | inside NS_IMPL_COCOA. | |
6761 | (toggleFullScreen:): Put call to toggleFullScreen inside | |
6762 | NS_IMPL_COCOA. Cast float to EmacsCGFloat. | |
6763 | (setPosition:portion:whole:): por is CGFloat. | |
6764 | (getMouseMotionPart:window:x:y:): Add F suffix to float. | |
6765 | (mouseDown:): Use CGFloat. | |
6766 | (mouseDragged:): Remove unised variable edge. | |
6767 | (EmacsDocument): Implement for NS_IMPL_GNUSTEP. | |
6768 | ||
6769 | * nsterm.h (EmacsCGFloat): Typedef for OSX and GNUStep when the size | |
6770 | of CGFloat differs. | |
6771 | (EmacsApp): New variable nextappdefined. Declare sendFromMainThread | |
6772 | when NS_IMPL_GNUSTEP. | |
6773 | (EmacsDocument): Declare when NS_IMPL_GNUSTEP. | |
6774 | (EmacsView): Remove unlockFocusNeedsFlush, add windowDidMove. | |
6775 | (EmacsToolbar): Add clearAll. Add tag argument to | |
6776 | addDisplayItemWithImage. | |
6777 | (EmacsSavePanel, EmacsOpenPanel): Remove getFilename and getDirectory. | |
6778 | ||
6779 | * nsselect.m (ns_get_local_selection): Remove unused variable type. | |
6780 | ||
6781 | * nsmenu.m (ns_update_menubar): Make static. | |
6782 | (x_activate_menubar): Surround with ifdef NS_IMPL_COCOA | |
6783 | (fillWithWidgetValue:): Add cast to SEL for setAction. | |
6784 | (addSubmenuWithTitle:forFrame:): Add cast to SEL for action. | |
6785 | (update_frame_tool_bar): Update code for GNUStep. | |
6786 | (clearAll): New method. | |
6787 | (addDisplayItemWithImage:idx:tag:helpText:enabled:): Handle new tag | |
4f405069 | 6788 | argument. Call insertItemWithItemIdentifier when NS_IMPL_GNUSTEP. |
e7b41c4c | 6789 | Move identifierToItem setObject and activeIdentifiers addObject before |
c0342369 JD |
6790 | call to insertItemWithItemIdentifier. |
6791 | (validateVisibleItems): Fix indentation. | |
6792 | (toolbarAllowedItemIdentifiers:): Return activeIdentifiers. | |
6793 | (initWithContentRect:styleMask:backing:defer:): Add ClosableWindow and | |
6794 | UtilityWindow to aStyle, remove call to setStyleMask. | |
6795 | ||
6796 | * nsimage.m (setXBMColor:, getPixelAtX:Y:): Use EmacsCGFloat. | |
6797 | ||
6798 | * nsfont.m (ns_attribute_fvalue, ns_spec_to_descriptor) | |
6799 | (ns_charset_covers, ns_get_covering_families, nsfont_open): | |
6800 | Use F suffix on floats. | |
6801 | (ns_char_width): Returns CGFloat. | |
6802 | (ns_ascii_average_width): w is CGFloat instead of float. | |
e7b41c4c | 6803 | (nsfont_draw): cbuf and c are unsigned. Cast to char* in call to |
c0342369 JD |
6804 | DPSxshow. |
6805 | (ns_glyph_metrics): CGFloat instead of float. | |
6806 | ||
a0eb10b3 JB |
6807 | * nsfns.m (x_set_foreground_color, x_set_background_color): |
6808 | Use EmacsCGFloat. | |
6809 | (ns_implicitly_set_icon_type, Fx_create_frame): Make static, | |
6810 | remove unused variables. | |
6811 | (Fns_read_file_name): Keep track if panel is for save. | |
6812 | Use ns_filename_from_panel/ns_directory_from_panel. | |
c0342369 | 6813 | (Fns_list_services): delegate only used for COCOA. |
a0eb10b3 JB |
6814 | (Fns_convert_utf8_nfd_to_nfc): Remove warning for GNUStep. |
6815 | Just return the input if GNUStep. | |
c0342369 JD |
6816 | (x_screen_planes): Remove. |
6817 | (Fxw_color_values): Use EmacsCGFloat | |
6818 | (Fns_display_monitor_attributes_list): Only get screen number for | |
6819 | Cocoa. | |
ef099a94 | 6820 | (getDirectory, getFilename): Remove from EmacsOpenPanel and |
c0342369 JD |
6821 | EmacsSavePanel. |
6822 | (EmacsOpenPanel:ok:): Use ns_filename_from_panel and | |
6823 | ns_directory_from_panel. | |
6824 | ||
da9aff11 PE |
6825 | 2013-06-01 Paul Eggert <eggert@cs.ucla.edu> |
6826 | ||
6827 | * process.c (handle_child_signal): Also use WCONTINUED. | |
6828 | This is so that list-processes doesn't mistakenly list the process | |
6829 | as stopped, when the process has actually been continued and is | |
6830 | now running. | |
6831 | ||
0e64479a PE |
6832 | 2013-05-31 Paul Eggert <eggert@cs.ucla.edu> |
6833 | ||
fc186a96 PE |
6834 | Don't let D-bus autolaunch mess up SIGCHLD handling (Bug#14474). |
6835 | * xterm.c (x_term_init): Inhibit D-Bus autolaunch if D-Bus is | |
6836 | not already configured. | |
6837 | ||
0e64479a PE |
6838 | * fileio.c (Finsert_file_contents): Remove unused local (Bug#8447). |
6839 | ||
38b787fa EZ |
6840 | 2013-05-29 Eli Zaretskii <eliz@gnu.org> |
6841 | ||
6842 | * Makefile.in (mostlyclean): Remove *.res files. | |
6843 | ||
22513e52 SM |
6844 | 2013-05-29 Stefan Monnier <monnier@iro.umontreal.ca> |
6845 | ||
6846 | * fileio.c (Finsert_file_contents): Preserve undo info when reverting | |
6847 | a buffer (bug#8447). | |
6848 | ||
6ef3db10 EZ |
6849 | 2013-05-27 Eli Zaretskii <eliz@gnu.org> |
6850 | ||
6851 | * xdisp.c (pos_visible_p): When CHARPOS is displayed frrom a | |
6852 | display vector, and we backtrack, handle the case that the | |
6853 | previous character position is also displayed from a display | |
6854 | vector or covered by a display string or image. (Bug#14476) | |
6855 | ||
6799bb26 JD |
6856 | 2013-05-25 Jan Djärv <jan.h.d@swipnet.se> |
6857 | ||
6858 | * xfns.c (Qgeometry, Qworkarea, Qmm_size, Qframes, Qsource): Remove. | |
6859 | (struct MonitorInfo, free_monitors): Remove. | |
6860 | (x_make_monitor_attribute_list): Call make_monitor_attribute_list. | |
6861 | (Fx_display_monitor_attributes_list): Call make_monitor_attribute_list. | |
6862 | (syms_of_xfns): Remove DEFSYM for Qgeometry, Qworkarea, Qmm_size, | |
6863 | Qframes, Qsource. | |
6864 | ||
6865 | * nsfns.m (Qgeometry, Qworkarea, Qmm_size, Qframes, Qsource): Remove. | |
6866 | (struct MonitorInfo, free_monitors): Remove. | |
6867 | (ns_screen_name): Make static. | |
6868 | (ns_make_monitor_attribute_list): Call make_monitor_attribute_list. | |
6869 | (syms_of_nsfns): Remove DEFSYM for Qgeometry, Qworkarea, Qmm_size, | |
6870 | Qframes, Qsource. | |
6871 | ||
6872 | * frame.h (Qgeometry, Qworkarea, Qmm_size, Qframes, Qsource): Declare. | |
6873 | (struct MonitorInfo): New struct. | |
6874 | (free_monitors, make_monitor_attribute_list): Declare. | |
6875 | ||
22513e52 SM |
6876 | * frame.c (Qgeometry, Qworkarea, Qmm_size, Qframes, Qsource): |
6877 | New Lisp_Object:s. | |
6799bb26 JD |
6878 | (free_monitors, make_monitor_attribute_list): New functions. |
6879 | (syms_of_frame): DEFSYM Qgeometry, Qworkarea, Qmm_size, Qframes, | |
6880 | Qsource. | |
6881 | ||
38cd43eb XF |
6882 | 2013-05-25 Xue Fuqiao <xfq.free@gmail.com> |
6883 | ||
6884 | * callproc.c (call_process): Refine the doc string. (Bug#14045) | |
6885 | ||
2af0948d SM |
6886 | 2013-05-23 Stefan Monnier <monnier@iro.umontreal.ca> |
6887 | ||
a7eb9b0f SM |
6888 | * keyboard.c: Apply keyboard decoding only to events that come directly |
6889 | from the tty, not from unread-command-events (bug#14368). | |
6890 | (read_event_from_main_queue): New function, extracted from read_char). | |
6891 | (read_decoded_char): Remove. | |
6892 | (read_decoded_event_from_main_queue): New function to replace it. | |
6893 | (read_char): Use it. | |
6894 | (read_key_sequence): Use read_char rather than read_decoded_char. | |
6895 | ||
2af0948d SM |
6896 | * keyboard.c (read_decoded_char): Don't decode under w32 (bug#14403). |
6897 | ||
9698f11c | 6898 | 2013-05-22 Barry O'Reilly <gundaetiapo@gmail.com> |
1413e9a5 BR |
6899 | |
6900 | * casetab.c (init_casetab_once): Fix last change (bug#14424). | |
6901 | ||
e6d2f155 KH |
6902 | 2013-05-22 Kenichi Handa <handa@gnu.org> |
6903 | ||
6904 | The following changes are to fix the setting of | |
6905 | buffer-file-coding-system on, for instance, C-x RET c unix RET | |
6906 | _FILE_OF_DOS_EOL_TYPE_ RET. | |
6907 | ||
6908 | * coding.h (struct coding_system): New member detected_utf8_chars. | |
6909 | ||
6910 | * coding.c (detect_coding_utf_8): Count characters and check EOL | |
6911 | format. Include CATEGORY_MASK_UTF_8_AUTO in detect_info->found if | |
6912 | BOM is there. | |
6913 | (setup_coding_system): Do not initialize coding->head_ascii. | |
6914 | (check_ascii): Do not set coding->eol_seen but update it. Do not | |
6915 | call adjust_coding_eol_type here. | |
1413e9a5 BR |
6916 | (detect_coding): Fix detection of BOM for utf-8 and utf-16. |
6917 | If the eol-type of CODING is already specified, adjust the eol type | |
e6d2f155 KH |
6918 | of the found coding-system. |
6919 | (decode_coding_gap): Cancel previous change. Utilize the | |
6920 | character numbers counted by detect_coding_utf_8. Fix detection | |
6921 | of BOM for utf-8. | |
6922 | ||
9698f11c | 6923 | 2013-05-21 Barry O'Reilly <gundaetiapo@gmail.com> |
fc30d803 SM |
6924 | |
6925 | * search.c (looking_at_1): Only set last_thing_searched if the match | |
6926 | changed the match-data (bug#14281). | |
6927 | ||
ecc3c6ed DA |
6928 | 2013-05-21 Dmitry Antipov <dmantipov@yandex.ru> |
6929 | ||
6930 | * xdisp.c (reseat_at_previous_visible_line_start): | |
a0eb10b3 | 6931 | Already declared in dispextern.h, so remove it here. |
ecc3c6ed DA |
6932 | (move_it_vertically_backward): Likewise. |
6933 | ||
5ba8bf35 YM |
6934 | 2013-05-20 YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp> |
6935 | ||
6936 | * xfns.c (check_x_display_info): Don't use XINT for terminal object. | |
d6635ba2 | 6937 | (Fx_display_pixel_width, Fx_display_pixel_height) |
fc30d803 SM |
6938 | (Fx_display_mm_width, Fx_display_mm_height): |
6939 | Mention `display-monitor-attributes-list' in docstrings. | |
5ba8bf35 | 6940 | |
91e8418b | 6941 | * nsfns.m (ns_get_screen): Remove function. All uses removed. |
a0eb10b3 | 6942 | (check_ns_display_info): Sync with check_x_display_info in xfns.c. |
91e8418b YM |
6943 | (Fx_server_max_request_size, Fx_server_vendor, Fx_server_version) |
6944 | (Fx_display_screens, Fx_display_mm_width, Fx_display_mm_height) | |
6945 | (Fx_display_backing_store, Fx_display_visual_class) | |
6946 | (Fx_display_save_under, Fx_close_connection, Fxw_display_color_p) | |
6947 | (Fx_display_grayscale_p, Fx_display_pixel_width) | |
6948 | (Fx_display_pixel_height, Fx_display_planes) | |
6949 | (Fx_display_color_cells): Sync args and docstrings with xfns.c. | |
6950 | (Fx_display_screens): Don't confuse X11 screens with NS screens. | |
6951 | (Fx_display_mm_width, Fx_display_mm_height) | |
6952 | (Fx_display_pixel_width, Fx_display_pixel_width): Return width or | |
6953 | height for all physical monitors as in X11. | |
6954 | ||
fc30d803 SM |
6955 | * nsterm.m (x_display_pixel_width, x_display_pixel_height): |
6956 | Return pixel width or height for all physical monitors as in X11. | |
91e8418b | 6957 | |
31ff141c PE |
6958 | 2013-05-18 Paul Eggert <eggert@cs.ucla.edu> |
6959 | ||
6960 | Port --enable-gcc-warnings to clang. | |
6961 | * bytecode.c (exec_byte_code): | |
6962 | * regex.c: | |
6963 | Redo diagnostic pragmas to pacify clang, too. | |
6964 | * dbusbind.c (xd_retrieve_arg): Do not use uninitialized variable. | |
6965 | * editfns.c (Fencode_time): | |
6966 | * fileio.c (file_accessible_directory_p): | |
6967 | * font.c (font_unparse_xlfd): | |
6968 | Use '&"string"[index]' instead of '"string" + (index)'. | |
6969 | * undo.c (user_error): Remove; unused. | |
6970 | ||
df065a0b EZ |
6971 | 2013-05-16 Eli Zaretskii <eliz@gnu.org> |
6972 | ||
04d360e7 EZ |
6973 | * insdel.c (insert_1_both): Document the arguments, instead of |
6974 | referring to insert_1, which no longer exists. | |
6975 | ||
5bb98290 EZ |
6976 | * xdisp.c (message_dolog): If the *Messages* buffer is shown in |
6977 | some window, increment windows_or_buffers_changed, so that | |
6978 | *Messages* display in that window is updated. (Bug#14408) | |
6979 | ||
df065a0b EZ |
6980 | * w32.c: Include epaths.h. |
6981 | (init_environment): Use cmdproxy.exe without leading directories. | |
6982 | Support emacs.exe in src; point SHELL to cmdproxy in ../nt in that | |
6983 | case. | |
6984 | (gettimeofday): Adjust signature and return value to Posix | |
6985 | expectations. | |
6986 | ||
6987 | * unexw32.c (open_output_file): Delete the existing emacs.exe | |
6988 | before creating it, to break the hard link to the versioned | |
6989 | executable. | |
6990 | ||
6991 | * Makefile.in (EMACS_MANIFEST, CM_OBJ, TEMACS_POST_LINK) | |
6992 | (ADDSECTION, EMACS_HEAPSIZE, MINGW_TEMACS_POST_LINK) | |
6993 | (FIRSTFILE_OBJ): New variables. | |
6994 | (W32_RES): Rename to EMACSRES. All users changed. | |
6995 | (base_obj): Use $(CM_OBJ). | |
6996 | (ALLOBJS): Use $(FIRSTFILE_OBJ). | |
6997 | (emacs$(EXEEXT)): Depend on $(ADDSECTION). | |
6998 | (temacs$(EXEEXT)): Use $(TEMACS_POST_LINK), and move | |
6999 | $(W32_RES_LINK) before $(LIBES). | |
7000 | (emacs.res): Depend on $(EMACS_MANIFEST). Put emacs.rc in nt. | |
7001 | ||
1aa8d505 SM |
7002 | 2013-05-15 Stefan Monnier <monnier@iro.umontreal.ca> |
7003 | ||
6e911150 SM |
7004 | * makefile.w32-in (DOC): Use just "DOC". |
7005 | ||
7006 | * Makefile.in (bootstrap-clean): DOC-* doesn't exist any more. | |
7007 | ||
1aa8d505 SM |
7008 | * process.c: Export default filters and sentinels to Elisp. |
7009 | (Qinternal_default_process_sentinel, Qinternal_default_process_filter): | |
7010 | New constants. | |
7011 | (pset_filter, pset_sentinel, make_process, Fset_process_filter) | |
7012 | (Fset_process_sentinel, Fformat_network_address): | |
7013 | Default to them instead of nil. | |
7014 | (server_accept_connection): Sentinels can't be nil any more. | |
7015 | (read_and_dispose_of_process_output): New function, extracted from | |
7016 | read_process_output. | |
7017 | (read_process_output): Use it; filters can't be nil. | |
7018 | (Finternal_default_process_filter): New function, extracted from | |
7019 | read_process_output. | |
7020 | (exec_sentinel_unwind): Remove function. | |
7021 | (exec_sentinel): Don't zilch sentinel while running. | |
7022 | (status_notify): Sentinels can't be nil. | |
7023 | (Finternal_default_process_sentinel): New function extracted from | |
7024 | status_notify. | |
7025 | (setup_process_coding_systems): Default filter is not nil any more. | |
7026 | (syms_of_process): Export new Elisp functions and initialize | |
7027 | new constants. | |
7028 | * lisp.h (make_lisp_proc): New function. | |
7029 | ||
5ac2eb34 SM |
7030 | 2013-05-15 Stefan Monnier <monnier@iro.umontreal.ca> |
7031 | ||
7032 | * regex.c (regex_compile) [\=, \>, \<]: Don't forget to set laststart. | |
7033 | ||
eda9c7d7 EZ |
7034 | 2013-05-14 Eli Zaretskii <eliz@gnu.org> |
7035 | ||
7036 | * w32fns.c (w32_wnd_proc): Don't call WINDOW_HEADER_LINE_HEIGHT | |
5ac2eb34 SM |
7037 | unless we know that the window w is a leaf window. |
7038 | Another attempt at solving bug#14062. | |
eda9c7d7 | 7039 | |
8fdeaad5 JD |
7040 | 2013-05-14 Jan Djärv <jan.h.d@swipnet.se> |
7041 | ||
7042 | * nsfont.m (ns_spec_to_descriptor): Retain and autorelease | |
7043 | fdesc (Bug#14375). | |
7044 | ||
44aa9ee6 PE |
7045 | 2013-05-12 Paul Eggert <eggert@cs.ucla.edu> |
7046 | ||
7047 | * image.c (gif_load): Check that subimages fit (Bug#14345). | |
7048 | ||
759fd763 SM |
7049 | 2013-05-09 Stefan Monnier <monnier@iro.umontreal.ca> |
7050 | ||
7051 | * lread.c (skip_dyn_eof): New function. | |
7052 | (read1): Use it to skip the end of a file in response to #@00. | |
7053 | ||
7054 | * doc.c (get_doc_string): Slightly relax the sanity checking. | |
7055 | ||
4465bfb4 JD |
7056 | 2013-05-09 Jan Djärv <jan.h.d@swipnet.se> |
7057 | ||
7058 | * nsfns.m: Include IOGraphicsLib.h if Cocoa. | |
7059 | (Qgeometry, Qworkarea, Qmm_size, Qframes, Qsource): Declare. | |
7060 | (MonitorInfo): New struct. | |
7061 | (free_monitors, ns_screen_name, ns_make_monitor_attribute_list) | |
7062 | (Fns_display_monitor_attributes_list): New functions. | |
7063 | (display-usable-bounds): Remove. | |
7064 | (syms_of_nsfns): DEFSYM Qgeometry, Qworkarea, Qmm_size, Qframes and | |
7065 | Qsource. | |
7066 | ||
7583e2a0 PE |
7067 | 2013-05-09 Paul Eggert <eggert@cs.ucla.edu> |
7068 | ||
7069 | * xterm.h (GTK_PREREQ): Remove, replacing with GTK_CHECK_VERSION. | |
7070 | (GTK_CHECK_VERSION): New macro, if not already defined. | |
7071 | All uses of GTK_PREREQ, GTK_MAJOR_VERSION, etc. | |
7072 | replaced by GTK_CHECK_VERSION. | |
7073 | ||
ad75d77e PE |
7074 | 2013-05-08 Paul Eggert <eggert@cs.ucla.edu> |
7075 | ||
7076 | * xterm.h (GTK_PREREQ): New macro. | |
7077 | All simple uses of GTK_MAJOR_VERSION and GTK_MINOR_VERSION changed | |
7078 | to use this macro instead, for consistency and clarity. | |
7079 | ||
07525f77 EZ |
7080 | 2013-05-08 Eli Zaretskii <eliz@gnu.org> |
7081 | ||
7082 | * xdisp.c (row_for_charpos_p): New function, with code of | |
7083 | cursor_row_p, but accepts an additional argument CHARPOS instead | |
7084 | of using a hardcoded PT. | |
7085 | (cursor_row_p): Call row_for_charpos_p with 2nd argument PT. | |
7086 | (row_containing_pos): Call row_for_charpos_p instead of partially | |
7087 | doing the same. Fixes cursor positioning under longlines-mode | |
7088 | when longlines-show-effect includes more than one newline, when | |
7089 | moving the cursor vertically up. | |
7090 | ||
d901fc8d JB |
7091 | 2013-05-08 Juanma Barranquero <lekktu@gmail.com> |
7092 | ||
7093 | * makefile.w32-in (ACL_H): New macro. | |
7094 | ($(BLD)/fileio.$(O)): Update dependencies. | |
7095 | ||
f269bc61 PE |
7096 | 2013-05-07 Paul Eggert <eggert@cs.ucla.edu> |
7097 | ||
e7b41c4c | 7098 | Use Gnulib ACL implementation, for benefit of Solaris etc. (Bug#14295) |
ffdc270a PE |
7099 | * Makefile.in (LIB_ACL): New macro. |
7100 | (LIBACL_LIBS): Remove. | |
7101 | (LIBES): Use LIB_ACL, not LIBACL_LIBS. | |
7102 | * fileio.c: Include <acl.h>. | |
7103 | Use HAVE_ACL_SET_FILE rather than HAVE_POSIX_ACL. | |
7104 | (ACL_NOT_WELL_SUPPORTED): Remove. All uses replaced by | |
7105 | !acl_errno_valid. | |
7106 | (Fcopy_file) [!WINDOWSNT]: Use qcopy_acl instead of rolling | |
7107 | it ourselves. | |
7108 | ||
f269bc61 PE |
7109 | * unexelf.c: Don't assume ElfW (Half) fits in int. |
7110 | (entry_address, find_section, unexec): Use ptrdiff_t, not int, | |
7111 | when dealing with ElfW (Half) values, since they can exceed 2**31 | |
7112 | on 64-bit OpenBSD hosts. Problem reported privately by Han Boetes. | |
7113 | (entry_address): Omit unused NUM arg. All uses changed. | |
7114 | ||
a261c53e JL |
7115 | 2013-05-07 Juri Linkov <juri@jurta.org> |
7116 | ||
7117 | * callint.c (Fcall_interactively): Set `visargs[i]' for code 'n' | |
7118 | to the string converted from number with `Fnumber_to_string'. | |
7119 | (Bug#14254) | |
7120 | ||
2b66427d PE |
7121 | 2013-05-07 Paul Eggert <eggert@cs.ucla.edu> |
7122 | ||
7123 | * xfns.c (x_get_net_workarea): Define only if !GTK || GTK<3.4. | |
7124 | This fixes a problem introduced by my previous change. | |
7125 | ||
15acfe41 GM |
7126 | 2013-05-07 Glenn Morris <rgm@gnu.org> |
7127 | ||
7128 | * lread.c (readchar): Don't read from a dead buffer. (Bug#14280) | |
7129 | ||
5ea03bf5 JD |
7130 | 2013-05-07 Jan Djärv <jan.h.d@swipnet.se> |
7131 | ||
7132 | * xfns.c: Move misplaced ifndef USE_GTK from previous checkin. | |
7133 | ||
e0c9d565 PE |
7134 | 2013-05-07 Paul Eggert <eggert@cs.ucla.edu> |
7135 | ||
7136 | Static checking by GCC 4.8.0. | |
7137 | * xfns.c (x_get_net_workarea, struct MonitorInfo, free_monitors) | |
7138 | (x_get_monitor_for_frame, x_make_monitor_attribute_list) | |
7139 | (x_get_monitor_attributes_fallback) | |
7140 | (x_get_monitor_attributes_xinerama) | |
7141 | (x_get_monitor_attributes_xrandr, x_get_monitor_attributes): | |
7142 | Define only if USE_GTK. | |
7143 | (free_monitors): Define only if HAVE_XINERAMA || HAVE_XRANDR. | |
7144 | (x_get_monitor_attributes_fallback): Omit unused locals. | |
7145 | (x_get_monitor_attributes_xinerama, Fx_display_monitor_attributes_list): | |
7146 | Use double, not float, to avoid mixed-mode floating point arithmetic. | |
7147 | ||
4e3f9230 YM |
7148 | 2013-05-07 YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp> |
7149 | Jan Djärv <jan.h.d@swipnet.se> | |
7150 | ||
7151 | * Makefile.in (XRANDR_LIBS, XRANDR_CFLAGS, XINERAMA_LIBS) | |
7152 | (XINERAMA_CFLAGS): New macros. | |
7153 | (ALL_CFLAGS, LIBES): Use them. | |
7154 | ||
7155 | * xfns.c: Include <X11/extensions/Xrandr.h> if HAVE_XRANDR, and | |
7156 | include <X11/extensions/Xinerama.h> if HAVE_XINERAMA. | |
7157 | (Qgeometry, Qworkarea, Qmm_size, Qframes, Qsource): New variables. | |
7158 | (syms_of_xfns): DEFSYM them. | |
7159 | (struct MonitorInfo): New struct. | |
7160 | (x_get_net_workarea, free_monitors, x_get_monitor_for_frame) | |
7161 | (x_make_monitor_attribute_list, x_get_monitor_attributes_fallback) | |
7162 | (x_get_monitor_attributes_xrandr, x_get_monitor_attributes) | |
7163 | (x_get_monitor_attributes_xinerama): New functions. | |
7164 | (Fx_display_monitor_attributes_list): New primitive. | |
7165 | (syms_of_xfns): Defsubr it. | |
7166 | ||
7167 | * xterm.h (x_display_info): Add Xatom_net_workarea and | |
7168 | Xatom_net_current_desktop. | |
7169 | ||
7170 | * xterm.c (x_term_init): Initialize dpyinfo->Xatom_net_workarea | |
7171 | and dpyinfo->Xatom_net_current_desktop. | |
7172 | ||
05839b6a EZ |
7173 | 2013-05-06 Eli Zaretskii <eliz@gnu.org> |
7174 | ||
7175 | * xdisp.c (pos_visible_p): Use the special code for finding the | |
7176 | beginning of a display property or overlay for any "replacing" | |
7177 | display property, not just for display strings. This solves | |
7178 | incorrect reporting of position by posn-at-point. (Bug#14241) | |
7179 | ||
dc4a2ee0 PE |
7180 | 2013-05-06 Paul Eggert <eggert@cs.ucla.edu> |
7181 | ||
5ee94506 PE |
7182 | * unexelf.c: Fix some 32-bit integer problems, notably when debugging. |
7183 | Include <limits.h>, <stdbool.h>, <intprops.h>, <verify.h>. | |
7184 | Verify that ElfW (Half) fits in int. | |
7185 | (fatal): Use same signature as lisp.h. | |
7186 | (UNEXELF_DEBUG): New macro, replacing DEBUG, so that people can | |
7187 | configure and build with -DUNEXELF_DEBUG without worrying about | |
7188 | other modules that use DEBUG. | |
7189 | (DEBUG_LOG) [UNEXELF_DEBUG]: New macro. All debug code that prints | |
7190 | possibly-wide integers now uses it instead of plain fprintf. | |
7191 | (entry_address): New function, which avoids problems with 32-bit | |
7192 | overflow on 64-bit hosts. | |
7193 | (OLD_SECTION_H, NEW_SECTION_H, NEW_PROGRAM_H): Use it. | |
7194 | (round_up): Don't assume the remainder fits in int. | |
7195 | (find_section): Use bool for boolean. Simplify debug code. | |
7196 | (unexec): Don't assume file sizes fit in int or size_t. | |
7197 | Omit unnecessary trailing newline in 'fatal' format. | |
7198 | Use strerror rather than outputting decimal error number. | |
7199 | Remove unused code when emacs is not defined; | |
7200 | this file relies on Emacs now. | |
7201 | Don't assume e_phnum and e_shnum are positive. | |
7202 | ||
dc4a2ee0 PE |
7203 | * regex.c: Fix problems when DEBUG is defined. |
7204 | (extract_number, extract_number_and_incr): Define regardless of | |
7205 | whether DEBUG is defined; that's simpler and makes the code less | |
7206 | likely to go stale in the normal case when DEBUG is not defined. | |
7207 | Return int rather than taking an int * arg. All callers changed. | |
7208 | (DEBUG_PRINT1, DEBUG_PRINT2, DEBUG_PRINT3, DEBUG_PRINT4): | |
7209 | Remove, replacing with ... | |
7210 | (DEBUG_PRINT): New macro. All callers changed. | |
7211 | (DEBUG_COMPILES_ARGUMENTS): New macro. | |
7212 | (print_fastmap, print_partial_compiled_pattern) [DEBUG]: | |
7213 | (print_compiled_pattern, print_double_string) [DEBUG]: | |
7214 | Use prototype rather than old-style definition. | |
7215 | (print_partial_compiled_pattern, print_compiled_pattern) [DEBUG]: | |
7216 | (ENSURE_FAIL_STACK, PUSH_FAILURE_REG) [DEBUG]: | |
7217 | (POP_FAILURE_REG_OR_COUNT, PUSH_FAILURE_POINT) [DEBUG]: | |
7218 | (POP_FAILURE_POINT, re_match_2_internal) [DEBUG]: | |
7219 | Don't assume ptrdiff_t, size_t, and long are the same width as int. | |
7220 | (POINTER_TO_OFFSET): Return ptrdiff_t, not regoff_t. | |
7221 | This matters only when DEBUG is defined. | |
7222 | ||
14c7ed05 EZ |
7223 | 2013-05-05 Eli Zaretskii <eliz@gnu.org> |
7224 | ||
7225 | * xdisp.c (set_iterator_to_next): Set the | |
7226 | ignore_overlay_strings_at_pos_p flag only if we are _really_ | |
7227 | iterating over an overlay string, as indicated by the | |
7228 | current.overlay_string_index member. (Bug#14306) | |
7229 | ||
e6076b1b JD |
7230 | 2013-05-05 Jan Djärv <jan.h.d@swipnet.se> |
7231 | ||
7232 | * nsmenu.m (ns_update_menubar): Move initialization of submenuTitle | |
7233 | to where it is used, to avoid autorelease issues (Bug#14050). | |
7234 | ||
cbee2131 PE |
7235 | 2013-05-05 Paul Eggert <eggert@cs.ucla.edu> |
7236 | ||
7237 | `write-region-inhibit-fsync' defaults to noninteractive (Bug#14273). | |
7238 | * fileio.c (syms_of_fileio): Implement this. | |
7239 | * filelock.c (create_lock_file): If symbolic links don't work, so | |
7240 | we use a regular file as a lock file, do not fsync the lock file; | |
7241 | it's not needed. | |
7242 | ||
30c7e542 SM |
7243 | 2013-05-04 Stefan Monnier <monnier@iro.umontreal.ca> |
7244 | ||
7245 | * minibuf.c (Fread_minibuffer, Feval_minibuffer): Move to Elisp. | |
7246 | (syms_of_minibuf): Adjust accodingly. | |
7247 | * lread.c (Fread): | |
7248 | * callint.c (Fcall_interactively): Adjust calls accordingly. | |
7249 | ||
5bebd186 EZ |
7250 | 2013-05-04 Eli Zaretskii <eliz@gnu.org> |
7251 | ||
7252 | * dispextern.h (WINDOW_WANTS_HEADER_LINE_P): Verify that | |
30c7e542 SM |
7253 | w->contents is a buffer before computing everything else. |
7254 | Use parentheses to disambiguate last part of the condition. | |
5bebd186 EZ |
7255 | |
7256 | * w32fns.c (w32_wnd_proc): Remove temporary code used to trap | |
7257 | assertion violations. (Bug#14062) | |
7258 | ||
0fb0a4f3 DR |
7259 | 2013-05-01 David Reitter <david.reitter@gmail.com> |
7260 | ||
7261 | * nsfns.m (ns_tooltip): Initialize. | |
7262 | ||
9e63b4a5 EZ |
7263 | 2013-04-28 Eli Zaretskii <eliz@gnu.org> |
7264 | ||
7265 | * coding.c (decode_coding_gap): Don't remove the character before | |
7266 | a newline unless it's a CR character. (Bug#14287) | |
7267 | ||
ad60824e DN |
7268 | 2013-04-28 Dan Nicolaescu <dann@gnu.org> |
7269 | ||
7270 | * dispextern.h (struct face): Move enum face_underline_type | |
7271 | earlier so that bitfields can be in the same word. | |
7272 | ||
edbdcec0 JD |
7273 | 2013-04-28 Jan Djärv <jan.h.d@swipnet.se> |
7274 | ||
7275 | * nsfns.m (handlePanelKeys): New function. | |
7276 | (EmacsOpenPanel:performKeyEquivalent:) | |
7277 | (EmacsSavePanel:performKeyEquivalent:): Call handlePanelKeys to handle | |
7278 | arrows/function/control and copy/paste keys (Bug#14296). | |
7279 | ||
0208ede7 JL |
7280 | 2013-04-27 Juri Linkov <juri@jurta.org> |
7281 | ||
7282 | * callint.c (Fcall_interactively): Call `Qread_number' for | |
7283 | interactive code letter `n' instead of using duplicate code. | |
7284 | (Bug#14254) | |
7285 | ||
b8dd59f7 PE |
7286 | 2013-04-27 Paul Eggert <eggert@cs.ucla.edu> |
7287 | ||
7288 | * systime.h (make_timeval): Declare as 'const'. | |
7289 | ||
8bd722db KH |
7290 | 2013-04-27 Kenichi Handa <handa@gnu.org> |
7291 | ||
7292 | * font.c (font_open_entity): Always open a font of manageable | |
7293 | size. | |
7294 | ||
13d0e56f | 7295 | 2013-04-26 Paul Eggert <eggert@cs.ucla.edu> |
cbee2131 | 7296 | |
f780d632 PE |
7297 | Port better to AIX (Bug#14258). |
7298 | * lisp.h (ENUM_BF) [__IBMC__]: Make it 'unsigned int' here, too, | |
7299 | to pacify AIX xlc. | |
7300 | ||
ec509856 KH |
7301 | 2013-04-24 Kenichi Handa <handa@gnu.org> |
7302 | ||
7303 | * coding.c (decode_coding_iso_2022): When an invalid escape | |
7304 | sequence is encountered, reset the invocation and designation | |
7305 | status to the safest one. | |
7306 | ||
84fc48e5 PE |
7307 | 2013-04-22 Paul Eggert <eggert@cs.ucla.edu> |
7308 | ||
7309 | * Makefile.in (bootstrap-clean): Remove stamp-h1 too. | |
7310 | Without this fix, "make distclean" leaves stamp-h1 behind. | |
7311 | ||
806bda47 EC |
7312 | 2013-04-20 Erik Charlebois <erikcharlebois@gmail.com> |
7313 | ||
7314 | * w32fns.c (w32_fullscreen_rect): New function to compute the | |
7315 | window rectangle for the given fullscreen mode. | |
7316 | (w32_wnd_proc): When in a fullscreen mode, WM_WINDOWPOSCHANGING no | |
7317 | longer tunes the window size. This keeps the window's edges flush | |
7318 | with the screen and allows the taskbar to hide itself in fullboth. | |
7319 | ||
7320 | * w32term.c (w32fullscreen_hook): 'fullboth' now shows without | |
7321 | window decorations and uses the entire screen. | |
7322 | ||
7323 | * w32term.h (w32_fullscreen_rect) Add prototype. | |
7324 | (struct w32_output): Replace normal_width, normal_height, | |
7325 | normal_top, and normal_left members with a single normal_placement | |
7326 | struct. | |
7327 | (FRAME_NORMAL_WIDTH, FRAME_NORMAL_HEIGHT, FRAME_NORMAL_TOP): | |
7328 | Remove macros. | |
7329 | (FRAME_NORMAL_PLACEMENT): New macro. | |
7330 | ||
9cc2810b JB |
7331 | 2013-04-16 Juanma Barranquero <lekktu@gmail.com> |
7332 | ||
7333 | * minibuf.c (Ftest_completion): Silence compiler warning. | |
7334 | ||
fd16b54c EZ |
7335 | 2013-04-15 Eli Zaretskii <eliz@gnu.org> |
7336 | ||
7337 | * w32fns.c (w32_wnd_proc): Add more assertions to investigate | |
5fbcd237 | 7338 | bug#14062. |
fd16b54c EZ |
7339 | |
7340 | * frame.h (WINDOW_FRAME): Protect macro and its argument with | |
7341 | parentheses. | |
7342 | ||
7343 | * dispextern.h (CURRENT_MODE_LINE_HEIGHT) | |
7344 | (CURRENT_HEADER_LINE_HEIGHT, WINDOW_WANTS_MODELINE_P) | |
7345 | (WINDOW_WANTS_HEADER_LINE_P): Protect macro arguments with | |
7346 | parentheses where appropriate. | |
7347 | ||
9e3379a0 PE |
7348 | 2013-04-14 Paul Eggert <eggert@cs.ucla.edu> |
7349 | ||
7350 | * keyboard.c (timer_start_idle): Remove no-longer-used local. | |
7351 | ||
ddd6b685 EZ |
7352 | 2013-04-14 Eli Zaretskii <eliz@gnu.org> |
7353 | ||
7354 | * buffer.c (syms_of_buffer) <left-margin-width, right-margin-width> | |
7355 | <left-fringe-width, right-fringe-width, fringes-outside-margins>: | |
7356 | Mention in the doc string that setting these variables takes | |
7357 | effect only after a call to set-window-buffer. (Bug#14200) | |
7358 | ||
29b79ba1 EZ |
7359 | 2013-04-13 Eli Zaretskii <eliz@gnu.org> |
7360 | ||
7361 | * indent.c (Fvertical_motion): Don't consider display strings on | |
7362 | overlay strings as display strings on the buffer position we | |
7363 | started from. This prevents vertical cursor motion from jumping | |
7364 | more than one line when there's an overlay string with a display | |
7365 | property at end of line. | |
7366 | Reported by Karl Chen <Karl.Chen@quarl.org> in | |
7367 | http://lists.gnu.org/archive/html/emacs-devel/2013-04/msg00362.html. | |
7368 | ||
562c6ee9 SM |
7369 | 2013-04-12 Stefan Monnier <monnier@iro.umontreal.ca> |
7370 | ||
7371 | * window.c (select_window): `record_buffer' even if window is | |
7372 | already selected (bug#14191). | |
7373 | ||
fcc1fe85 EZ |
7374 | 2013-04-11 Eli Zaretskii <eliz@gnu.org> |
7375 | ||
7376 | * window.c (Fwindow_end): Test more flags, including the buffer's | |
7377 | last_overlay_modified flag, to determine whether the window's | |
7378 | display is really up-to-date. Prevents the function from | |
7379 | returning a stale value. (Bug#14170) | |
7380 | (Fwindow_line_height): Fix the test for up-to-date-ness of the | |
7381 | current matrix. | |
7382 | ||
f009190a EZ |
7383 | 2013-04-10 Eli Zaretskii <eliz@gnu.org> |
7384 | ||
7385 | * frame.c (do_switch_frame): Mark the TTY frame we switch to as | |
562c6ee9 SM |
7386 | garbaged only if it is not already the top frame on its TTY. |
7387 | This prevents flickering due to constant redrawing of TTY frames when | |
f009190a EZ |
7388 | there are GUI frames open in the same session. (Bug#13864) |
7389 | ||
78ce603d SM |
7390 | 2013-04-10 Stefan Monnier <monnier@iro.umontreal.ca> |
7391 | ||
7392 | * keyboard.c (timer_start_idle): Call internal-timer-start-idle instead | |
7393 | of marking the idle timers directly. | |
7394 | ||
a8036e40 SM |
7395 | 2013-04-09 Stefan Monnier <monnier@iro.umontreal.ca> |
7396 | ||
7397 | * minibuf.c (Ftest_completion): Ignore non-string/symbol keys in hash | |
7398 | tables (bug#14054). | |
7399 | ||
7ffe7ef6 SM |
7400 | 2013-04-08 Stefan Monnier <monnier@iro.umontreal.ca> |
7401 | ||
7402 | * window.c (select_window): Don't record_buffer while the invariant is | |
7403 | temporarily broken (bug#14161). | |
7404 | ||
7405 | * fns.c (Fdelq): Don't assume !NILP => CONSP. | |
7406 | ||
7d9f6883 EZ |
7407 | 2013-04-07 Eli Zaretskii <eliz@gnu.org> |
7408 | ||
7409 | * fileio.c (ACL_NOT_WELL_SUPPORTED): Define macro for WINDOWSNT. | |
7410 | ||
5406cfd9 RF |
7411 | 2013-04-07 Romain Francoise <romain@orebokech.com> |
7412 | ||
7413 | Ignore additional platform-specific ACL errors (Bug#13702). | |
7414 | * fileio.c (ACL_NOT_WELL_SUPPORTED): New macro copied from gnulib. | |
7415 | (Fcopy_file, Fset_file_acl) [HAVE_POSIX_ACL]: Use it. | |
7416 | ||
95c0e83b JD |
7417 | 2013-03-31 Jan Djärv <jan.h.d@swipnet.se> |
7418 | ||
7419 | * nsterm.m (ns_mouse_position): Use NS_FRAME_P instead of checking | |
7420 | f->output_data.ns. | |
7421 | ||
876da980 PE |
7422 | 2013-04-07 Paul Eggert <eggert@cs.ucla.edu> |
7423 | ||
7424 | Fix --enable-profiling bug introduced by 2013-02-25 change (Bug#13783). | |
7425 | This bug was introduced by my 2013-02-25 change that simplified | |
7426 | data_start configuration. Without this change, on GNU/Linux | |
7427 | an Emacs configured with --enable-profiling fails immediately | |
7428 | due to a profiler signal. | |
7429 | * Makefile.in: Compile with $(PROFILING_CFLAGS), but do not link | |
7430 | with these flags. On platforms where special flags are needed | |
7431 | when linking temacs, the flags are now in LD_SWITCH_SYSTEM_TEMACS. | |
7432 | (ALL_CFLAGS): Remove $(PROFILING_CFLAGS). | |
7433 | (.c.o, .m.o): Compile with $(PROFILING_CFLAGS). | |
7434 | ||
7452b7bd DA |
7435 | 2013-04-07 Dmitry Antipov <dmantipov@yandex.ru> |
7436 | ||
7437 | Get rid of some platform-specific functions examining window | |
7438 | system and its capabilities. This is a partial rework of the | |
7439 | 2013-04-05 change. | |
7440 | * lisp.h (have_menus_p): Remove prototype. This function is | |
7441 | replaced with platform-independent window_system_available. | |
7442 | (check_window_system): Move to... | |
7443 | * frame.h (decode_window_system_frame, window_system_available): | |
7444 | ...here, add new prototypes. | |
7445 | * frame.c (window_system_available, decode_window_system_frame): | |
7446 | New functions. | |
7447 | (check_window_system): Platform-independent now. | |
7448 | * xterm.h (x_in_use): Remove declaration. | |
7449 | (check_x_frame): | |
7450 | * w32term.h (check_x_frame): | |
7451 | * nsterm.h (check_x_frame): Remove prototypes. This function | |
7452 | is replaced with platform-independent decode_window_system_frame. | |
7453 | * msdos.c (have_menus_p): Remove. | |
7454 | * nsfns.m (check_window_system, have_menus_p, check_ns_frame): | |
7455 | Remove platform-specific functions. Use check_window_system, | |
7456 | decode_window_system_frame and check_ns_display_info where | |
7457 | appropriate. Minor style and comment tweaks. | |
7458 | * w32fns.c (w32_in_use, check_window_system, have_menus_p) | |
7459 | (check_x_frame): Likewise. | |
7460 | * xfns.c (x_in_use, check_window_system, have_menus_p, check_x_frame): | |
7461 | Likewise. | |
7462 | * fileio.c, fns.c, font.c, fontset.c, image.c, menu.c, nsmenu.m: | |
7463 | * nsselect.m, nsterm.m, w32font.c, w32menu.c, xfaces.c, xgselect.c: | |
7464 | * xmenu.c, xselect.c: All related users changed. | |
7465 | ||
251e9147 KH |
7466 | 2013-04-03 Kenichi Handa <handa@gnu.org> |
7467 | ||
7468 | The following changes is to optimize the code for reading UTF-8 | |
7469 | files. | |
7470 | ||
562c6ee9 | 7471 | * coding.c (check_ascii): Rename from detect_ascii. Return value |
251e9147 KH |
7472 | changed. Check EOL format. Do not call adjust_coding_eol_type |
7473 | here. | |
7474 | (check_utf_8): New function. | |
7475 | (adjust_coding_eol_type): Do nothing if already adjusted. | |
7476 | (detect_coding): Compare the return value of check_ascii with | |
7477 | coding->src_bytes. Call adjust_coding_eol_type if necessary. | |
7478 | (decode_coding_gap): Optimize for valid UTF-8. | |
7479 | ||
8bc369d4 KH |
7480 | 2013-03-21 Kenichi Handa <handa@gnu.org> |
7481 | ||
7482 | * coding.c (syms_of_coding): Cancel previous change. | |
7483 | ||
7484 | * insdel.c (insert_from_gap): Fix previous change. | |
7485 | ||
73931ad1 DA |
7486 | 2013-04-05 Dmitry Antipov <dmantipov@yandex.ru> |
7487 | ||
7488 | Consistently use platform-specific function to detect window system. | |
7489 | * lisp.h (check_window_system): New prototype. This function is | |
7490 | going to replace check_x, check_w32 and check_ns. | |
7491 | (have_menus_p): Mention msdos.c in comment. | |
7492 | * fontset.c (check_window_system_func): Remove. Adjust all users. | |
7493 | * fontset.h (check_window_system_func): Remove prototype. | |
7494 | * nsterm.h (check_ns): | |
7495 | * xterm.h (check_x): | |
7496 | * w32term.h (check_w32): Likewise. | |
7497 | * menu.c (Fx_popup_menu): Use check_window_system. | |
7498 | * msdos.c (check_window_system): Define for MS-DOS. | |
7499 | * nsfns.m (check_window_system): Define for NS. Adjust all users. | |
7500 | * w32fns.c (check_window_system): Likewise for MS-Windows. | |
7501 | * xfns.c (check_window_system): Likewise for X. | |
7502 | * font.c, frame.c, nsmenu.m, nsselect.m, nsterm.m, w32menu.c: | |
7503 | * xfaces.c, xmenu.c: Use check_window_system where appropriate. | |
7504 | ||
7216e43b PE |
7505 | 2013-04-02 Paul Eggert <eggert@cs.ucla.edu> |
7506 | ||
7507 | Prefer < to > in range checks such as 0 <= i && i < N. | |
7508 | This makes it easier to visualize quantities on a number line. | |
7509 | This patch doesn't apply to all such range checks, | |
7510 | only to the range checks affected by the 2013-03-24 change. | |
7511 | This patch reverts most of the 2013-03-24 change. | |
7512 | * alloc.c (xpalloc, Fgarbage_collect): | |
7513 | * ccl.c (ccl_driver, resolve_symbol_ccl_program): | |
7514 | * character.c (string_escape_byte8): | |
7515 | * charset.c (read_hex): | |
7516 | * data.c (cons_to_unsigned): | |
7517 | * dispnew.c (update_frame_1): | |
7518 | * doc.c (Fsubstitute_command_keys): | |
7519 | * doprnt.c (doprnt): | |
7520 | * editfns.c (hi_time, decode_time_components): | |
7521 | * fileio.c (file_offset): | |
7522 | * fns.c (larger_vector, make_hash_table, Fmake_hash_table): | |
7523 | * font.c (font_intern_prop): | |
7524 | * frame.c (x_set_alpha): | |
7525 | * gtkutil.c (get_utf8_string): | |
7526 | * indent.c (check_display_width): | |
7527 | * keymap.c (Fkey_description): | |
7528 | * lisp.h (FIXNUM_OVERFLOW_P, vcopy): | |
7529 | * lread.c (read1): | |
7530 | * minibuf.c (read_minibuf_noninteractive): | |
7531 | * process.c (wait_reading_process_output): | |
7532 | * search.c (Freplace_match): | |
7533 | * window.c (get_phys_cursor_glyph): | |
7534 | * xdisp.c (redisplay_internal): | |
7535 | * xsmfns.c (smc_save_yourself_CB): | |
7536 | Prefer < to > for range checks. | |
7537 | * dispnew.c (sit_for): Don't mishandle NaNs. | |
7538 | This fixes a bug introduced in the 2013-03-24 change. | |
7539 | * editfns.c (decode_time_components): Don't hoist comparison. | |
7540 | This fixes another bug introduced in the 2013-03-24 change. | |
7541 | ||
92759988 DA |
7542 | 2013-03-31 Dmitry Antipov <dmantipov@yandex.ru> |
7543 | ||
7544 | * frame.h (struct frame): Drop scroll_bottom_vpos | |
7545 | member becaue all real users are dead long ago. | |
7546 | (FRAME_SCROLL_BOTTOM_VPOS): Remove. | |
7547 | * xdisp.c (redisplay_internal): Adjust user. | |
7548 | ||
9a1971bb GM |
7549 | 2013-03-30 Darren Ho <darren.hoo@gmail.com> (tiny change) |
7550 | ||
f38ab167 JD |
7551 | * nsmenu.m (showAtX:Y:for:): setLevel to |
7552 | NSPopUpMenuWindowLevel (Bug#13998). | |
7553 | ||
6d01f1fe JD |
7554 | 2013-03-30 Jan Djärv <jan.h.d@swipnet.se> |
7555 | ||
7556 | * nsterm.h (ns_get_pending_menu_title, ns_check_menu_open) | |
7557 | (ns_check_pending_open_menu): Declare. | |
7558 | ||
7559 | * nsmenu.m (ns_update_menubar): Correct NSTRACE. | |
7560 | (x_activate_menubar): Update the menu with title that matches | |
7561 | ns_get_pending_menu_title, and call | |
7562 | ns_check_pending_openmenu (Bug#12698). | |
7563 | (menuWillOpen:): New method. | |
7564 | (menuNeedsUpdate:): Add check for ! COCOA || OSX < 10.5 (Bug#12698). | |
7565 | ||
7566 | * nsterm.m (menu_will_open_state, menu_mouse_point) | |
7567 | (menu_pending_title): New varaibles. | |
7568 | (ns_get_pending_menu_title, ns_check_menu_open) | |
7569 | (ns_check_pending_open_menu): New functions. | |
7570 | ||
781f4782 DA |
7571 | 2013-03-29 Dmitry Antipov <dmantipov@yandex.ru> |
7572 | ||
7573 | * indent.c (current_column_bol_cache): Remove leftover which is not | |
7574 | used in Fmove_to_column any more. | |
7575 | (current_column, scan_for_column): Adjust users. | |
7576 | * keyboard.c (last_point_position_buffer, last_point_position_window): | |
7577 | Remove leftovers which are not used for recording undo any more. | |
7578 | (command_loop_1, syms_of_keyboard): Adjust users. | |
7579 | * xdisp.c (last_max_ascent): Remove leftover which is not used in | |
7580 | redisplay_window any more. | |
7581 | (move_it_to): Adjust user. | |
7582 | ||
1921c31b JB |
7583 | 2013-03-29 Juanma Barranquero <lekktu@gmail.com> |
7584 | ||
7585 | * makefile.w32-in ($(BLD)/filelock.$(O), $(BLD)/filelock.$(O)): | |
7586 | Update dependencies. | |
7587 | ||
717b8bcd SM |
7588 | 2013-03-28 Stefan Monnier <monnier@iro.umontreal.ca> |
7589 | ||
7590 | * lisp.h (save_type, XSAVE_POINTER, set_save_pointer, XSAVE_INTEGER) | |
7591 | (set_save_integer, XSAVE_OBJECT, XSAVE_VALUE): Move to avoid | |
7592 | forward references. | |
7593 | ||
e74aeda8 DA |
7594 | 2013-03-28 Dmitry Antipov <dmantipov@yandex.ru> |
7595 | ||
7596 | * window.h (struct window): Replace hchild, vchild and buffer slots | |
7597 | with the only contents slot. This is possible because each valid | |
7598 | window may have either the child window (in vertical or horizontal | |
7599 | combination) or buffer to display (for the leaf window). Using that, | |
7600 | a lof of operations to traverse and/or change window hierarchies may | |
7601 | be simplified. New member horizontal is used to distinguish between | |
7602 | horizontal and vertical combinations of internal windows. | |
7603 | (WINDOW_LEAF_P, WINDOW_HORIZONTAL_COMBINATION_P) | |
7604 | (WINDOW_VERTICAL_COMBINATION_P): New macros. | |
7605 | (WINDOW_VALID_P, WINDOW_LIVE_P): Adjust to match struct window changes. | |
7606 | * window.c (wset_hchild, wset_vchild): Remove. Adjust all users. | |
7607 | Use contents slot, not buffer, where appropriate. | |
7608 | (wset_combination): New function. | |
7609 | (wset_buffer): Add eassert. | |
7610 | (Fframe_first_window): Simplify the loop reaching first window. | |
7611 | (Fwindow_buffer): Use WINDOW_LEAF_P. | |
7612 | (Fwindow_top_child): Use WINDOW_VERTICAL_COMBINATION_P. | |
7613 | (Fwindow_left_child): Use WINDOW_HORIZONTAL_COMBINATION_P. | |
7614 | (unshow_buffer): Convert initial debugging check to eassert. | |
7615 | (replace_window, recombine_windows, Fdelete_other_windows_internal) | |
7616 | (make_parent_window, window_resize_check, window_resize_apply) | |
7617 | (resize_frame_windows, Fsplit_window_internal, Fdelete_window_internal) | |
7618 | (Fset_window_configuration, delete_all_child_windows, save_window_save): | |
7619 | Adjust to match struct window changes. | |
7620 | (window_loop): Check for broken markers in CHECK_ALL_WINDOWS. | |
7621 | (mark_window_cursors_off, count_windows, get_leaf_windows) | |
7622 | (foreach_window_1): Simplify the loop. | |
7623 | * alloc.c (mark_object): Do not check for the leaf window because | |
7624 | internal windows has no glyph matrices anyway. | |
7625 | * dispnew.c (clear_window_matrices, showing_window_margins_p) | |
7626 | (allocate_matrices_for_window_redisplay, fake_current_matrices) | |
7627 | (allocate_matrices_for_frame_redisplay, free_window_matrices) | |
7628 | (build_frame_matrix_from_window_tree, mirror_make_current) | |
7629 | (frame_row_to_window, mirror_line_dance, check_window_matrix_pointers) | |
7630 | (update_window_tree, set_window_update_flags): Simplify the loop. | |
7631 | (sync_window_with_frame_matrix_rows): Enforce live window. | |
7632 | Use contents slot, not buffer, where appropriate. | |
7633 | * frame.c (set_menu_bar_lines_1): Use WINDOW_VERTICAL_COMBINATION_P | |
7634 | and WINDOW_HORIZONTAL_COMBINATION_P. | |
7635 | (make_frame_visible_1): Simplify the loop. | |
7636 | Use contents slot, not buffer, where appropriate. | |
7637 | * xdisp.c (hscroll_window_tree, mark_window_display_accurate) | |
7638 | (redisplay_windows, redisplay_mode_lines, update_cursor_in_window_tree) | |
7639 | (expose_window_tree): Likewise. | |
7640 | Use contents slot, not buffer, where appropriate. | |
7641 | * textprop.c (get_char_property_and_overlay): Add CHECK_LIVE_WINDOW | |
7642 | to avoid deleted windows. Use contents slot instead of buffer. | |
7643 | * buffer.c, dispextern.h, editfns.c, fileio.c, font.c, fringe.c: | |
7644 | * indent.c, insdel.c, keyboard.c, keymap.c, minibuf.c, msdos.c: | |
7645 | * nsfns.m, nsmenu.m, nsterm.m, print.c, w32fns.c, w32menu.c, xfaces.c: | |
7646 | * xfns.c, xmenu.c: Use contents slot, not buffer, where appropriate. | |
7647 | ||
121ab1cd EZ |
7648 | 2013-03-28 Eli Zaretskii <eliz@gnu.org> |
7649 | ||
ef454cf7 EZ |
7650 | * w32fns.c (w32_wnd_proc) [ENABLE_CHECKING]: Add code to help |
7651 | identify the reasons for assertion violations in bug#14062 and | |
7652 | similar ones. | |
21e930f8 EZ |
7653 | (Fx_show_tip): Fix compilation error under |
7654 | "--enable-check-lisp-object-type". (Bug#14073) | |
ef454cf7 | 7655 | |
121ab1cd EZ |
7656 | * image.c (g_error_free) [WINDOWSNT]: Add DEF_IMGLIB_FN. |
7657 | Reported by <rzl24ozi@gmail.com>. | |
7658 | ||
5c89ca24 DA |
7659 | 2013-03-28 Dmitry Antipov <dmantipov@yandex.ru> |
7660 | ||
7661 | * xdisp.c (with_echo_area_buffer_unwind_data): Save window | |
7662 | start marker... | |
562c6ee9 SM |
7663 | (unwind_with_echo_area_buffer): ...to restore it here. |
7664 | This is needed to ensure that... | |
5c89ca24 DA |
7665 | (redisplay_window): ...both window markers are valid here, |
7666 | which is verified by eassert. | |
7667 | * editfns.c (save_excursion_save): Do not assume that | |
7668 | selected_window always displays the buffer. | |
c7f53895 DA |
7669 | * buffer.c (Fbuffer_swap_text): Adjust window start markers. |
7670 | Fix comment. | |
5c89ca24 | 7671 | |
f557c1b1 SM |
7672 | 2013-03-27 Stefan Monnier <monnier@iro.umontreal.ca> |
7673 | ||
7674 | * casetab.c (init_casetab_once): Don't abuse the ascii eqv table for | |
7675 | the upcase table. | |
7676 | ||
40693bba | 7677 | 2013-03-27 rzl24ozi <rzl24ozi@gmail.com> (tiny changes) |
7678 | ||
7679 | * image.c [WINDOWSNT]: Fix calls to DEF_IMGLIB_FN for SVG function. | |
7680 | ||
c86f791f EZ |
7681 | 2013-03-27 Eli Zaretskii <eliz@gnu.org> |
7682 | ||
7683 | * w32proc.c (IsValidLocale) [__GNUC__]: Don't declare prototype, | |
7684 | since MinGW's w32api headers do. This avoids compiler warnings. | |
7685 | ||
7686 | * w32.c (FSCTL_GET_REPARSE_POINT) [_MSC_VER || _W64]: Don't define | |
7687 | if already defined. | |
7688 | ||
c6e72e17 EZ |
7689 | 2013-03-26 Eli Zaretskii <eliz@gnu.org> |
7690 | ||
7691 | * w32.c (_REPARSE_DATA_BUFFER): Condition by _MSVC and _W64. | |
7692 | ||
54e95010 JD |
7693 | 2013-03-26 Jan Djärv <jan.h.d@swipnet.se> |
7694 | ||
7695 | * gtkutil.c (style_changed_cb): Check if frame is live and an | |
7696 | X frame (Bug#14038). | |
7697 | ||
b88b62de EZ |
7698 | 2013-03-26 Eli Zaretskii <eliz@gnu.org> |
7699 | ||
a18d7de6 EZ |
7700 | * w32.c (_PROCESS_MEMORY_COUNTERS_EX) [_WIN32_WINNT < 0x0500]: |
7701 | Define only for _WIN32_WINNT less than 0x0500. | |
da9dcbb8 EZ |
7702 | (_ANONYMOUS_UNION, _ANONYMOUS_STRUCT) [!_W64]: Don't define for |
7703 | MinGW64. | |
8f5e14c8 EZ |
7704 | Move inclusion of time.h before sys/time.h, so that MinGW64 could |
7705 | see its own definitions of 'struct timeval' and 'struct timezone'. | |
a18d7de6 | 7706 | |
b88b62de EZ |
7707 | Fix incompatibilities between MinGW.org and MinGW64 headers. |
7708 | * w32term.c (WCRANGE, GLYPHSET): Don't define if _W64 is defined. | |
7709 | ||
7710 | * w32.c (REPARSE_DATA_BUFFER): Guard with | |
7711 | MAXIMUM_REPARSE_DATA_BUFFER_SIZE being defined. | |
7712 | ||
c074e458 JD |
7713 | 2013-03-25 Jan Djärv <jan.h.d@swipnet.se> |
7714 | ||
7715 | * xterm.c: Include X11/XKBlib.h | |
7716 | (XTring_bell): Use XkbBell if HAVE_XKB (Bug#14041). | |
7717 | ||
908589fd AS |
7718 | 2013-03-24 Andreas Schwab <schwab@linux-m68k.org> |
7719 | ||
7720 | * alloc.c (xpalloc, Fgarbage_collect): Reorder conditions that are | |
7721 | written backwards. | |
7722 | * blockinput.h (input_blocked_p): Likewise. | |
7723 | * bytecode.c (exec_byte_code): Likewise. | |
7724 | * callproc.c (call_process_kill, call_process_cleanup) | |
7725 | (Fcall_process): Likewise. | |
7726 | * ccl.c (ccl_driver, resolve_symbol_ccl_program) | |
7727 | (Fccl_execute_on_string): Likewise. | |
7728 | * character.c (string_escape_byte8): Likewise. | |
7729 | * charset.c (read_hex): Likewise. | |
7730 | * cm.c (calccost): Likewise. | |
7731 | * data.c (cons_to_unsigned): Likewise. | |
7732 | * dired.c (directory_files_internal, file_name_completion): | |
7733 | Likewise. | |
7734 | * dispnew.c (scrolling_window, update_frame_1, Fsleep_for) | |
7735 | (sit_for): Likewise. | |
7736 | * doc.c (Fsubstitute_command_keys): Likewise. | |
7737 | * doprnt.c (doprnt): Likewise. | |
7738 | * editfns.c (hi_time, decode_time_components, Fformat): Likewise. | |
7739 | * emacsgtkfixed.c: Likewise. | |
7740 | * fileio.c (file_offset, Fwrite_region): Likewise. | |
7741 | * floatfns.c (Fexpt, fmod_float): Likewise. | |
7742 | * fns.c (larger_vector, make_hash_table, Fmake_hash_table): | |
7743 | Likewise. | |
7744 | * font.c (font_intern_prop): Likewise. | |
7745 | * frame.c (x_set_alpha): Likewise. | |
7746 | * gtkutil.c (get_utf8_string): Likewise. | |
7747 | * indent.c (check_display_width): Likewise. | |
7748 | * intervals.c (create_root_interval, rotate_right, rotate_left) | |
7749 | (split_interval_right, split_interval_left) | |
7750 | (adjust_intervals_for_insertion, delete_node) | |
7751 | (interval_deletion_adjustment, adjust_intervals_for_deletion) | |
7752 | (merge_interval_right, merge_interval_left, copy_intervals) | |
7753 | (set_intervals_multibyte_1): Likewise. | |
7754 | * keyboard.c (gobble_input, append_tool_bar_item): Likewise. | |
7755 | * keymap.c (Fkey_description): Likewise. | |
7756 | * lisp.h (FIXNUM_OVERFLOW_P, vcopy): Likewise. | |
7757 | * lread.c (openp, read_integer, read1, string_to_number): | |
7758 | Likewise. | |
7759 | * menu.c (ensure_menu_items): Likewise. | |
7760 | * minibuf.c (read_minibuf_noninteractive): Likewise. | |
7761 | * print.c (printchar, strout): Likewise. | |
7762 | * process.c (create_process, Faccept_process_output) | |
7763 | (wait_reading_process_output, read_process_output, send_process) | |
7764 | (wait_reading_process_output): Likewise. | |
7765 | * profiler.c (make_log, handle_profiler_signal): Likewise. | |
7766 | * regex.c (re_exec): Likewise. | |
7767 | * regex.h: Likewise. | |
7768 | * search.c (looking_at_1, Freplace_match): Likewise. | |
7769 | * sysdep.c (get_child_status, procfs_ttyname) | |
7770 | (procfs_get_total_memory): Likewise. | |
7771 | * systime.h (EMACS_TIME_VALID_P): Likewise. | |
7772 | * term.c (dissociate_if_controlling_tty): Likewise. | |
7773 | * window.c (get_phys_cursor_glyph): Likewise. | |
7774 | * xdisp.c (init_iterator, redisplay_internal, redisplay_window) | |
7775 | (try_window_reusing_current_matrix, try_window_id, pint2hrstr): | |
7776 | Likewise. | |
7777 | * xfns.c (Fx_window_property): Likewise. | |
7778 | * xmenu.c (set_frame_menubar): Likewise. | |
7779 | * xselect.c (x_get_window_property, x_handle_dnd_message): | |
7780 | Likewise. | |
7781 | * xsmfns.c (smc_save_yourself_CB): Likewise. | |
7782 | * xterm.c (x_scroll_bar_set_handle): Likewise. | |
7783 | ||
2bf7d27a DA |
7784 | 2013-03-24 Dmitry Antipov <dmantipov@yandex.ru> |
7785 | ||
7786 | * xfaces.c (Finternal_face_x_get_resource): Allow 3rd (frame) argument | |
7787 | to be optional or nil. Adjust comment and convert it to docstring. | |
7788 | * xselect.c (Fx_send_client_event): Rename to Fx_send_client_message. | |
7789 | * frame.c (display_x_get_resource, Fx_get_resource): Break long line. | |
7790 | ||
a9ebfa0b PE |
7791 | 2013-03-24 Paul Eggert <eggert@cs.ucla.edu> |
7792 | ||
7793 | Static checking by GCC 4.8-20130319. | |
7794 | * image.c (gif_load): Assume pass < 3 to pacify GCC. | |
7795 | * process.c (Fset_process_datagram_address) | |
7796 | (Fmake_network_process): Check get_lisp_to_sockaddr_size return value. | |
7797 | * xdisp.c (get_char_face_and_encoding): | |
7798 | (get_glyph_face_and_encoding): Ensure that *CHAR2B is initialized. | |
7799 | (get_glyph_face_and_encoding): Prepare face before possibly using it. | |
7800 | (get_per_char_metric): Don't use CHAR2B if it might not be initialized. | |
7801 | ||
4f3576ee KB |
7802 | 2013-03-24 Ken Brown <kbrown@cornell.edu> |
7803 | ||
789b5e9a KB |
7804 | * w32fns.c (emacs_abort) [CYGWIN]: Define `_open' as a macro to |
7805 | fix compilation on 64-bit Cygwin, where underscores are not | |
7806 | automatically prepended. | |
7807 | ||
4f3576ee KB |
7808 | * w32term.c (w32_initialize): Silence compiler warning. |
7809 | ||
b5b7745f EZ |
7810 | 2013-03-23 Eli Zaretskii <eliz@gnu.org> |
7811 | ||
cdc0d0bd EZ |
7812 | * w32term.c (w32fullscreen_hook): Use FRAME_NORMAL_WIDTH, |
7813 | FRAME_NORMAL_HEIGHT, and FRAME_PREV_FSMODE, instead of static | |
562c6ee9 SM |
7814 | variables, to save and restore frame dimensions. |
7815 | Use FRAME_NORMAL_LEFT and FRAME_NORMAL_TOP to restore frame position | |
7816 | after returning from a 'fullscreen' configuration. | |
7817 | use SendMessage instead of PostMessage to send the SC_RESTORE message, | |
cdc0d0bd EZ |
7818 | to avoid races between the main thread and the input thread. |
7819 | ||
7820 | * w32term.h (struct w32_output): New members normal_width, | |
7821 | normal_height, normal_top, normal_left, and prev_fsmode. | |
7822 | (FRAME_NORMAL_WIDTH, FRAME_NORMAL_HEIGHT, FRAME_NORMAL_TOP) | |
7823 | (FRAME_NORMAL_LEFT, FRAME_PREV_FSMODE): New macros to access these | |
7824 | members of a frame. | |
7825 | ||
b5b7745f EZ |
7826 | * w32term.c (w32fullscreen_hook): Record last value of the frame's |
7827 | 'fullscreen' parameter. Always record previous width and height | |
7828 | of the frame, except when switching out of maximized modes, so | |
7829 | that they could be restored correctly, instead of resetting to the | |
7830 | default frame dimensions. Send SC_RESTORE command to the frame, | |
7831 | unless we are going to send SC_MAXIMIZE, to restore the frame | |
7832 | resize hints in the mouse pointer shown by the window manager. | |
7833 | (Bug#14032) | |
7834 | ||
7835 | * frame.c (get_frame_param): Now extern for WINDOWSNT as well. | |
7836 | ||
7837 | * lisp.h (get_frame_param): Adjust conditions for prototype | |
7838 | declaration. | |
7839 | ||
a3454eed KB |
7840 | 2013-03-22 Ken Brown <kbrown@cornell.edu> |
7841 | ||
7842 | * unexcw.c: Drop unneeded inclusion of w32common.h. | |
7843 | (report_sheap_usage): Declare. | |
7844 | (read_exe_header): Add magic numbers for x86_64. | |
7845 | (fixup_executable): Fix printf format specifier for unsigned long | |
7846 | argument. | |
7847 | ||
5a49b79c DA |
7848 | 2013-03-22 Dmitry Antipov <dmantipov@yandex.ru> |
7849 | ||
7850 | * frame.h (struct frame): Put menu_bar_window under #ifdef | |
7851 | because this member is not needed when X toolkit is in use. | |
7852 | (fset_menu_bar_window): | |
7853 | * dispnew.c (clear_current_matrices, clear_desired_matrices) | |
7854 | (free_glyphs, update_frame): | |
7855 | * xdisp.c (expose_frame): Likewise. | |
7856 | (display_menu_bar): Likewise. Remove redundant eassert. | |
7857 | * window.h (WINDOW_MENU_BAR_P): Always define to 0 if X | |
7858 | toolkit is in use. | |
7859 | ||
d6723bf7 PE |
7860 | 2013-03-21 Paul Eggert <eggert@cs.ucla.edu> |
7861 | ||
7b1123d8 PE |
7862 | Use functions and constants to manipulate Lisp_Save_Value objects. |
7863 | This replaces code that used macros and strings and token-pasting. | |
7864 | The change makes the C source a bit easier to follow, | |
7865 | and shrinks the Emacs executable a bit. | |
7866 | * alloc.c: Verify some properties of Lisp_Save_Value's representation. | |
7867 | (make_save_value): Change 1st arg from string to enum. All callers | |
7868 | changed. | |
7869 | (INTX): Remove. | |
7870 | (mark_object): Use if, not #if, for GC_MARK_STACK. | |
7871 | * lisp.h (SAVE_VALUEP, XSAVE_VALUE, XSAVE_POINTER, XSAVE_INTEGER) | |
7872 | (XSAVE_OBJECT): Now functions, not macros. | |
7873 | (STRING_BYTES_BOUND): Now just a macro, not a constant too; | |
7874 | the constant was never used. | |
7875 | (SAVE_SLOT_BITS, SAVE_VALUE_SLOTS, SAVE_TYPE_BITS, SAVE_TYPE_INT_INT) | |
7876 | (SAVE_TYPE_INT_INT_INT, SAVE_TYPE_OBJ_OBJ, SAVE_TYPE_OBJ_OBJ_OBJ) | |
7877 | (SAVE_TYPE_OBJ_OBJ_OBJ_OBJ, SAVE_TYPE_PTR_INT, SAVE_TYPE_PTR_OBJ) | |
7878 | (SAVE_TYPE_PTR_PTR, SAVE_TYPE_PTR_PTR_OBJ, SAVE_TYPE_MEMORY): | |
7879 | New constants. | |
7880 | (struct Lisp_Save_Value): Replace members area, type0, type1, type2, | |
7881 | type3 with a single member save_type. All uses changed. | |
7882 | (save_type, set_save_pointer, set_save_integer): New functions. | |
7883 | * print.c (PRINTX): Remove. | |
7884 | ||
d6723bf7 PE |
7885 | * alloc.c: Remove redundant static declarations. |
7886 | ||
5f24fa51 DA |
7887 | 2013-03-20 Dmitry Antipov <dmantipov@yandex.ru> |
7888 | ||
7889 | * window.h (struct window): Convert left_col, top_line, total_lines | |
7890 | and total_cols from Lisp_Objects to integers. Adjust comments. | |
7891 | (wset_left_col, wset_top_line, wset_total_cols, wset_total_lines): | |
7892 | Remove. | |
7893 | (WINDOW_TOTAL_COLS, WINDOW_TOTAL_LINES, WINDOW_LEFT_EDGE_COL) | |
7894 | (WINDOW_TOP_EDGE_LINE): Drop Lisp_Object to integer conversion. | |
7895 | * dispnew.c, frame.c, w32fns.c, window.c, xdisp.c, xfns.c: | |
7896 | Adjust users where appropriate. | |
7897 | ||
42143acd DA |
7898 | 2013-03-20 Dmitry Antipov <dmantipov@yandex.ru> |
7899 | ||
7900 | * frame.h (struct frame): Drop resx and resy because the same data is | |
7901 | available from window system-specific output context. Adjust users. | |
562c6ee9 SM |
7902 | (default_pixels_per_inch_x, default_pixels_per_inch_y): |
7903 | New functions to provide defaults when no window system available. | |
42143acd | 7904 | (FRAME_RES_X, FRAME_RES_Y): New macros. |
562c6ee9 | 7905 | (NUMVAL): Move from xdisp.c. |
42143acd DA |
7906 | * font.c (font_pixel_size, font_find_for_lface, font_open_for_lface) |
7907 | (Ffont_face_attributes, Fopen_font): | |
7908 | * image.c (gs_load): | |
7909 | * w32font.c (fill_in_logfont): | |
7910 | * xdisp.c (calc_pixel_width_or_height): | |
7911 | * xfaces.c (Fx_family_fonts, set_lface_from_font): Use them. | |
7912 | * xsettings.c (apply_xft_settings): Drop frame loop and adjust comment. | |
7913 | ||
c0a17406 KH |
7914 | 2013-03-20 Kenichi Handa <handa@gnu.org> |
7915 | ||
7916 | * coding.c (syms_of_coding): Initialize disable_ascii_optimization | |
7917 | to 1 (temporary workaround until a bug related to ASCII | |
7918 | optimization is fixed). | |
7919 | ||
095d384d DA |
7920 | 2013-03-19 Dmitry Antipov <dmantipov@yandex.ru> |
7921 | ||
7922 | * window.c (Fwindow_combination_limit, Fset_window_combination_limit): | |
7923 | Signal error if window is not internal. Adjust docstring. | |
7924 | (delete_all_child_windows): Use combination_limit to save the buffer. | |
7925 | (Fset_window_configuration): Adjust accordingly. | |
cf4bb06d DA |
7926 | * print.c (syms_of_print): Initialize debugging output not here... |
7927 | (init_print_once): ...but in a new function here. | |
7928 | * lisp.h (init_print_once): Add prototype. | |
7929 | * emacs.c (main): Add call to init_print_once. Adjust comments. | |
095d384d | 7930 | |
748fa866 DA |
7931 | 2013-03-18 Dmitry Antipov <dmantipov@yandex.ru> |
7932 | ||
7933 | * window.c (window_resize_check, window_resize_apply) | |
7934 | (window_from_coordinates, recombine_windows, set_window_buffer) | |
7935 | (make_parent_window, Fwindow_resize_apply, resize_frame_windows) | |
7936 | (Fsplit_window_internal, Fdelete_window_internal) | |
7937 | (freeze_window_starts): Use bool for booleans. | |
7938 | * window.h (window_frame_coordinates, resize_frame_windows) | |
7939 | (freeze_window_starts, set_window_buffer): Adjust prototypes. | |
7940 | ||
81519fd2 SM |
7941 | 2013-03-17 Stefan Monnier <monnier@iro.umontreal.ca> |
7942 | ||
7943 | * dispnew.c (bitch_at_user): Use `user-error'. | |
7944 | ||
6db423a9 KB |
7945 | 2013-03-17 Ken Brown <kbrown@cornell.edu> |
7946 | ||
7947 | * dispextern.h (RGB_PIXEL_COLOR): Move here from image.c. Use it | |
7948 | as return type of image_background. (Bug#13981) | |
7949 | * image.c (RGB_PIXEL_COLOR): Move to dispextern.h. | |
7950 | ||
8f2906f5 JD |
7951 | 2013-03-16 Jan Djärv <jan.h.d@swipnet.se> |
7952 | ||
960ce480 | 7953 | * nsterm.m (updateFrameSize:): Change resize increments if needed. |
6615748a | 7954 | (ns_select): Don't return with result uninitialized. |
960ce480 | 7955 | |
8f2906f5 JD |
7956 | * nsterm.h (EmacsSavePanel, EmacsOpenPanel): Add getFilename |
7957 | and getDirectory. | |
7958 | ||
81519fd2 SM |
7959 | * nsfns.m (ns_filename_from_panel, ns_directory_from_panel): |
7960 | New functions. | |
8f2906f5 JD |
7961 | (Fns_read_file_name): ret is BOOL. If ! dir_only_p, don't choose |
7962 | directories. If filename is nil, get directory name (Bug#13932). | |
7963 | Use getFilename and getDirectory. | |
7964 | (getFilename, getDirectory): New methods for EmacsSavePanel and | |
7965 | EmacsOpenPanel. | |
7966 | (ok:): In EmacsOpenPanel, if we can't choose directories, just return. | |
7967 | ||
cded56c1 PE |
7968 | 2013-03-15 Paul Eggert <eggert@cs.ucla.edu> |
7969 | ||
7970 | * coding.c (decode_coding_gap): Fix typo caught by static checking. | |
7971 | ||
251e9147 | 7972 | 2013-03-15 Kenichi Handa <handa@gnu.org> |
8a44e6d1 KH |
7973 | |
7974 | * insdel.c (insert_from_gap): New arg text_at_gap_tail. | |
7975 | (adjust_after_replace): Make it back to static. Delete the third | |
7976 | arg text_at_gap_tail. Cancel the code for handling it. | |
7977 | ||
7978 | * coding.h (struct coding_system): New member eol_seen. | |
7979 | ||
7980 | * coding.c (detect_ascii): New function. | |
7981 | (detect_coding): Set coding->head_ascii and coding->eol_seen only | |
7982 | when the source bytes are actually scanned. On detecting for | |
7983 | coding_category_utf_8_auto, call detect_ascii instead of scanning | |
7984 | source bytes directly. | |
7985 | (produce_chars): Call insert_from_gap with the new arg 0. | |
7986 | (encode_coding): Likewise. | |
7987 | (decode_coding_gap): Control ASCII optimization by the variable | |
7988 | disable_ascii_optimization instead of #ifndef .. #endif. | |
7989 | Deccode EOL format according to coding->eol_seen. | |
7990 | (syms_of_coding): Declare disable-ascii-optimization as a Lisp | |
7991 | variable. | |
7992 | ||
8a44e6d1 KH |
7993 | * lisp.h (adjust_after_replace): Cancel externing it. |
7994 | (insert_from_gap): Adjust prototype. | |
7995 | ||
5f795e34 EZ |
7996 | 2013-03-15 Eli Zaretskii <eliz@gnu.org> |
7997 | ||
7998 | * w32term.c (w32fullscreen_hook): Swap FULLSCREEN_BOTH and | |
7999 | FULLSCREEN_MAXIMIZED. (Bug#13935) | |
8000 | ||
f258b4be DA |
8001 | 2013-03-15 Dmitry Antipov <dmantipov@yandex.ru> |
8002 | ||
8003 | * region-cache.c (find_cache_boundary, move_cache_gap) | |
8004 | (insert_cache_boundary, delete_cache_boundaries, set_cache_region): | |
8005 | Simplify debugging check and convert to eassert. Adjust comment. | |
8006 | (pp_cache): Put under ENABLE_CHECKING. | |
8007 | ||
a5cc4dde EZ |
8008 | 2013-03-14 Eli Zaretskii <eliz@gnu.org> |
8009 | ||
8010 | * w32term.c (w32_read_socket) <WM_WINDOWPOSCHANGED>: Remove old | |
8011 | and incorrect code. Treat WM_WINDOWPOSCHANGED like WM_ACTIVATE | |
8012 | and WM_ACTIVATEAPP. | |
8013 | (w32fullscreen_hook): If the frame is visible, reset | |
8014 | f->want_fullscreen flag after changing the frame size. If the | |
8015 | frame is not visible, set f->want_fullscreen to FULLSCREEN_WAIT. | |
8016 | (Bug#13953) | |
8017 | ||
3fc5e44a DC |
8018 | 2013-03-13 Daniel Colascione <dancol@dancol.org> |
8019 | ||
8020 | * emacs.c (main): Call syms_of_cygw32 on CYGWIN non-NTGUI builds | |
8021 | too so that these builds can use Cygwin's file conversion | |
8022 | functions. (We've been building and linking cygw32.o all along | |
8023 | and just not using it.) | |
8024 | ||
47d7532e PE |
8025 | 2013-03-13 Paul Eggert <eggert@cs.ucla.edu> |
8026 | ||
8027 | File synchronization fixes (Bug#13944). | |
8028 | * Makefile.in (LIB_FDATASYNC): New macro. | |
8029 | (LIBES): Use it. | |
8030 | * conf_post.h (BSD_SYSTEM, BSD_SYSTEM_AHB): Remove; no longer needed. | |
8031 | * fileio.c (Fwrite_region, write_region_inhibit_fsync): | |
8032 | Don't worry about HAVE_FSYNC, since a substitute fsync is | |
8033 | available if the system lacks one. | |
8034 | (Fwrite_regin): Retry fsync if interrupted. | |
8035 | ||
c7ffccaf EZ |
8036 | 2013-03-13 Eli Zaretskii <eliz@gnu.org> |
8037 | ||
4e2df81d | 8038 | * w32term.c (w32_read_socket): If the Emacs frame is being |
c7ffccaf EZ |
8039 | activated, call w32fullscreen_hook, to make sure the new frame |
8040 | dimensions are in effect. (Bug#13937) | |
8041 | ||
8a7debc1 DA |
8042 | 2013-03-13 Dmitry Antipov <dmantipov@yandex.ru> |
8043 | ||
8044 | * xdisp.c (init_iterator): Simplify because both character and byte | |
8045 | positions are either specified or -1. Add eassert. Adjust comment. | |
ffcd945e DA |
8046 | * window.c (Fscroll_other_window): Use SET_PT_BOTH because both |
8047 | character and byte positions can be obtained from marker. | |
8a7debc1 | 8048 | |
7fd8c501 PE |
8049 | 2013-03-13 Paul Eggert <eggert@cs.ucla.edu> |
8050 | ||
d9df6f40 PE |
8051 | Static checking by Sun C 5.12. |
8052 | * alloc.c (buffer_memory_full) [REL_ALLOC]: | |
8053 | * bytecode.c (exec_byte_code): | |
8054 | * dispnew.c (init_display): | |
8055 | * eval.c (error): | |
8056 | * fileio.c (Fsubstitute_in_file_name): | |
8057 | * keyboard.c (Fevent_convert_list): | |
8058 | * keymap.c (Fsingle_key_description): | |
8059 | * term.c (maybe_fatal, fatal): | |
8060 | * xfns.c (Fx_display_backing_store, Fx_display_visual_class): | |
8061 | * xsmfns.c (Fhandle_save_session): | |
8062 | Omit unreachable code. | |
8063 | * keymap.c (map_keymap_char_table_item): Cast void * to | |
8064 | a function pointer type; the C Standard requires this. | |
8065 | ||
7fd8c501 PE |
8066 | * sysdep.c: Remove a use of BSD_SYSTEM, which I'm trying to phase out. |
8067 | Include <sys/param.h> unconditionally, as that works elsewhere and | |
8068 | is simpler here. Include <sys/sysctl.h> if DARWIN_OS || | |
8069 | __FreeBSD__, not if BSD_SYSTEM, since it's needed only for Darwin | |
8070 | and FreeBSD now. | |
8071 | ||
a020afb9 | 8072 | See ChangeLog.12 for earlier changes. |
aac0c6e3 MR |
8073 | |
8074 | ;; Local Variables: | |
8075 | ;; coding: utf-8 | |
aac0c6e3 MR |
8076 | ;; End: |
8077 | ||
ab422c4d | 8078 | Copyright (C) 2011-2013 Free Software Foundation, Inc. |
aac0c6e3 MR |
8079 | |
8080 | This file is part of GNU Emacs. | |
8081 | ||
8082 | GNU Emacs is free software: you can redistribute it and/or modify | |
8083 | it under the terms of the GNU General Public License as published by | |
8084 | the Free Software Foundation, either version 3 of the License, or | |
8085 | (at your option) any later version. | |
8086 | ||
8087 | GNU Emacs is distributed in the hope that it will be useful, | |
8088 | but WITHOUT ANY WARRANTY; without even the implied warranty of | |
8089 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
8090 | GNU General Public License for more details. | |
8091 | ||
8092 | You should have received a copy of the GNU General Public License | |
8093 | along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>. |