From f5497e458ada626917620248ec1238dc44fa7fd1 Mon Sep 17 00:00:00 2001 From: Adrian Robert Date: Wed, 31 Dec 2008 14:59:37 +0000 Subject: [PATCH] (ns_appkit_version_str): Rename from ns_appkit_version. (ns_appkit_version_int): New function. (x-server-version): Use ns_appkit_version_int and follow 21+ convention of returning 3 integers --- src/ChangeLog | 7 +++++++ src/nsfns.m | 39 +++++++++++++++++++++++++++++++++------ 2 files changed, 40 insertions(+), 6 deletions(-) diff --git a/src/ChangeLog b/src/ChangeLog index c06f20d5ad7..eba071fcd98 100644 --- a/src/ChangeLog +++ b/src/ChangeLog @@ -1,3 +1,10 @@ +2008-12-31 Adrian Robert + + * nsfns.m (ns_appkit_version_str): Rename from ns_appkit_version. + (ns_appkit_version_int): New function. + (x-server-version): Use ns_appkit_version_int and follow 21+ + convention of returning 3 integers. + 2008-12-30 Kenichi Handa * character.h (CHAR_VARIATION_SELECTOR_P): New macro. diff --git a/src/nsfns.m b/src/nsfns.m index 0f7b6318e63..acda234e466 100644 --- a/src/nsfns.m +++ b/src/nsfns.m @@ -952,7 +952,7 @@ ns_set_mouse_color (struct frame *f, Lisp_Object arg, Lisp_Object oldval) #define Xstr(x) Str(x) static Lisp_Object -ns_appkit_version () +ns_appkit_version_str () { char tmp[80]; @@ -967,6 +967,21 @@ ns_appkit_version () } +/* This is for use by x-server-version and collapses all version info we + have into a single int. For a better picture of the implementation + running, use ns_appkit_version_str.*/ +static int +ns_appkit_version_int () +{ +#ifdef NS_IMPL_GNUSTEP + return GNUSTEP_GUI_MAJOR_VERSION * 100 + GNUSTEP_GNU_MINOR_VERSION; +#elif defined(NS_IMPL_COCOA) + return (int)NSAppKitVersionNumber; +#endif + return 0; +} + + static void x_icon (struct frame *f, Lisp_Object parms) /* -------------------------------------------------------------------------- @@ -1602,14 +1617,26 @@ If omitted or nil, the selected frame's display is used. */) DEFUN ("x-server-version", Fx_server_version, Sx_server_version, 0, 1, 0, - doc: /* Return the version number of Nextstep display server DISPLAY. + doc: /* Return the version numbers of the server of DISPLAY. +The value is a list of three integers: the major and minor +version numbers of the X Protocol in use, and the distributor-specific +release number. See also the function `x-server-vendor'. + +The optional argument DISPLAY specifies which display to ask about. DISPLAY should be either a frame or a display name (a string). -If omitted or nil, the selected frame's display is used. -See also the function `ns-server-vendor'. */) +If omitted or nil, that stands for the selected frame's display. */) (display) Lisp_Object display; { - return ns_appkit_version (); + /*NOTE: it is unclear what would best correspond with "protocol"; + we return 10.3, meaning Panther, since this is roughly the + level that GNUstep's APIs correspond to. + The last number is where we distinguish between the Apple + and GNUstep implementations ("distributor-specific release + number") and give int'ized versions of major.minor. */ + return Fcons (make_number (10), + Fcons (make_number (3), + Fcons (make_number (ns_appkit_version_int()), Qnil))); } @@ -2658,7 +2685,7 @@ be used as the image of the icon representing the frame. */); DEFVAR_LISP ("ns-version-string", &Vns_version_string, doc: /* Toolkit version for NS Windowing. */); - Vns_version_string = ns_appkit_version (); + Vns_version_string = ns_appkit_version_str (); defsubr (&Sns_read_file_name); defsubr (&Sns_get_resource); -- 2.39.2