summaryrefslogtreecommitdiff
path: root/src/xselect.c
diff options
context:
space:
mode:
authorKenichi Handa <handa@m17n.org>2000-07-21 02:07:14 +0000
committerKenichi Handa <handa@m17n.org>2000-07-21 02:07:14 +0000
commit2b38b37ef7436c5c3810146c45b555857022b13b (patch)
tree68fa6ff07a1bbfe0c41a2bca5e653c5c0bdd5c49 /src/xselect.c
parent96db09e41093ed1ddc0e90fb581166b9b7f899e1 (diff)
downloademacs-2b38b37ef7436c5c3810146c45b555857022b13b.tar.gz
(lisp_data_to_selection_data): Use x_encode_text.
Diffstat (limited to 'src/xselect.c')
-rw-r--r--src/xselect.c61
1 files changed, 13 insertions, 48 deletions
diff --git a/src/xselect.c b/src/xselect.c
index e785960b863..dba8289ccda 100644
--- a/src/xselect.c
+++ b/src/xselect.c
@@ -1648,56 +1648,21 @@ lisp_data_to_selection_data (display, obj,
{
/* Since we are now handling multilingual text, we must consider
sending back compound text. */
- unsigned char *ptr = XSTRING (obj)->data;
- int nbytes = STRING_BYTES (XSTRING (obj));
- int charset_info = find_charset_in_text (ptr, XSTRING (obj)->size,
- nbytes, NULL, Qnil);
- *format_ret = 8;
+ int latin1_p;
- if (charset_info == 0)
- {
- /* No multibyte character in OBJ. We need not encode it. */
- *size_ret = nbytes;
- *data_ret = ptr;
- *nofree_ret = 1;
- if (NILP (type)) type = QSTRING;
- Vlast_coding_system_used = Qraw_text;
- }
- else
- {
- /* We must encode contents of OBJ to compound text format.
- The format is compatible with what the target `STRING'
- expects if OBJ contains only ASCII and Latin-1
- characters. */
- int bufsize;
- unsigned char *buf;
- struct coding_system coding;
+ if (NILP (Vnext_selection_coding_system))
+ Vnext_selection_coding_system = Vselection_coding_system;
- if (NILP (Vnext_selection_coding_system))
- Vnext_selection_coding_system = Vselection_coding_system;
- setup_coding_system
- (Fcheck_coding_system (Vnext_selection_coding_system), &coding);
- coding.src_multibyte = 1;
- coding.dst_multibyte = 0;
- Vnext_selection_coding_system = Qnil;
- coding.mode |= CODING_MODE_LAST_BLOCK;
- bufsize = encoding_buffer_size (&coding, nbytes);
- buf = (unsigned char *) xmalloc (bufsize);
- encode_coding (&coding, ptr, buf, nbytes, bufsize);
- *size_ret = coding.produced;
- *data_ret = buf;
- if (charset_info == 1)
- {
- /* Ok, we can return it as `STRING'. */
- if (NILP (type)) type = QSTRING;
- }
- else
- {
- /* We must return it as `COMPOUND_TEXT'. */
- if (NILP (type)) type = QCOMPOUND_TEXT;
- }
- Vlast_coding_system_used = coding.symbol;
- }
+ *format_ret = 8;
+ *data_ret = x_encode_text (obj, Vnext_selection_coding_system,
+ (int *) size_ret, &latin1_p);
+ *nofree_ret = (*data_ret == XSTRING (obj)->data);
+ if (NILP (type))
+ type = (latin1_p ? QSTRING : QCOMPOUND_TEXT);
+ Vlast_coding_system_used = (*nofree_ret
+ ? Qraw_text
+ : Vnext_selection_coding_system);
+ Vnext_selection_coding_system = Qnil;
}
else if (SYMBOLP (obj))
{