Mercurial > hg > xemacs-beta
comparison src/process-unix.c @ 4981:4aebb0131297
Cleanups/renaming of EXTERNAL_TO_C_STRING and friends
-------------------- ChangeLog entries follow: --------------------
modules/ChangeLog addition:
2010-02-05 Ben Wing <ben@xemacs.org>
* postgresql/postgresql.c:
* postgresql/postgresql.c (CHECK_LIVE_CONNECTION):
* postgresql/postgresql.c (Fpq_connectdb):
* postgresql/postgresql.c (Fpq_connect_start):
* postgresql/postgresql.c (Fpq_lo_import):
* postgresql/postgresql.c (Fpq_lo_export):
* ldap/eldap.c (Fldap_open):
* ldap/eldap.c (Fldap_search_basic):
* ldap/eldap.c (Fldap_add):
* ldap/eldap.c (Fldap_modify):
* ldap/eldap.c (Fldap_delete):
* canna/canna_api.c (Fcanna_initialize):
* canna/canna_api.c (Fcanna_store_yomi):
* canna/canna_api.c (Fcanna_parse):
* canna/canna_api.c (Fcanna_henkan_begin):
EXTERNAL_TO_C_STRING returns its argument instead of storing it
in a parameter, and is renamed to EXTERNAL_TO_ITEXT. Similar
things happen to related macros. See entry in src/ChangeLog.
More Mule-izing of postgresql.c. Extract out common code
between `pq-connectdb' and `pq-connect-start'. Fix places
that signal an error string using a formatted string to instead
follow the standard and have a fixed reason followed by the
particular error message stored as one of the frobs.
src/ChangeLog addition:
2010-02-05 Ben Wing <ben@xemacs.org>
* console-msw.c (write_string_to_mswindows_debugging_output):
* console-msw.c (Fmswindows_message_box):
* console-x.c (x_perhaps_init_unseen_key_defaults):
* console.c:
* database.c (dbm_get):
* database.c (dbm_put):
* database.c (dbm_remove):
* database.c (berkdb_get):
* database.c (berkdb_put):
* database.c (berkdb_remove):
* database.c (Fopen_database):
* device-gtk.c (gtk_init_device):
* device-msw.c (msprinter_init_device_internal):
* device-msw.c (msprinter_default_printer):
* device-msw.c (msprinter_init_device):
* device-msw.c (sync_printer_with_devmode):
* device-msw.c (Fmsprinter_select_settings):
* device-x.c (sanity_check_geometry_resource):
* device-x.c (Dynarr_add_validified_lisp_string):
* device-x.c (x_init_device):
* device-x.c (Fx_put_resource):
* device-x.c (Fx_valid_keysym_name_p):
* device-x.c (Fx_set_font_path):
* dialog-msw.c (push_lisp_string_as_unicode):
* dialog-msw.c (handle_directory_dialog_box):
* dialog-msw.c (handle_file_dialog_box):
* dialog-x.c (dbox_descriptor_to_widget_value):
* editfns.c (Fformat_time_string):
* editfns.c (Fencode_time):
* editfns.c (Fset_time_zone_rule):
* emacs.c (make_argc_argv):
* emacs.c (Fdump_emacs):
* emodules.c (emodules_load):
* eval.c:
* eval.c (maybe_signal_error_1):
* event-msw.c (Fdde_alloc_advise_item):
* event-msw.c (mswindows_dde_callback):
* event-msw.c (mswindows_wnd_proc):
* fileio.c (report_error_with_errno):
* fileio.c (Fsysnetunam):
* fileio.c (Fdo_auto_save):
* font-mgr.c (extract_fcapi_string):
* font-mgr.c (Ffc_config_app_font_add_file):
* font-mgr.c (Ffc_config_app_font_add_dir):
* font-mgr.c (Ffc_config_filename):
* frame-gtk.c (gtk_set_frame_text_value):
* frame-gtk.c (gtk_create_widgets):
* frame-msw.c (mswindows_init_frame_1):
* frame-msw.c (mswindows_set_title_from_ibyte):
* frame-msw.c (msprinter_init_frame_3):
* frame-x.c (x_set_frame_text_value):
* frame-x.c (x_set_frame_properties):
* frame-x.c (start_drag_internal_1):
* frame-x.c (x_cde_transfer_callback):
* frame-x.c (x_create_widgets):
* glyphs-eimage.c (my_jpeg_output_message):
* glyphs-eimage.c (jpeg_instantiate):
* glyphs-eimage.c (gif_instantiate):
* glyphs-eimage.c (png_instantiate):
* glyphs-eimage.c (tiff_instantiate):
* glyphs-gtk.c (xbm_instantiate_1):
* glyphs-gtk.c (gtk_xbm_instantiate):
* glyphs-gtk.c (gtk_xpm_instantiate):
* glyphs-gtk.c (gtk_xface_instantiate):
* glyphs-gtk.c (cursor_font_instantiate):
* glyphs-gtk.c (gtk_redisplay_widget):
* glyphs-gtk.c (gtk_widget_instantiate_1):
* glyphs-gtk.c (gtk_add_tab_item):
* glyphs-msw.c (mswindows_xpm_instantiate):
* glyphs-msw.c (bmp_instantiate):
* glyphs-msw.c (mswindows_resource_instantiate):
* glyphs-msw.c (xbm_instantiate_1):
* glyphs-msw.c (mswindows_xbm_instantiate):
* glyphs-msw.c (mswindows_xface_instantiate):
* glyphs-msw.c (mswindows_redisplay_widget):
* glyphs-msw.c (mswindows_widget_instantiate):
* glyphs-msw.c (add_tree_item):
* glyphs-msw.c (add_tab_item):
* glyphs-msw.c (mswindows_combo_box_instantiate):
* glyphs-msw.c (mswindows_widget_query_string_geometry):
* glyphs-x.c (x_locate_pixmap_file):
* glyphs-x.c (xbm_instantiate_1):
* glyphs-x.c (x_xbm_instantiate):
* glyphs-x.c (extract_xpm_color_names):
* glyphs-x.c (x_xpm_instantiate):
* glyphs-x.c (x_xface_instantiate):
* glyphs-x.c (autodetect_instantiate):
* glyphs-x.c (safe_XLoadFont):
* glyphs-x.c (cursor_font_instantiate):
* glyphs-x.c (x_redisplay_widget):
* glyphs-x.c (Fchange_subwindow_property):
* glyphs-x.c (x_widget_instantiate):
* glyphs-x.c (x_tab_control_redisplay):
* glyphs.c (pixmap_to_lisp_data):
* gui-x.c (menu_separator_style_and_to_external):
* gui-x.c (add_accel_and_to_external):
* gui-x.c (button_item_to_widget_value):
* hpplay.c (player_error_internal):
* hpplay.c (play_sound_file):
* hpplay.c (play_sound_data):
* intl.c (Fset_current_locale):
* lisp.h:
* menubar-gtk.c (gtk_xemacs_set_accel_keys):
* menubar-msw.c (populate_menu_add_item):
* menubar-msw.c (populate_or_checksum_helper):
* menubar-x.c (menu_item_descriptor_to_widget_value_1):
* nt.c (init_user_info):
* nt.c (get_long_basename):
* nt.c (nt_get_resource):
* nt.c (init_mswindows_environment):
* nt.c (get_cached_volume_information):
* nt.c (mswindows_readdir):
* nt.c (read_unc_volume):
* nt.c (mswindows_stat):
* nt.c (mswindows_getdcwd):
* nt.c (mswindows_executable_type):
* nt.c (Fmswindows_short_file_name):
* ntplay.c (nt_play_sound_file):
* objects-gtk.c:
* objects-gtk.c (gtk_valid_color_name_p):
* objects-gtk.c (gtk_initialize_font_instance):
* objects-gtk.c (gtk_font_list):
* objects-msw.c (font_enum_callback_2):
* objects-msw.c (parse_font_spec):
* objects-x.c (x_parse_nearest_color):
* objects-x.c (x_valid_color_name_p):
* objects-x.c (x_initialize_font_instance):
* objects-x.c (x_font_instance_truename):
* objects-x.c (x_font_list):
* objects-xlike-inc.c (XFUN):
* objects-xlike-inc.c (xft_find_charset_font):
* process-nt.c (mswindows_report_winsock_error):
* process-nt.c (nt_create_process):
* process-nt.c (get_internet_address):
* process-nt.c (nt_open_network_stream):
* process-unix.c:
* process-unix.c (allocate_pty):
* process-unix.c (get_internet_address):
* process-unix.c (unix_canonicalize_host_name):
* process-unix.c (unix_open_network_stream):
* realpath.c:
* select-common.h (lisp_data_to_selection_data):
* select-gtk.c (symbol_to_gtk_atom):
* select-gtk.c (atom_to_symbol):
* select-msw.c (symbol_to_ms_cf):
* select-msw.c (mswindows_register_selection_data_type):
* select-x.c (symbol_to_x_atom):
* select-x.c (x_atom_to_symbol):
* select-x.c (hack_motif_clipboard_selection):
* select-x.c (Fx_store_cutbuffer_internal):
* sound.c (Fplay_sound_file):
* sound.c (Fplay_sound):
* sound.h (sound_perror):
* sysdep.c:
* sysdep.c (qxe_allocating_getcwd):
* sysdep.c (qxe_execve):
* sysdep.c (copy_in_passwd):
* sysdep.c (qxe_getpwnam):
* sysdep.c (qxe_ctime):
* sysdll.c (dll_open):
* sysdll.c (dll_function):
* sysdll.c (dll_variable):
* sysdll.c (search_linked_libs):
* sysdll.c (dll_error):
* sysfile.h:
* sysfile.h (PATHNAME_CONVERT_OUT_TSTR):
* sysfile.h (PATHNAME_CONVERT_OUT_UTF_8):
* sysfile.h (PATHNAME_CONVERT_OUT):
* sysfile.h (LISP_PATHNAME_CONVERT_OUT):
* syswindows.h (ITEXT_TO_TSTR):
* syswindows.h (LOCAL_FILE_FORMAT_TO_TSTR):
* syswindows.h (TSTR_TO_LOCAL_FILE_FORMAT):
* syswindows.h (LOCAL_FILE_FORMAT_TO_INTERNAL_MSWIN):
* syswindows.h (LISP_LOCAL_FILE_FORMAT_MAYBE_URL_TO_TSTR):
* text.h:
* text.h (eicpy_ext_len):
* text.h (enum new_dfc_src_type):
* text.h (EXTERNAL_TO_ITEXT):
* text.h (GET_STRERROR):
* tooltalk.c (check_status):
* tooltalk.c (Fadd_tooltalk_message_arg):
* tooltalk.c (Fadd_tooltalk_pattern_attribute):
* tooltalk.c (Fadd_tooltalk_pattern_arg):
* win32.c (tstr_to_local_file_format):
* win32.c (mswindows_lisp_error_1):
* win32.c (mswindows_report_process_error):
* win32.c (Fmswindows_shell_execute):
* win32.c (mswindows_read_link_1):
Changes involving external/internal format conversion,
mostly code cleanup and renaming.
1. Eliminate the previous macros like LISP_STRING_TO_EXTERNAL
that stored its result in a parameter. The new version of
LISP_STRING_TO_EXTERNAL returns its result through the
return value, same as the previous NEW_LISP_STRING_TO_EXTERNAL.
Use the new-style macros throughout the code.
2. Rename C_STRING_TO_EXTERNAL and friends to ITEXT_TO_EXTERNAL,
in keeping with overall naming rationalization involving
Itext and related types.
Macros involved in previous two:
EXTERNAL_TO_C_STRING -> EXTERNAL_TO_ITEXT
EXTERNAL_TO_C_STRING_MALLOC -> EXTERNAL_TO_ITEXT_MALLOC
SIZED_EXTERNAL_TO_C_STRING -> SIZED_EXTERNAL_TO_ITEXT
SIZED_EXTERNAL_TO_C_STRING_MALLOC -> SIZED_EXTERNAL_TO_ITEXT_MALLOC
C_STRING_TO_EXTERNAL -> ITEXT_TO_EXTERNAL
C_STRING_TO_EXTERNAL_MALLOC -> ITEXT_TO_EXTERNAL_MALLOC
LISP_STRING_TO_EXTERNAL
LISP_STRING_TO_EXTERNAL_MALLOC
LISP_STRING_TO_TSTR
C_STRING_TO_TSTR -> ITEXT_TO_TSTR
TSTR_TO_C_STRING -> TSTR_TO_ITEXT
The following four still return their values through parameters,
since they have more than one value to return:
C_STRING_TO_SIZED_EXTERNAL -> ITEXT_TO_SIZED_EXTERNAL
LISP_STRING_TO_SIZED_EXTERNAL
C_STRING_TO_SIZED_EXTERNAL_MALLOC -> ITEXT_TO_SIZED_EXTERNAL_MALLOC
LISP_STRING_TO_SIZED_EXTERNAL_MALLOC
Sometimes additional casts had to be inserted, since the old
macros played strange games and completely defeated the type system
of the store params.
3. Rewrite many places where direct calls to TO_EXTERNAL_FORMAT
occurred with calls to one of the convenience macros listed above,
or to make_extstring().
4. Eliminate SIZED_C_STRING macros (they were hardly used, anyway)
and use a direct call to TO_EXTERNAL_FORMAT or TO_INTERNAL_FORMAT.
4. Use LISP_PATHNAME_CONVERT_OUT in many places instead of something
like LISP_STRING_TO_EXTERNAL(..., Qfile_name).
5. Eliminate some temporary variables that are no longer necessary
now that we return a value rather than storing it into a variable.
6. Some Mule-izing in database.c.
7. Error functions:
-- A bit of code cleanup in maybe_signal_error_1.
-- Eliminate report_file_type_error; it's just an alias for
signal_error_2 with params in a different order.
-- Fix some places in the hostname-handling code that directly
inserted externally-retrieved error strings into the
supposed ASCII "reason" param instead of doing the right thing
and sticking text descriptive of what was going on in "reason"
and putting the external message in a frob.
8. Use Ascbyte instead of CIbyte in process-unix.c and maybe one
or two other places.
9. Some code cleanup in copy_in_passwd() in sysdep.c.
10. Fix a real bug due to accidental variable shadowing in
tstr_to_local_file_format() in win32.c.
author | Ben Wing <ben@xemacs.org> |
---|---|
date | Fri, 05 Feb 2010 11:02:24 -0600 |
parents | 304aebb79cd3 |
children | ae48681c47fa |
comparison
equal
deleted
inserted
replaced
4972:c448f4c38d65 | 4981:4aebb0131297 |
---|---|
220 allocate_pty() tries all the different known easy ways of opening | 220 allocate_pty() tries all the different known easy ways of opening |
221 a pty. In case of failure, we resort to the old BSD-style pty | 221 a pty. In case of failure, we resort to the old BSD-style pty |
222 grovelling code in allocate_pty_the_old_fashioned_way(). */ | 222 grovelling code in allocate_pty_the_old_fashioned_way(). */ |
223 int master_fd = -1; | 223 int master_fd = -1; |
224 const Extbyte *slave_name = NULL; | 224 const Extbyte *slave_name = NULL; |
225 const CIbyte *clone = NULL; | 225 const Ascbyte *clone = NULL; |
226 static const CIbyte * const clones[] = | 226 static const Ascbyte * const clones[] = |
227 /* Different pty master clone devices */ | 227 /* Different pty master clone devices */ |
228 { | 228 { |
229 "/dev/ptmx", /* Various systems */ | 229 "/dev/ptmx", /* Various systems */ |
230 "/dev/ptm/clone", /* HPUX */ | 230 "/dev/ptm/clone", /* HPUX */ |
231 "/dev/ptc", /* AIX */ | 231 "/dev/ptc", /* AIX */ |
305 | 305 |
306 have_slave_name: | 306 have_slave_name: |
307 { | 307 { |
308 Ibyte *slaveint; | 308 Ibyte *slaveint; |
309 | 309 |
310 EXTERNAL_TO_C_STRING (slave_name, slaveint, Qfile_name); | 310 slaveint = EXTERNAL_TO_ITEXT (slave_name, Qfile_name); |
311 qxestrncpy (pty_name, slaveint, sizeof (pty_name)); | 311 qxestrncpy (pty_name, slaveint, sizeof (pty_name)); |
312 } | 312 } |
313 | 313 |
314 pty_name[sizeof (pty_name) - 1] = '\0'; | 314 pty_name[sizeof (pty_name) - 1] = '\0'; |
315 setup_pty (master_fd); | 315 setup_pty (master_fd); |
332 the user's primary group, and we fix that. */ | 332 the user's primary group, and we fix that. */ |
333 { | 333 { |
334 struct group *tty_group = getgrnam ("tty"); | 334 struct group *tty_group = getgrnam ("tty"); |
335 if (tty_group != NULL) | 335 if (tty_group != NULL) |
336 { | 336 { |
337 Extbyte *ptyout; | 337 Extbyte *ptyout = ITEXT_TO_EXTERNAL (pty_name, Qfile_name); |
338 | |
339 C_STRING_TO_EXTERNAL (pty_name, ptyout, Qfile_name); | |
340 chown (ptyout, (uid_t) -1, tty_group->gr_gid); | 338 chown (ptyout, (uid_t) -1, tty_group->gr_gid); |
341 } | 339 } |
342 } | 340 } |
343 #endif /* HPUX has broken grantpt() */ | 341 #endif /* HPUX has broken grantpt() */ |
344 #endif /* HAVE_GRANTPT */ | 342 #endif /* HAVE_GRANTPT */ |
456 #ifdef TRY_AGAIN | 454 #ifdef TRY_AGAIN |
457 if (count++ > 10) break; | 455 if (count++ > 10) break; |
458 h_errno = 0; | 456 h_errno = 0; |
459 #endif | 457 #endif |
460 | 458 |
461 LISP_STRING_TO_EXTERNAL (host, hostext, Qunix_host_name_encoding); | 459 hostext = LISP_STRING_TO_EXTERNAL (host, Qunix_host_name_encoding); |
462 | 460 |
463 /* Some systems can't handle SIGIO/SIGALARM in gethostbyname. */ | 461 /* Some systems can't handle SIGIO/SIGALARM in gethostbyname. */ |
464 slow_down_interrupts (); | 462 slow_down_interrupts (); |
465 host_info_ptr = gethostbyname (hostext); | 463 host_info_ptr = gethostbyname (hostext); |
466 speed_up_interrupts (); | 464 speed_up_interrupts (); |
480 { | 478 { |
481 IN_ADDR numeric_addr; | 479 IN_ADDR numeric_addr; |
482 Extbyte *hostext; | 480 Extbyte *hostext; |
483 | 481 |
484 /* Attempt to interpret host as numeric inet address */ | 482 /* Attempt to interpret host as numeric inet address */ |
485 LISP_STRING_TO_EXTERNAL (host, hostext, Qunix_host_name_encoding); | 483 hostext = LISP_STRING_TO_EXTERNAL (host, Qunix_host_name_encoding); |
486 numeric_addr = inet_addr (hostext); | 484 numeric_addr = inet_addr (hostext); |
487 if (NUMERIC_ADDR_ERROR) | 485 if (NUMERIC_ADDR_ERROR) |
488 { | 486 { |
489 maybe_signal_error (Qio_error, "Unknown host", host, | 487 maybe_signal_error (Qio_error, "Unknown host", host, |
490 Qprocess, errb); | 488 Qprocess, errb); |
522 { | 520 { |
523 struct servent *svc_info; | 521 struct servent *svc_info; |
524 Extbyte *tailportext; | 522 Extbyte *tailportext; |
525 | 523 |
526 CHECK_STRING (tail_port); | 524 CHECK_STRING (tail_port); |
527 TO_EXTERNAL_FORMAT (LISP_STRING, tail_port, C_STRING_ALLOCA, | 525 svc_info = getservbyname (LISP_STRING_TO_EXTERNAL |
528 tailportext, Qunix_service_name_encoding); | 526 (tail_port, Qunix_service_name_encoding), |
529 | 527 proto); |
530 svc_info = getservbyname (tailportext, proto); | |
531 if ((svc_info != 0) && (svc_info->s_port == port)) | 528 if ((svc_info != 0) && (svc_info->s_port == port)) |
532 break; | 529 break; |
533 else | 530 else |
534 continue; | 531 continue; |
535 } | 532 } |
1814 #else | 1811 #else |
1815 hints.ai_family = PF_INET; | 1812 hints.ai_family = PF_INET; |
1816 #endif | 1813 #endif |
1817 hints.ai_socktype = SOCK_STREAM; | 1814 hints.ai_socktype = SOCK_STREAM; |
1818 hints.ai_protocol = 0; | 1815 hints.ai_protocol = 0; |
1819 LISP_STRING_TO_EXTERNAL (host, ext_host, Qunix_host_name_encoding); | 1816 ext_host = LISP_STRING_TO_EXTERNAL (host, Qunix_host_name_encoding); |
1820 retval = getaddrinfo (ext_host, NULL, &hints, &res); | 1817 retval = getaddrinfo (ext_host, NULL, &hints, &res); |
1821 if (retval != 0) | 1818 if (retval != 0) |
1822 { | 1819 { |
1823 CIbyte *gai_err; | 1820 maybe_signal_error_2 (Qio_error, "Canonicalizing host name", |
1824 | 1821 build_extstring (gai_strerror (retval), |
1825 EXTERNAL_TO_C_STRING (gai_strerror (retval), gai_err, | 1822 Qstrerror_encoding), |
1826 Qstrerror_encoding); | 1823 host, Qprocess, ERROR_ME_DEBUG_WARN); |
1827 maybe_signal_error (Qio_error, gai_err, host, | |
1828 Qprocess, ERROR_ME_DEBUG_WARN); | |
1829 canonname = host; | 1824 canonname = host; |
1830 } | 1825 } |
1831 else | 1826 else |
1832 { | 1827 { |
1833 int gni = getnameinfo (res->ai_addr, res->ai_addrlen, | 1828 int gni = getnameinfo (res->ai_addr, res->ai_addrlen, |
1899 port = htons ((unsigned short) XINT (service)); | 1894 port = htons ((unsigned short) XINT (service)); |
1900 } | 1895 } |
1901 else | 1896 else |
1902 { | 1897 { |
1903 CHECK_STRING (service); | 1898 CHECK_STRING (service); |
1904 LISP_STRING_TO_EXTERNAL (service, portstring, | 1899 portstring = LISP_STRING_TO_EXTERNAL (service, |
1905 Qunix_service_name_encoding); | 1900 Qunix_service_name_encoding); |
1906 port = 0; | 1901 port = 0; |
1907 } | 1902 } |
1908 | 1903 |
1909 xzero (hints); | 1904 xzero (hints); |
1910 hints.ai_flags = 0; | 1905 hints.ai_flags = 0; |
1912 if (EQ (protocol, Qtcp)) | 1907 if (EQ (protocol, Qtcp)) |
1913 hints.ai_socktype = SOCK_STREAM; | 1908 hints.ai_socktype = SOCK_STREAM; |
1914 else /* EQ (protocol, Qudp) */ | 1909 else /* EQ (protocol, Qudp) */ |
1915 hints.ai_socktype = SOCK_DGRAM; | 1910 hints.ai_socktype = SOCK_DGRAM; |
1916 hints.ai_protocol = 0; | 1911 hints.ai_protocol = 0; |
1917 LISP_STRING_TO_EXTERNAL (host, ext_host, Qunix_host_name_encoding); | 1912 ext_host = LISP_STRING_TO_EXTERNAL (host, Qunix_host_name_encoding); |
1918 retval = getaddrinfo (ext_host, portstring, &hints, &res); | 1913 retval = getaddrinfo (ext_host, portstring, &hints, &res); |
1919 if (retval != 0) | 1914 if (retval != 0) |
1920 { | 1915 { |
1921 CIbyte *gai_err; | 1916 signal_error_2 (Qio_error, "Converting host name to IP address", |
1922 | 1917 build_extstring (gai_strerror (retval), |
1923 EXTERNAL_TO_C_STRING (gai_strerror (retval), gai_err, | 1918 Qstrerror_encoding), |
1924 Qstrerror_encoding); | 1919 list2 (host, service)); |
1925 signal_error (Qio_error, gai_err, list2 (host, service)); | |
1926 } | 1920 } |
1927 | 1921 |
1928 /* address loop */ | 1922 /* address loop */ |
1929 for (lres = res; lres ; lres = lres->ai_next) | 1923 for (lres = res; lres ; lres = lres->ai_next) |
1930 | 1924 |
1939 { | 1933 { |
1940 struct servent *svc_info; | 1934 struct servent *svc_info; |
1941 Extbyte *servext; | 1935 Extbyte *servext; |
1942 | 1936 |
1943 CHECK_STRING (service); | 1937 CHECK_STRING (service); |
1944 LISP_STRING_TO_EXTERNAL (service, servext, | 1938 servext = LISP_STRING_TO_EXTERNAL (service, |
1945 Qunix_service_name_encoding); | 1939 Qunix_service_name_encoding); |
1946 | 1940 |
1947 if (EQ (protocol, Qtcp)) | 1941 if (EQ (protocol, Qtcp)) |
1948 svc_info = getservbyname (servext, "tcp"); | 1942 svc_info = getservbyname (servext, "tcp"); |
1949 else /* EQ (protocol, Qudp) */ | 1943 else /* EQ (protocol, Qudp) */ |
1950 svc_info = getservbyname (servext, "udp"); | 1944 svc_info = getservbyname (servext, "udp"); |