1
0
mirror of https://git.savannah.gnu.org/git/emacs.git synced 2025-01-07 15:21:46 +00:00

; Revert "File-name completion of non-ASCII characters on OS X (bug#22169)"

; This reverts commit 0905307522.

; This caused a build from scratch to fail.
This commit is contained in:
Anders Lindgren 2015-12-24 09:50:26 +01:00
parent 076172ba82
commit d107eda498
3 changed files with 56 additions and 7 deletions

View File

@ -276,7 +276,6 @@
(if (featurep 'ns)
(progn
(load "term/common-win")
(load "international/ucs-normalize")
(load "term/ns-win")))
(if (fboundp 'x-create-frame)
;; Do it after loading term/foo-win.el since the value of the

View File

@ -51,7 +51,6 @@
(require 'menu-bar)
(require 'fontset)
(require 'dnd)
(require 'ucs-normalize)
(defgroup ns nil
"GNUstep/Mac OS X specific features."
@ -338,12 +337,29 @@ See `ns-insert-working-text'."
(setq ns-working-overlay nil))
;; OS X file system Unicode UTF-8 NFD (decomposed form) support.
(when (eq system-type 'darwin)
;; Used prior to Emacs 25.
(define-coding-system-alias 'utf-8-nfd 'utf-8-hfs)
(declare-function ns-convert-utf8-nfd-to-nfc "nsfns.m" (str))
(set-file-name-coding-system 'utf-8-hfs))
;;;; OS X file system Unicode UTF-8 NFD (decomposed form) support
;; Lisp code based on utf-8m.el, by Seiji Zenitani, Eiji Honjoh, and
;; Carsten Bormann.
(when (eq system-type 'darwin)
(defun ns-utf8-nfd-post-read-conversion (length)
"Calls `ns-convert-utf8-nfd-to-nfc' to compose char sequences."
(save-excursion
(save-restriction
(narrow-to-region (point) (+ (point) length))
(let ((str (buffer-string)))
(delete-region (point-min) (point-max))
(insert (ns-convert-utf8-nfd-to-nfc str))
(- (point-max) (point-min))))))
(define-coding-system 'utf-8-nfd
"UTF-8 NFD (decomposed) encoding."
:coding-type 'utf-8
:mnemonic ?U
:charset-list '(unicode)
:post-read-conversion 'ns-utf8-nfd-post-read-conversion)
(set-file-name-coding-system 'utf-8-nfd))
;;;; Inter-app communications support.

View File

@ -2099,6 +2099,39 @@ and GNUstep implementations ("distributor-specific release
}
DEFUN ("ns-convert-utf8-nfd-to-nfc", Fns_convert_utf8_nfd_to_nfc,
Sns_convert_utf8_nfd_to_nfc, 1, 1, 0,
doc: /* Return an NFC string that matches the UTF-8 NFD string STR. */)
(Lisp_Object str)
{
/* TODO: If GNUstep ever implements precomposedStringWithCanonicalMapping,
remove this. */
NSString *utfStr;
Lisp_Object ret = Qnil;
NSAutoreleasePool *pool;
CHECK_STRING (str);
pool = [[NSAutoreleasePool alloc] init];
utfStr = [NSString stringWithUTF8String: SSDATA (str)];
#ifdef NS_IMPL_COCOA
if (utfStr)
utfStr = [utfStr precomposedStringWithCanonicalMapping];
#endif
if (utfStr)
{
const char *cstr = [utfStr UTF8String];
if (cstr)
ret = build_string (cstr);
}
[pool release];
if (NILP (ret))
error ("Invalid UTF-8");
return ret;
}
#ifdef NS_IMPL_COCOA
/* Compile and execute the AppleScript SCRIPT and return the error
@ -3174,6 +3207,7 @@ - (NSString *)panel: (id)sender userEnteredFilename: (NSString *)filename
defsubr (&Sns_emacs_info_panel);
defsubr (&Sns_list_services);
defsubr (&Sns_perform_service);
defsubr (&Sns_convert_utf8_nfd_to_nfc);
defsubr (&Sns_popup_font_panel);
defsubr (&Sns_popup_color_panel);