mirror of
https://git.savannah.gnu.org/git/emacs.git
synced 2024-12-11 09:20:51 +00:00
4b4deea229
* xfns.c (x_create_tip_frame, Fx_show_tip): Replace B_ with BVAR. * xfaces.c (compute_char_face): Replace B_ with BVAR. * xdisp.c (pos_visible_p, init_iterator, reseat_1) (message_dolog, update_echo_area, ensure_echo_area_buffers) (with_echo_area_buffer, setup_echo_area_for_printing) (set_message_1, update_menu_bar, update_tool_bar) (text_outside_line_unchanged_p, redisplay_internal) (try_scrolling, try_cursor_movement, redisplay_window) (try_window_reusing_current_matrix, row_containing_pos) (try_window_id, get_overlay_arrow_glyph_row, display_line) (Fcurrent_bidi_paragraph_direction, display_mode_lines) (decode_mode_spec_coding, decode_mode_spec, display_count_lines) (get_window_cursor_type, note_mouse_highlight): Replace B_ with BVAR. * window.c (window_display_table, unshow_buffer, window_loop) (window_min_size_2, set_window_buffer, Fset_window_buffer) (select_window, Fforce_window_update, temp_output_buffer_show) (Fset_window_configuration, save_window_save): Replace B_ with BVAR. * w32fns.c (x_create_tip_frame, Fx_show_tip, Fw32_shell_execute): Replace B_ with BVAR. * undo.c (record_point, record_insert, record_delete) (record_marker_adjustment, record_first_change) (record_property_change, Fundo_boundary, truncate_undo_list) (Fprimitive_undo): Replace B_ with BVAR. * syntax.h (Vstandard_syntax_table, CURRENT_SYNTAX_TABLE) (SETUP_BUFFER_SYNTAX_TABLE): Replace B_ with BVAR. * syntax.c (update_syntax_table, dec_bytepos, Fsyntax_table) (Fset_syntax_table, Fmodify_syntax_entry, skip_chars) (skip_syntaxes, scan_lists): Replace B_ with BVAR. * search.c (compile_pattern_1, compile_pattern, looking_at_1) (string_match_1, fast_looking_at, newline_cache_on_off) (search_command, search_buffer, simple_search, boyer_moore) (Freplace_match): Replace B_ with BVAR. * process.c (get_process, list_processes_1, Fstart_process) (Fmake_serial_process, Fmake_network_process) (read_process_output, send_process, exec_sentinel) (status_notify, setup_process_coding_systems): Replace B_ with BVAR. * print.c (PRINTDECLARE, PRINTPREPARE, PRINTFINISH, printchar) (strout, print_string, temp_output_buffer_setup, print_object): Replace B_ with BVAR. * msdos.c (IT_frame_up_to_date): Replace B_ with BVAR. * minibuf.c (read_minibuf, get_minibuffer, Fread_buffer): Replace B_ with BVAR. * marker.c (Fmarker_buffer, Fset_marker, set_marker_restricted) (set_marker_both, set_marker_restricted_both, unchain_marker): Replace B_ with BVAR. * lread.c (readchar, unreadchar, openp, readevalloop) (Feval_buffer, Feval_region): Replace B_ with BVAR. * lisp.h (DOWNCASE_TABLE, UPCASE_TABLE): Replace B_ with BVAR. * keymap.c (Flocal_key_binding, Fuse_local_map) (Fcurrent_local_map, push_key_description) (Fdescribe_buffer_bindings): Replace B_ with BVAR. * keyboard.c (command_loop_1, read_char_minibuf_menu_prompt) (read_key_sequence): Replace B_ with BVAR. * intervals.h (TEXT_PROP_MEANS_INVISIBLE): Replace B_ with BVAR. * intervals.c (set_point_both, get_local_map): Replace B_ with BVAR. * insdel.c (check_markers, insert_char, insert_1_both) (insert_from_string_1, insert_from_gap, insert_from_buffer_1) (adjust_after_replace, replace_range, del_range_2) (modify_region, prepare_to_modify_buffer) (Fcombine_after_change_execute): Replace B_ with BVAR. * indent.c (buffer_display_table, recompute_width_table) (width_run_cache_on_off, current_column, scan_for_column) (Findent_to, position_indentation, compute_motion, vmotion): Replace B_ with BVAR. * fringe.c (get_logical_cursor_bitmap) (get_logical_fringe_bitmap, update_window_fringes): Replace B_ with BVAR. * frame.c (make_frame_visible_1): Replace B_ with BVAR. * font.c (font_at): Replace B_ with BVAR. * fns.c (Fbase64_encode_region, Fbase64_decode_region, Fmd5): Replace B_ with BVAR. * filelock.c (unlock_all_files, Flock_buffer, Funlock_buffer) (unlock_buffer): Replace B_ with BVAR. * fileio.c (Fexpand_file_name, Ffile_directory_p) (Ffile_regular_p, Ffile_selinux_context) (Fset_file_selinux_context, Ffile_modes, Fset_file_modes) (Fset_file_times, Ffile_newer_than_file_p, decide_coding_unwind) (Finsert_file_contents, choose_write_coding_system) (Fwrite_region, build_annotations, Fverify_visited_file_modtime) (Fset_visited_file_modtime, auto_save_error, auto_save_1) (Fdo_auto_save, Fset_buffer_auto_saved): Replace B_ with BVAR. * editfns.c (region_limit, Fmark_marker, save_excursion_save) (save_excursion_restore, Fprevious_char, Fchar_before) (general_insert_function, Finsert_char, Finsert_byte) (make_buffer_string_both, Finsert_buffer_substring) (Fcompare_buffer_substrings, subst_char_in_region_unwind) (subst_char_in_region_unwind_1, Fsubst_char_in_region) (Ftranslate_region_internal, save_restriction_restore) (Fchar_equal): Replace B_ with BVAR. * dispnew.c (Fframe_or_buffer_changed_p): Replace B_ with BVAR. * dispextern.h (WINDOW_WANTS_MODELINE_P) (WINDOW_WANTS_HEADER_LINE_P): Replace B_ with BVAR. * dired.c (directory_files_internal): Replace B_ with BVAR. * data.c (swap_in_symval_forwarding, set_internal) (Fmake_local_variable, Fkill_local_variable, Flocal_variable_p): Replace B_ with BVAR. * composite.c (fill_gstring_header) (composition_compute_stop_pos, composition_adjust_point) (Ffind_composition_internal): Replace B_ with BVAR. * coding.c (decode_coding, encode_coding) (make_conversion_work_buffer, decode_coding_gap) (decode_coding_object, encode_coding_object) (Fdetect_coding_region, Ffind_coding_systems_region_internal) (Funencodable_char_position, Fcheck_coding_systems_region): Replace B_ with BVAR. * cmds.c (Fself_insert_command, internal_self_insert): Replace B_ with BVAR. * charset.c (Ffind_charset_region): Replace B_ with BVAR. * character.h (FETCH_CHAR_ADVANCE, INC_BOTH, DEC_BOTH) (ASCII_CHAR_WIDTH): Replace B_ with BVAR. * character.c (chars_in_text, Fget_byte): Replace B_ with BVAR. * category.h (Vstandard_category_table): Replace B_ with BVAR. * category.c (check_category_table, Fcategory_table) (Fset_category_table, char_category_set): Replace B_ with BVAR. * casetab.c (Fcurrent_case_table, set_case_table): Replace B_ with BVAR. * casefiddle.c (casify_object, casify_region): Replace B_ with BVAR. * callproc.c (Fcall_process, Fcall_process_region): Replace B_ with BVAR. * callint.c (check_mark, Fcall_interactively): Replace B_ with BVAR. * bytecode.c (Fbyte_code): Replace B_ with BVAR. * buffer.h (FETCH_CHAR, FETCH_CHAR_AS_MULTIBYTE, BVAR): Replace B_ with BVAR. * buffer.c (Fbuffer_live_p, Fget_file_buffer) (get_truename_buffer, Fget_buffer_create) (clone_per_buffer_values, Fmake_indirect_buffer, reset_buffer) (reset_buffer_local_variables, Fbuffer_name, Fbuffer_file_name) (Fbuffer_local_value, buffer_lisp_local_variables) (Fset_buffer_modified_p, Frestore_buffer_modified_p) (Frename_buffer, Fother_buffer, Fbuffer_enable_undo) (Fkill_buffer, Fset_buffer_major_mode, set_buffer_internal_1) (set_buffer_temp, Fset_buffer, set_buffer_if_live) (Fbarf_if_buffer_read_only, Fbury_buffer, Ferase_buffer) (Fbuffer_swap_text, swapfield_, Fbuffer_swap_text) (Fset_buffer_multibyte, swap_out_buffer_local_variables) (record_overlay_string, overlay_strings, init_buffer_once) (init_buffer, syms_of_buffer): Replace B_ with BVAR.
445 lines
13 KiB
C
445 lines
13 KiB
C
/* GNU Emacs case conversion functions.
|
||
|
||
Copyright (C) 1985, 1994, 1997-1999, 2001-2011 Free Software Foundation, Inc.
|
||
|
||
This file is part of GNU Emacs.
|
||
|
||
GNU Emacs is free software: you can redistribute it and/or modify
|
||
it under the terms of the GNU General Public License as published by
|
||
the Free Software Foundation, either version 3 of the License, or
|
||
(at your option) any later version.
|
||
|
||
GNU Emacs is distributed in the hope that it will be useful,
|
||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||
GNU General Public License for more details.
|
||
|
||
You should have received a copy of the GNU General Public License
|
||
along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>. */
|
||
|
||
|
||
#include <config.h>
|
||
#include <setjmp.h>
|
||
#include "lisp.h"
|
||
#include "buffer.h"
|
||
#include "character.h"
|
||
#include "commands.h"
|
||
#include "syntax.h"
|
||
#include "composite.h"
|
||
#include "keymap.h"
|
||
|
||
enum case_action {CASE_UP, CASE_DOWN, CASE_CAPITALIZE, CASE_CAPITALIZE_UP};
|
||
|
||
Lisp_Object Qidentity;
|
||
|
||
Lisp_Object
|
||
casify_object (enum case_action flag, Lisp_Object obj)
|
||
{
|
||
register int c, c1;
|
||
register int inword = flag == CASE_DOWN;
|
||
|
||
/* If the case table is flagged as modified, rescan it. */
|
||
if (NILP (XCHAR_TABLE (BVAR (current_buffer, downcase_table))->extras[1]))
|
||
Fset_case_table (BVAR (current_buffer, downcase_table));
|
||
|
||
if (INTEGERP (obj))
|
||
{
|
||
int flagbits = (CHAR_ALT | CHAR_SUPER | CHAR_HYPER
|
||
| CHAR_SHIFT | CHAR_CTL | CHAR_META);
|
||
int flags = XINT (obj) & flagbits;
|
||
int multibyte = ! NILP (BVAR (current_buffer, enable_multibyte_characters));
|
||
|
||
/* If the character has higher bits set
|
||
above the flags, return it unchanged.
|
||
It is not a real character. */
|
||
if ((unsigned) XFASTINT (obj) > (unsigned) flagbits)
|
||
return obj;
|
||
|
||
c1 = XFASTINT (obj) & ~flagbits;
|
||
/* FIXME: Even if enable-multibyte-characters is nil, we may
|
||
manipulate multibyte chars. This means we have a bug for latin-1
|
||
chars since when we receive an int 128-255 we can't tell whether
|
||
it's an eight-bit byte or a latin-1 char. */
|
||
if (c1 >= 256)
|
||
multibyte = 1;
|
||
if (! multibyte)
|
||
MAKE_CHAR_MULTIBYTE (c1);
|
||
c = DOWNCASE (c1);
|
||
if (inword)
|
||
XSETFASTINT (obj, c | flags);
|
||
else if (c == (XFASTINT (obj) & ~flagbits))
|
||
{
|
||
if (! inword)
|
||
c = UPCASE1 (c1);
|
||
if (! multibyte)
|
||
MAKE_CHAR_UNIBYTE (c);
|
||
XSETFASTINT (obj, c | flags);
|
||
}
|
||
return obj;
|
||
}
|
||
|
||
if (!STRINGP (obj))
|
||
wrong_type_argument (Qchar_or_string_p, obj);
|
||
else if (!STRING_MULTIBYTE (obj))
|
||
{
|
||
EMACS_INT i;
|
||
EMACS_INT size = SCHARS (obj);
|
||
|
||
obj = Fcopy_sequence (obj);
|
||
for (i = 0; i < size; i++)
|
||
{
|
||
c = SREF (obj, i);
|
||
MAKE_CHAR_MULTIBYTE (c);
|
||
c1 = c;
|
||
if (inword && flag != CASE_CAPITALIZE_UP)
|
||
c = DOWNCASE (c);
|
||
else if (!UPPERCASEP (c)
|
||
&& (!inword || flag != CASE_CAPITALIZE_UP))
|
||
c = UPCASE1 (c1);
|
||
if ((int) flag >= (int) CASE_CAPITALIZE)
|
||
inword = (SYNTAX (c) == Sword);
|
||
if (c != c1)
|
||
{
|
||
MAKE_CHAR_UNIBYTE (c);
|
||
/* If the char can't be converted to a valid byte, just don't
|
||
change it. */
|
||
if (c >= 0 && c < 256)
|
||
SSET (obj, i, c);
|
||
}
|
||
}
|
||
return obj;
|
||
}
|
||
else
|
||
{
|
||
EMACS_INT i, i_byte, size = SCHARS (obj);
|
||
int len;
|
||
USE_SAFE_ALLOCA;
|
||
unsigned char *dst, *o;
|
||
/* Over-allocate by 12%: this is a minor overhead, but should be
|
||
sufficient in 99.999% of the cases to avoid a reallocation. */
|
||
EMACS_INT o_size = SBYTES (obj) + SBYTES (obj) / 8 + MAX_MULTIBYTE_LENGTH;
|
||
SAFE_ALLOCA (dst, void *, o_size);
|
||
o = dst;
|
||
|
||
for (i = i_byte = 0; i < size; i++, i_byte += len)
|
||
{
|
||
if ((o - dst) + MAX_MULTIBYTE_LENGTH > o_size)
|
||
{ /* Not enough space for the next char: grow the destination. */
|
||
unsigned char *old_dst = dst;
|
||
o_size += o_size; /* Probably overkill, but extremely rare. */
|
||
SAFE_ALLOCA (dst, void *, o_size);
|
||
memcpy (dst, old_dst, o - old_dst);
|
||
o = dst + (o - old_dst);
|
||
}
|
||
c = STRING_CHAR_AND_LENGTH (SDATA (obj) + i_byte, len);
|
||
if (inword && flag != CASE_CAPITALIZE_UP)
|
||
c = DOWNCASE (c);
|
||
else if (!UPPERCASEP (c)
|
||
&& (!inword || flag != CASE_CAPITALIZE_UP))
|
||
c = UPCASE1 (c);
|
||
if ((int) flag >= (int) CASE_CAPITALIZE)
|
||
inword = (SYNTAX (c) == Sword);
|
||
o += CHAR_STRING (c, o);
|
||
}
|
||
eassert (o - dst <= o_size);
|
||
obj = make_multibyte_string ((char *) dst, size, o - dst);
|
||
SAFE_FREE ();
|
||
return obj;
|
||
}
|
||
}
|
||
|
||
DEFUN ("upcase", Fupcase, Supcase, 1, 1, 0,
|
||
doc: /* Convert argument to upper case and return that.
|
||
The argument may be a character or string. The result has the same type.
|
||
The argument object is not altered--the value is a copy.
|
||
See also `capitalize', `downcase' and `upcase-initials'. */)
|
||
(Lisp_Object obj)
|
||
{
|
||
return casify_object (CASE_UP, obj);
|
||
}
|
||
|
||
DEFUN ("downcase", Fdowncase, Sdowncase, 1, 1, 0,
|
||
doc: /* Convert argument to lower case and return that.
|
||
The argument may be a character or string. The result has the same type.
|
||
The argument object is not altered--the value is a copy. */)
|
||
(Lisp_Object obj)
|
||
{
|
||
return casify_object (CASE_DOWN, obj);
|
||
}
|
||
|
||
DEFUN ("capitalize", Fcapitalize, Scapitalize, 1, 1, 0,
|
||
doc: /* Convert argument to capitalized form and return that.
|
||
This means that each word's first character is upper case
|
||
and the rest is lower case.
|
||
The argument may be a character or string. The result has the same type.
|
||
The argument object is not altered--the value is a copy. */)
|
||
(Lisp_Object obj)
|
||
{
|
||
return casify_object (CASE_CAPITALIZE, obj);
|
||
}
|
||
|
||
/* Like Fcapitalize but change only the initials. */
|
||
|
||
DEFUN ("upcase-initials", Fupcase_initials, Supcase_initials, 1, 1, 0,
|
||
doc: /* Convert the initial of each word in the argument to upper case.
|
||
Do not change the other letters of each word.
|
||
The argument may be a character or string. The result has the same type.
|
||
The argument object is not altered--the value is a copy. */)
|
||
(Lisp_Object obj)
|
||
{
|
||
return casify_object (CASE_CAPITALIZE_UP, obj);
|
||
}
|
||
|
||
/* flag is CASE_UP, CASE_DOWN or CASE_CAPITALIZE or CASE_CAPITALIZE_UP.
|
||
b and e specify range of buffer to operate on. */
|
||
|
||
void
|
||
casify_region (enum case_action flag, Lisp_Object b, Lisp_Object e)
|
||
{
|
||
register int c;
|
||
register int inword = flag == CASE_DOWN;
|
||
register int multibyte = !NILP (BVAR (current_buffer, enable_multibyte_characters));
|
||
EMACS_INT start, end;
|
||
EMACS_INT start_byte, end_byte;
|
||
EMACS_INT first = -1, last; /* Position of first and last changes. */
|
||
EMACS_INT opoint = PT;
|
||
EMACS_INT opoint_byte = PT_BYTE;
|
||
|
||
if (EQ (b, e))
|
||
/* Not modifying because nothing marked */
|
||
return;
|
||
|
||
/* If the case table is flagged as modified, rescan it. */
|
||
if (NILP (XCHAR_TABLE (BVAR (current_buffer, downcase_table))->extras[1]))
|
||
Fset_case_table (BVAR (current_buffer, downcase_table));
|
||
|
||
validate_region (&b, &e);
|
||
start = XFASTINT (b);
|
||
end = XFASTINT (e);
|
||
modify_region (current_buffer, start, end, 0);
|
||
record_change (start, end - start);
|
||
start_byte = CHAR_TO_BYTE (start);
|
||
end_byte = CHAR_TO_BYTE (end);
|
||
|
||
SETUP_BUFFER_SYNTAX_TABLE(); /* For syntax_prefix_flag_p. */
|
||
|
||
while (start < end)
|
||
{
|
||
int c2, len;
|
||
|
||
if (multibyte)
|
||
{
|
||
c = FETCH_MULTIBYTE_CHAR (start_byte);
|
||
len = CHAR_BYTES (c);
|
||
}
|
||
else
|
||
{
|
||
c = FETCH_BYTE (start_byte);
|
||
MAKE_CHAR_MULTIBYTE (c);
|
||
len = 1;
|
||
}
|
||
c2 = c;
|
||
if (inword && flag != CASE_CAPITALIZE_UP)
|
||
c = DOWNCASE (c);
|
||
else if (!UPPERCASEP (c)
|
||
&& (!inword || flag != CASE_CAPITALIZE_UP))
|
||
c = UPCASE1 (c);
|
||
if ((int) flag >= (int) CASE_CAPITALIZE)
|
||
inword = ((SYNTAX (c) == Sword)
|
||
&& (inword || !syntax_prefix_flag_p (c)));
|
||
if (c != c2)
|
||
{
|
||
last = start;
|
||
if (first < 0)
|
||
first = start;
|
||
|
||
if (! multibyte)
|
||
{
|
||
MAKE_CHAR_UNIBYTE (c);
|
||
FETCH_BYTE (start_byte) = c;
|
||
}
|
||
else if (ASCII_CHAR_P (c2) && ASCII_CHAR_P (c))
|
||
FETCH_BYTE (start_byte) = c;
|
||
else
|
||
{
|
||
int tolen = CHAR_BYTES (c);
|
||
int j;
|
||
unsigned char str[MAX_MULTIBYTE_LENGTH];
|
||
|
||
CHAR_STRING (c, str);
|
||
if (len == tolen)
|
||
{
|
||
/* Length is unchanged. */
|
||
for (j = 0; j < len; ++j)
|
||
FETCH_BYTE (start_byte + j) = str[j];
|
||
}
|
||
else
|
||
{
|
||
/* Replace one character with the other,
|
||
keeping text properties the same. */
|
||
replace_range_2 (start, start_byte,
|
||
start + 1, start_byte + len,
|
||
(char *) str, 1, tolen,
|
||
0);
|
||
len = tolen;
|
||
}
|
||
}
|
||
}
|
||
start++;
|
||
start_byte += len;
|
||
}
|
||
|
||
if (PT != opoint)
|
||
TEMP_SET_PT_BOTH (opoint, opoint_byte);
|
||
|
||
if (first >= 0)
|
||
{
|
||
signal_after_change (first, last + 1 - first, last + 1 - first);
|
||
update_compositions (first, last + 1, CHECK_ALL);
|
||
}
|
||
}
|
||
|
||
DEFUN ("upcase-region", Fupcase_region, Supcase_region, 2, 2, "r",
|
||
doc: /* Convert the region to upper case. In programs, wants two arguments.
|
||
These arguments specify the starting and ending character numbers of
|
||
the region to operate on. When used as a command, the text between
|
||
point and the mark is operated on.
|
||
See also `capitalize-region'. */)
|
||
(Lisp_Object beg, Lisp_Object end)
|
||
{
|
||
casify_region (CASE_UP, beg, end);
|
||
return Qnil;
|
||
}
|
||
|
||
DEFUN ("downcase-region", Fdowncase_region, Sdowncase_region, 2, 2, "r",
|
||
doc: /* Convert the region to lower case. In programs, wants two arguments.
|
||
These arguments specify the starting and ending character numbers of
|
||
the region to operate on. When used as a command, the text between
|
||
point and the mark is operated on. */)
|
||
(Lisp_Object beg, Lisp_Object end)
|
||
{
|
||
casify_region (CASE_DOWN, beg, end);
|
||
return Qnil;
|
||
}
|
||
|
||
DEFUN ("capitalize-region", Fcapitalize_region, Scapitalize_region, 2, 2, "r",
|
||
doc: /* Convert the region to capitalized form.
|
||
Capitalized form means each word's first character is upper case
|
||
and the rest of it is lower case.
|
||
In programs, give two arguments, the starting and ending
|
||
character positions to operate on. */)
|
||
(Lisp_Object beg, Lisp_Object end)
|
||
{
|
||
casify_region (CASE_CAPITALIZE, beg, end);
|
||
return Qnil;
|
||
}
|
||
|
||
/* Like Fcapitalize_region but change only the initials. */
|
||
|
||
DEFUN ("upcase-initials-region", Fupcase_initials_region,
|
||
Supcase_initials_region, 2, 2, "r",
|
||
doc: /* Upcase the initial of each word in the region.
|
||
Subsequent letters of each word are not changed.
|
||
In programs, give two arguments, the starting and ending
|
||
character positions to operate on. */)
|
||
(Lisp_Object beg, Lisp_Object end)
|
||
{
|
||
casify_region (CASE_CAPITALIZE_UP, beg, end);
|
||
return Qnil;
|
||
}
|
||
|
||
static Lisp_Object
|
||
operate_on_word (Lisp_Object arg, EMACS_INT *newpoint)
|
||
{
|
||
Lisp_Object val;
|
||
EMACS_INT farend;
|
||
EMACS_INT iarg;
|
||
|
||
CHECK_NUMBER (arg);
|
||
iarg = XINT (arg);
|
||
farend = scan_words (PT, iarg);
|
||
if (!farend)
|
||
farend = iarg > 0 ? ZV : BEGV;
|
||
|
||
*newpoint = PT > farend ? PT : farend;
|
||
XSETFASTINT (val, farend);
|
||
|
||
return val;
|
||
}
|
||
|
||
DEFUN ("upcase-word", Fupcase_word, Supcase_word, 1, 1, "p",
|
||
doc: /* Convert following word (or ARG words) to upper case, moving over.
|
||
With negative argument, convert previous words but do not move.
|
||
See also `capitalize-word'. */)
|
||
(Lisp_Object arg)
|
||
{
|
||
Lisp_Object beg, end;
|
||
EMACS_INT newpoint;
|
||
XSETFASTINT (beg, PT);
|
||
end = operate_on_word (arg, &newpoint);
|
||
casify_region (CASE_UP, beg, end);
|
||
SET_PT (newpoint);
|
||
return Qnil;
|
||
}
|
||
|
||
DEFUN ("downcase-word", Fdowncase_word, Sdowncase_word, 1, 1, "p",
|
||
doc: /* Convert following word (or ARG words) to lower case, moving over.
|
||
With negative argument, convert previous words but do not move. */)
|
||
(Lisp_Object arg)
|
||
{
|
||
Lisp_Object beg, end;
|
||
EMACS_INT newpoint;
|
||
XSETFASTINT (beg, PT);
|
||
end = operate_on_word (arg, &newpoint);
|
||
casify_region (CASE_DOWN, beg, end);
|
||
SET_PT (newpoint);
|
||
return Qnil;
|
||
}
|
||
|
||
DEFUN ("capitalize-word", Fcapitalize_word, Scapitalize_word, 1, 1, "p",
|
||
doc: /* Capitalize the following word (or ARG words), moving over.
|
||
This gives the word(s) a first character in upper case
|
||
and the rest lower case.
|
||
With negative argument, capitalize previous words but do not move. */)
|
||
(Lisp_Object arg)
|
||
{
|
||
Lisp_Object beg, end;
|
||
EMACS_INT newpoint;
|
||
XSETFASTINT (beg, PT);
|
||
end = operate_on_word (arg, &newpoint);
|
||
casify_region (CASE_CAPITALIZE, beg, end);
|
||
SET_PT (newpoint);
|
||
return Qnil;
|
||
}
|
||
|
||
void
|
||
syms_of_casefiddle (void)
|
||
{
|
||
Qidentity = intern_c_string ("identity");
|
||
staticpro (&Qidentity);
|
||
defsubr (&Supcase);
|
||
defsubr (&Sdowncase);
|
||
defsubr (&Scapitalize);
|
||
defsubr (&Supcase_initials);
|
||
defsubr (&Supcase_region);
|
||
defsubr (&Sdowncase_region);
|
||
defsubr (&Scapitalize_region);
|
||
defsubr (&Supcase_initials_region);
|
||
defsubr (&Supcase_word);
|
||
defsubr (&Sdowncase_word);
|
||
defsubr (&Scapitalize_word);
|
||
}
|
||
|
||
void
|
||
keys_of_casefiddle (void)
|
||
{
|
||
initial_define_key (control_x_map, Ctl('U'), "upcase-region");
|
||
Fput (intern ("upcase-region"), Qdisabled, Qt);
|
||
initial_define_key (control_x_map, Ctl('L'), "downcase-region");
|
||
Fput (intern ("downcase-region"), Qdisabled, Qt);
|
||
|
||
initial_define_key (meta_map, 'u', "upcase-word");
|
||
initial_define_key (meta_map, 'l', "downcase-word");
|
||
initial_define_key (meta_map, 'c', "capitalize-word");
|
||
}
|