home *** CD-ROM | disk | FTP | other *** search
/ Australian Personal Computer 2004 July / APC0407D2.iso / workshop / apache / files / ActivePerl-5.6.1.638-MSWin32-x86.msi / _732b2e32d6b10efd56b145d94ee2aac5 < prev    next >
Encoding:
Text File  |  2004-04-13  |  191.6 KB  |  7,502 lines

  1. package Config;
  2. use Exporter ();
  3. @EXPORT = qw(%Config);
  4. @EXPORT_OK = qw(myconfig config_sh config_vars);
  5.  
  6. # Define our own import method to avoid pulling in the full Exporter:
  7. sub import {
  8.   my $pkg = shift;
  9.   @_ = @EXPORT unless @_;
  10.   my @func = grep {$_ ne '%Config'} @_;
  11.   local $Exporter::ExportLevel = 1;
  12.   Exporter::import('Config', @func) if @func;
  13.   return if @func == @_;
  14.   my $callpkg = caller(0);
  15.   *{"$callpkg\::Config"} = \%Config;
  16. }
  17.  
  18. die "Perl lib version (v5.6.1) doesn't match executable version ($])"
  19.     unless $^V;
  20.  
  21. $^V eq v5.6.1
  22.   or die "Perl lib version (v5.6.1) doesn't match executable version (" .
  23.     (sprintf "v%vd",$^V) . ")";
  24.  
  25. # This file was created by configpm when Perl was built. Any changes
  26. # made to this file will be lost the next time perl is built.
  27.  
  28. ## Configured by: support@ActiveState.com
  29. ### Target system: WIN32 
  30.  
  31. my $config_sh = <<'!END!';
  32. archlibexp='C:\p4view\Apps\ActivePerl\MSI\data\ActivePerl\Perl\lib'
  33. archname='MSWin32-x86-multi-thread'
  34. cc='cl'
  35. ccflags='-nologo -O1 -MD -Zi -DNDEBUG -DWIN32 -D_CONSOLE -DNO_STRICT -DHAVE_DES_FCRYPT  -DPERL_IMPLICIT_CONTEXT -DPERL_IMPLICIT_SYS -DPERL_MSVCRT_READFIX'
  36. cppflags='-DWIN32'
  37. dlsrc='dl_win32.xs'
  38. dynamic_ext='Socket IO Fcntl Opcode SDBM_File POSIX attrs Thread B re  Data/Dumper Devel/Peek ByteLoader Devel/DProf File/Glob  Sys/Hostname'
  39. extensions='DynaLoader Socket IO Fcntl Opcode SDBM_File POSIX attrs Thread B re  Data/Dumper Devel/Peek ByteLoader Devel/DProf File/Glob  Sys/Hostname Errno'
  40. installarchlib='C:\p4view\Apps\ActivePerl\MSI\data\ActivePerl\Perl\lib'
  41. installprivlib='C:\p4view\Apps\ActivePerl\MSI\data\ActivePerl\Perl\lib'
  42. libpth='C:\PROGRA~1\MICROS~3\VC98\lib'
  43. libs='  oldnames.lib kernel32.lib user32.lib gdi32.lib winspool.lib  comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib  netapi32.lib uuid.lib wsock32.lib mpr.lib winmm.lib  version.lib odbc32.lib odbccp32.lib msvcrt.lib'
  44. osname='MSWin32'
  45. osvers='4.0'
  46. prefix='C:\p4view\Apps\ActivePerl\MSI\data\ActivePerl\Perl'
  47. privlibexp='C:\p4view\Apps\ActivePerl\MSI\data\ActivePerl\Perl\lib'
  48. sharpbang='#!'
  49. shsharp='true'
  50. sig_name='ZERO NUM01 INT QUIT ILL NUM05 NUM06 NUM07 FPE KILL NUM10 SEGV NUM12 PIPE ALRM TERM NUM16 NUM17 NUM18 NUM19 CHLD BREAK ABRT STOP NUM24 CONT CLD'
  51. sig_num='0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 20 0'
  52. so='dll'
  53. startsh='#!/bin/sh'
  54. static_ext='DynaLoader'
  55. Author=''
  56. CONFIGDOTSH='true'
  57. Date='$Date'
  58. Header=''
  59. Id='$Id'
  60. Locker=''
  61. Log='$Log'
  62. PERL_API_REVISION='5'
  63. PERL_API_SUBVERSION='0'
  64. PERL_API_VERSION='5'
  65. PERL_REVISION='5'
  66. PERL_SUBVERSION='1'
  67. PERL_VERSION='6'
  68. RCSfile='$RCSfile'
  69. Revision='$Revision'
  70. Source=''
  71. State=''
  72. _a='.lib'
  73. _exe='.exe'
  74. _o='.obj'
  75. afs='false'
  76. alignbytes='8'
  77. ansi2knr=''
  78. aphostname=''
  79. api_revision='5'
  80. api_subversion='0'
  81. api_version='5'
  82. api_versionstring='5.5.0'
  83. ar='lib'
  84. archlib='C:\p4view\Apps\ActivePerl\MSI\data\ActivePerl\Perl\lib'
  85. archname64=''
  86. archobjs=''
  87. awk='awk'
  88. baserev='5'
  89. bash=''
  90. bin='C:\p4view\Apps\ActivePerl\MSI\data\ActivePerl\Perl\bin'
  91. bincompat5005='undef'
  92. binexp='C:\p4view\Apps\ActivePerl\MSI\data\ActivePerl\Perl\bin'
  93. bison=''
  94. byacc='byacc'
  95. byteorder='1234'
  96. c=''
  97. castflags='0'
  98. cat='type'
  99. cccdlflags=' '
  100. ccdlflags=' '
  101. ccflags_uselargefiles=''
  102. ccname=''
  103. ccsymbols=''
  104. ccversion=''
  105. cf_by='jand'
  106. cf_email='support@ActiveState.com'
  107. cf_time='Tue Apr 13 19:24:10 2004'
  108. charsize='1'
  109. chgrp=''
  110. chmod=''
  111. chown=''
  112. clocktype='clock_t'
  113. comm=''
  114. compress=''
  115. contains='grep'
  116. cp='copy'
  117. cpio=''
  118. cpp='cl -nologo -E'
  119. cpp_stuff='42'
  120. cppccsymbols=''
  121. cpplast=''
  122. cppminus=''
  123. cpprun='cl -nologo -E'
  124. cppstdin='cl -nologo -E'
  125. cppsymbols=''
  126. crosscompile='undef'
  127. cryptlib=''
  128. csh='undef'
  129. d_Gconvert='sprintf((b),"%.*g",(n),(x))'
  130. d_PRIEUldbl='undef'
  131. d_PRIFUldbl='undef'
  132. d_PRIGUldbl='undef'
  133. d_PRIXU64='undef'
  134. d_PRId64='undef'
  135. d_PRIeldbl='undef'
  136. d_PRIfldbl='undef'
  137. d_PRIgldbl='undef'
  138. d_PRIi64='undef'
  139. d_PRIo64='undef'
  140. d_PRIu64='undef'
  141. d_PRIx64='undef'
  142. d_SCNfldbl='undef'
  143. d__fwalk='undef'
  144. d_access='define'
  145. d_accessx='undef'
  146. d_alarm='undef'
  147. d_archlib='define'
  148. d_atolf='undef'
  149. d_atoll='undef'
  150. d_attribut='undef'
  151. d_bcmp='undef'
  152. d_bcopy='undef'
  153. d_bincompat5005='undef'
  154. d_bsd='define'
  155. d_bsdgetpgrp='undef'
  156. d_bsdsetpgrp='undef'
  157. d_bzero='undef'
  158. d_casti32='undef'
  159. d_castneg='define'
  160. d_charvspr='undef'
  161. d_chown='undef'
  162. d_chroot='undef'
  163. d_chsize='define'
  164. d_closedir='define'
  165. d_const='define'
  166. d_crypt='define'
  167. d_csh='undef'
  168. d_cuserid='undef'
  169. d_dbl_dig='define'
  170. d_difftime='define'
  171. d_dirnamlen='define'
  172. d_dlerror='define'
  173. d_dlopen='define'
  174. d_dlsymun='undef'
  175. d_dosuid='undef'
  176. d_drand48proto='undef'
  177. d_dup2='define'
  178. d_eaccess='undef'
  179. d_endgrent='undef'
  180. d_endhent='undef'
  181. d_endnent='undef'
  182. d_endpent='undef'
  183. d_endpwent='undef'
  184. d_endsent='undef'
  185. d_eofnblk='define'
  186. d_eunice='undef'
  187. d_fchmod='undef'
  188. d_fchown='undef'
  189. d_fcntl='undef'
  190. d_fcntl_can_lock='undef'
  191. d_fd_macros='define'
  192. d_fd_set='define'
  193. d_fds_bits='define'
  194. d_fgetpos='define'
  195. d_flexfnam='define'
  196. d_flock='define'
  197. d_fork='undef'
  198. d_fpathconf='undef'
  199. d_fpos64_t='undef'
  200. d_frexpl='undef'
  201. d_fs_data_s='undef'
  202. d_fseeko='undef'
  203. d_fsetpos='define'
  204. d_fstatfs='undef'
  205. d_fstatvfs='undef'
  206. d_fsync='undef'
  207. d_ftello='undef'
  208. d_ftime='define'
  209. d_getcwd='undef'
  210. d_getespwnam='undef'
  211. d_getfsstat='undef'
  212. d_getgrent='undef'
  213. d_getgrps='undef'
  214. d_gethbyaddr='define'
  215. d_gethbyname='define'
  216. d_gethent='undef'
  217. d_gethname='define'
  218. d_gethostprotos='define'
  219. d_getlogin='define'
  220. d_getmnt='undef'
  221. d_getmntent='undef'
  222. d_getnbyaddr='undef'
  223. d_getnbyname='undef'
  224. d_getnent='undef'
  225. d_getnetprotos='undef'
  226. d_getpagsz='undef'
  227. d_getpbyname='define'
  228. d_getpbynumber='define'
  229. d_getpent='undef'
  230. d_getpgid='undef'
  231. d_getpgrp2='undef'
  232. d_getpgrp='undef'
  233. d_getppid='undef'
  234. d_getprior='undef'
  235. d_getprotoprotos='define'
  236. d_getprpwnam='undef'
  237. d_getpwent='undef'
  238. d_getsbyname='define'
  239. d_getsbyport='define'
  240. d_getsent='undef'
  241. d_getservprotos='define'
  242. d_getspnam='undef'
  243. d_gettimeod='undef'
  244. d_gnulibc='undef'
  245. d_grpasswd='undef'
  246. d_hasmntopt='undef'
  247. d_htonl='define'
  248. d_iconv='undef'
  249. d_index='undef'
  250. d_inetaton='undef'
  251. d_int64_t='undef'
  252. d_isascii='define'
  253. d_isnan='define'
  254. d_isnanl='undef'
  255. d_killpg='undef'
  256. d_lchown='undef'
  257. d_ldbl_dig='define'
  258. d_link='define'
  259. d_locconv='define'
  260. d_lockf='undef'
  261. d_longdbl='define'
  262. d_longlong='undef'
  263. d_lseekproto='define'
  264. d_lstat='undef'
  265. d_madvise='undef'
  266. d_mblen='define'
  267. d_mbstowcs='define'
  268. d_mbtowc='define'
  269. d_memchr='define'
  270. d_memcmp='define'
  271. d_memcpy='define'
  272. d_memmove='define'
  273. d_memset='define'
  274. d_mkdir='define'
  275. d_mkdtemp='undef'
  276. d_mkfifo='undef'
  277. d_mkstemp='undef'
  278. d_mkstemps='undef'
  279. d_mktime='define'
  280. d_mmap='undef'
  281. d_modfl='undef'
  282. d_mprotect='undef'
  283. d_msg='undef'
  284. d_msg_ctrunc='undef'
  285. d_msg_dontroute='undef'
  286. d_msg_oob='undef'
  287. d_msg_peek='undef'
  288. d_msg_proxy='undef'
  289. d_msgctl='undef'
  290. d_msgget='undef'
  291. d_msgrcv='undef'
  292. d_msgsnd='undef'
  293. d_msync='undef'
  294. d_munmap='undef'
  295. d_mymalloc='undef'
  296. d_nice='undef'
  297. d_nv_preserves_uv='define'
  298. d_nv_preserves_uv_bits='32'
  299. d_off64_t='undef'
  300. d_old_pthread_create_joinable='undef'
  301. d_oldpthreads='undef'
  302. d_oldsock='undef'
  303. d_open3='undef'
  304. d_pathconf='undef'
  305. d_pause='define'
  306. d_perl_otherlibdirs='undef'
  307. d_phostname='undef'
  308. d_pipe='define'
  309. d_poll='undef'
  310. d_portable='define'
  311. d_pthread_atfork='undef'
  312. d_pthread_yield='undef'
  313. d_pwage='undef'
  314. d_pwchange='undef'
  315. d_pwclass='undef'
  316. d_pwcomment='undef'
  317. d_pwexpire='undef'
  318. d_pwgecos='undef'
  319. d_pwpasswd='undef'
  320. d_pwquota='undef'
  321. d_qgcvt='undef'
  322. d_quad='undef'
  323. d_readdir='define'
  324. d_readlink='undef'
  325. d_rename='define'
  326. d_rewinddir='define'
  327. d_rmdir='define'
  328. d_safebcpy='undef'
  329. d_safemcpy='undef'
  330. d_sanemcmp='define'
  331. d_sbrkproto='undef'
  332. d_sched_yield='undef'
  333. d_scm_rights='undef'
  334. d_seekdir='define'
  335. d_select='define'
  336. d_sem='undef'
  337. d_semctl='undef'
  338. d_semctl_semid_ds='undef'
  339. d_semctl_semun='undef'
  340. d_semget='undef'
  341. d_semop='undef'
  342. d_setegid='undef'
  343. d_seteuid='undef'
  344. d_setgrent='undef'
  345. d_setgrps='undef'
  346. d_sethent='undef'
  347. d_setlinebuf='undef'
  348. d_setlocale='define'
  349. d_setnent='undef'
  350. d_setpent='undef'
  351. d_setpgid='undef'
  352. d_setpgrp2='undef'
  353. d_setpgrp='undef'
  354. d_setprior='undef'
  355. d_setproctitle='undef'
  356. d_setpwent='undef'
  357. d_setregid='undef'
  358. d_setresgid='undef'
  359. d_setresuid='undef'
  360. d_setreuid='undef'
  361. d_setrgid='undef'
  362. d_setruid='undef'
  363. d_setsent='undef'
  364. d_setsid='undef'
  365. d_setvbuf='define'
  366. d_sfio='undef'
  367. d_shm='undef'
  368. d_shmat='undef'
  369. d_shmatprototype='undef'
  370. d_shmctl='undef'
  371. d_shmdt='undef'
  372. d_shmget='undef'
  373. d_sigaction='undef'
  374. d_sigsetjmp='undef'
  375. d_socket='define'
  376. d_socklen_t='undef'
  377. d_sockpair='undef'
  378. d_socks5_init='undef'
  379. d_sqrtl='undef'
  380. d_statblks='undef'
  381. d_statfs_f_flags='undef'
  382. d_statfs_s='undef'
  383. d_statvfs='undef'
  384. d_stdio_cnt_lval='define'
  385. d_stdio_ptr_lval='define'
  386. d_stdio_ptr_lval_nochange_cnt='undef'
  387. d_stdio_ptr_lval_sets_cnt='undef'
  388. d_stdio_stream_array='undef'
  389. d_stdiobase='define'
  390. d_stdstdio='define'
  391. d_strchr='define'
  392. d_strcoll='define'
  393. d_strctcpy='define'
  394. d_strerrm='strerror(e)'
  395. d_strerror='define'
  396. d_strtod='define'
  397. d_strtol='define'
  398. d_strtold='undef'
  399. d_strtoll='undef'
  400. d_strtoul='define'
  401. d_strtoull='undef'
  402. d_strtouq='undef'
  403. d_strxfrm='define'
  404. d_suidsafe='undef'
  405. d_symlink='undef'
  406. d_syscall='undef'
  407. d_sysconf='undef'
  408. d_sysernlst=''
  409. d_syserrlst='define'
  410. d_system='define'
  411. d_tcgetpgrp='undef'
  412. d_tcsetpgrp='undef'
  413. d_telldir='define'
  414. d_telldirproto='define'
  415. d_time='define'
  416. d_times='define'
  417. d_truncate='undef'
  418. d_tzname='define'
  419. d_umask='define'
  420. d_uname='define'
  421. d_union_semun='define'
  422. d_ustat='undef'
  423. d_vendorarch='undef'
  424. d_vendorbin='undef'
  425. d_vendorlib='undef'
  426. d_vfork='undef'
  427. d_void_closedir='undef'
  428. d_voidsig='define'
  429. d_voidtty=''
  430. d_volatile='define'
  431. d_vprintf='define'
  432. d_wait4='undef'
  433. d_waitpid='define'
  434. d_wcstombs='define'
  435. d_wctomb='define'
  436. d_xenix='undef'
  437. date='date'
  438. db_hashtype='int'
  439. db_prefixtype='int'
  440. defvoidused='15'
  441. direntrytype='struct direct'
  442. dlext='dll'
  443. doublesize='8'
  444. drand01='(rand()/(double)((unsigned)1<<RANDBITS))'
  445. eagain='EAGAIN'
  446. ebcdic='undef'
  447. echo='echo'
  448. egrep='egrep'
  449. emacs=''
  450. eunicefix=':'
  451. exe_ext='.exe'
  452. expr='expr'
  453. fflushNULL='define'
  454. fflushall='undef'
  455. find='find'
  456. firstmakefile='makefile'
  457. flex=''
  458. fpossize='4'
  459. fpostype='fpos_t'
  460. freetype='void'
  461. full_ar=''
  462. full_csh=''
  463. full_sed=''
  464. gccosandvers=''
  465. gccversion=''
  466. gidformat='"ld"'
  467. gidsign='-1'
  468. gidsize='4'
  469. gidtype='gid_t'
  470. glibpth='/usr/shlib  /lib/pa1.1 /usr/lib/large /lib /usr/lib /usr/lib/386 /lib/386 /lib/large /usr/lib/small /lib/small /usr/ccs/lib /usr/ucblib /usr/shlib '
  471. grep='grep'
  472. groupcat=''
  473. groupstype='gid_t'
  474. gzip='gzip'
  475. h_fcntl='false'
  476. h_sysfile='true'
  477. hint='recommended'
  478. hostcat='ypcat hosts'
  479. i16size='2'
  480. i16type='short'
  481. i32size='4'
  482. i32type='long'
  483. i64size='8'
  484. i64type='__int64'
  485. i8size='1'
  486. i8type='char'
  487. i_arpainet='define'
  488. i_bsdioctl=''
  489. i_db='undef'
  490. i_dbm='undef'
  491. i_dirent='define'
  492. i_dld='undef'
  493. i_dlfcn='define'
  494. i_fcntl='define'
  495. i_float='define'
  496. i_gdbm='undef'
  497. i_grp='undef'
  498. i_iconv='undef'
  499. i_ieeefp='undef'
  500. i_inttypes='undef'
  501. i_libutil='undef'
  502. i_limits='define'
  503. i_locale='define'
  504. i_machcthr='undef'
  505. i_malloc='define'
  506. i_math='define'
  507. i_memory='undef'
  508. i_mntent='undef'
  509. i_ndbm='undef'
  510. i_netdb='undef'
  511. i_neterrno='undef'
  512. i_netinettcp='undef'
  513. i_niin='undef'
  514. i_poll='undef'
  515. i_prot='undef'
  516. i_pthread='undef'
  517. i_pwd='undef'
  518. i_rpcsvcdbm='define'
  519. i_sfio='undef'
  520. i_sgtty='undef'
  521. i_shadow='undef'
  522. i_socks='undef'
  523. i_stdarg='define'
  524. i_stddef='define'
  525. i_stdlib='define'
  526. i_string='define'
  527. i_sunmath='undef'
  528. i_sysaccess='undef'
  529. i_sysdir='undef'
  530. i_sysfile='undef'
  531. i_sysfilio='define'
  532. i_sysin='undef'
  533. i_sysioctl='undef'
  534. i_syslog='undef'
  535. i_sysmman='undef'
  536. i_sysmode='undef'
  537. i_sysmount='undef'
  538. i_sysndir='undef'
  539. i_sysparam='undef'
  540. i_sysresrc='undef'
  541. i_syssecrt='undef'
  542. i_sysselct='undef'
  543. i_syssockio=''
  544. i_sysstat='define'
  545. i_sysstatfs='undef'
  546. i_sysstatvfs='undef'
  547. i_systime='undef'
  548. i_systimek='undef'
  549. i_systimes='undef'
  550. i_systypes='define'
  551. i_sysuio='undef'
  552. i_sysun='undef'
  553. i_sysutsname='undef'
  554. i_sysvfs='undef'
  555. i_syswait='undef'
  556. i_termio='undef'
  557. i_termios='undef'
  558. i_time='define'
  559. i_unistd='undef'
  560. i_ustat='undef'
  561. i_utime='define'
  562. i_values='undef'
  563. i_varargs='undef'
  564. i_varhdr='varargs.h'
  565. i_vfork='undef'
  566. ignore_versioned_solibs=''
  567. inc_version_list=''
  568. inc_version_list_init='0'
  569. incpath='C:\PROGRA~1\MICROS~3\VC98\include'
  570. inews=''
  571. installbin='C:\p4view\Apps\ActivePerl\MSI\data\ActivePerl\Perl\bin'
  572. installhtmldir='C:\p4view\Apps\ActivePerl\MSI\data\ActivePerl\Perl\html'
  573. installhtmlhelpdir='C:\p4view\Apps\ActivePerl\MSI\data\ActivePerl\Perl\htmlhelp'
  574. installman1dir='C:\p4view\Apps\ActivePerl\MSI\data\ActivePerl\Perl\man\man1'
  575. installman3dir='C:\p4view\Apps\ActivePerl\MSI\data\ActivePerl\Perl\man\man3'
  576. installprefix='C:\p4view\Apps\ActivePerl\MSI\data\ActivePerl\Perl'
  577. installprefixexp='C:\p4view\Apps\ActivePerl\MSI\data\ActivePerl\Perl'
  578. installscript='C:\p4view\Apps\ActivePerl\MSI\data\ActivePerl\Perl\bin'
  579. installsitearch='C:\p4view\Apps\ActivePerl\MSI\data\ActivePerl\Perl\site\lib'
  580. installsitebin='C:\p4view\Apps\ActivePerl\MSI\data\ActivePerl\Perl\bin'
  581. installsitelib='C:\p4view\Apps\ActivePerl\MSI\data\ActivePerl\Perl\site\lib'
  582. installstyle='lib'
  583. installusrbinperl='undef'
  584. installvendorarch=''
  585. installvendorbin=''
  586. installvendorlib=''
  587. intsize='4'
  588. issymlink=''
  589. ivdformat='"ld"'
  590. ivsize='4'
  591. ivtype='long'
  592. known_extensions='DynaLoader Socket IO Fcntl Opcode SDBM_File POSIX attrs Thread B re  Data/Dumper Devel/Peek ByteLoader Devel/DProf File/Glob  Sys/Hostname Errno'
  593. ksh=''
  594. ld='link'
  595. lddlflags='-dll -nologo -nodefaultlib -debug -opt:ref,icf  -libpath:"C:\p4view\Apps\ActivePerl\MSI\data\ActivePerl\Perl\lib\CORE"  -machine:x86'
  596. ldflags='-nologo -nodefaultlib -debug -opt:ref,icf  -libpath:"C:\p4view\Apps\ActivePerl\MSI\data\ActivePerl\Perl\lib\CORE"  -machine:x86'
  597. ldflags_uselargefiles=''
  598. ldlibpthname=''
  599. less='less'
  600. lib_ext='.lib'
  601. libc='msvcrt.lib'
  602. libperl='perl56.lib'
  603. libsdirs=''
  604. libsfiles=''
  605. libsfound=''
  606. libspath=''
  607. libswanted='net socket inet nsl nm ndbm gdbm dbm db malloc dl dld ld sun m c cposix posix ndir dir crypt ucb bsd BSD PW x'
  608. libswanted_uselargefiles=''
  609. line='line'
  610. lint=''
  611. lkflags=''
  612. ln=''
  613. lns='copy'
  614. locincpth='/usr/local/include /opt/local/include /usr/gnu/include /opt/gnu/include /usr/GNU/include /opt/GNU/include'
  615. loclibpth='/usr/local/lib /opt/local/lib /usr/gnu/lib /opt/gnu/lib /usr/GNU/lib /opt/GNU/lib'
  616. longdblsize='10'
  617. longlongsize='8'
  618. longsize='4'
  619. lp=''
  620. lpr=''
  621. ls='dir'
  622. lseeksize='4'
  623. lseektype='off_t'
  624. mail=''
  625. mailx=''
  626. make='nmake'
  627. make_set_make='#'
  628. mallocobj='malloc.o'
  629. mallocsrc='malloc.c'
  630. malloctype='void *'
  631. man1dir='C:\p4view\Apps\ActivePerl\MSI\data\ActivePerl\Perl\man\man1'
  632. man1direxp='C:\p4view\Apps\ActivePerl\MSI\data\ActivePerl\Perl\man\man1'
  633. man1ext='1'
  634. man3dir='C:\p4view\Apps\ActivePerl\MSI\data\ActivePerl\Perl\man\man3'
  635. man3direxp='C:\p4view\Apps\ActivePerl\MSI\data\ActivePerl\Perl\man\man3'
  636. man3ext='3'
  637. mips_type=''
  638. mkdir='mkdir'
  639. mmaptype='void *'
  640. modetype='mode_t'
  641. more='more /e'
  642. multiarch='undef'
  643. mv=''
  644. myarchname='MSWin32'
  645. mydomain=''
  646. myhostname=''
  647. myuname=''
  648. n='-n'
  649. netdb_hlen_type='int'
  650. netdb_host_type='char *'
  651. netdb_name_type='char *'
  652. netdb_net_type='long'
  653. nm=''
  654. nm_opt=''
  655. nm_so_opt=''
  656. nonxs_ext='Errno'
  657. nroff=''
  658. nvEUformat='"E"'
  659. nvFUformat='"F"'
  660. nvGUformat='"G"'
  661. nveformat='"e"'
  662. nvfformat='"f"'
  663. nvgformat='"g"'
  664. nvsize='8'
  665. nvtype='double'
  666. o_nonblock='O_NONBLOCK'
  667. obj_ext='.obj'
  668. old_pthread_create_joinable=''
  669. optimize='-O1 -MD -Zi -DNDEBUG'
  670. orderlib='false'
  671. otherlibdirs=''
  672. package='perl5'
  673. pager='more /e'
  674. passcat=''
  675. patchlevel='6'
  676. path_sep=';'
  677. perl5=''
  678. perl='perl'
  679. perladmin=''
  680. perllibs='  oldnames.lib kernel32.lib user32.lib gdi32.lib winspool.lib  comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib  netapi32.lib uuid.lib wsock32.lib mpr.lib winmm.lib  version.lib odbc32.lib odbccp32.lib msvcrt.lib'
  681. perlpath='C:\p4view\Apps\ActivePerl\MSI\data\ActivePerl\Perl\bin\perl.exe'
  682. pg=''
  683. phostname='hostname'
  684. pidtype='int'
  685. plibpth=''
  686. pm_apiversion='5.005'
  687. pmake=''
  688. pr=''
  689. prefixexp='C:\p4view\Apps\ActivePerl\MSI\data\ActivePerl\Perl'
  690. privlib='C:\p4view\Apps\ActivePerl\MSI\data\ActivePerl\Perl\lib'
  691. prototype='define'
  692. ptrsize='4'
  693. quadkind='5'
  694. quadtype='__int64'
  695. randbits='15'
  696. randfunc='rand'
  697. randseedtype='unsigned'
  698. ranlib='rem'
  699. rd_nodata='-1'
  700. revision='5'
  701. rm='del'
  702. rmail=''
  703. runnm='true'
  704. sPRIEUldbl='"E"'
  705. sPRIFUldbl='"F"'
  706. sPRIGUldbl='"G"'
  707. sPRIXU64='"lX"'
  708. sPRId64='"ld"'
  709. sPRIeldbl='"e"'
  710. sPRIfldbl='"f"'
  711. sPRIgldbl='"g"'
  712. sPRIi64='"li"'
  713. sPRIo64='"lo"'
  714. sPRIu64='"lu"'
  715. sPRIx64='"lx"'
  716. sSCNfldbl='"f"'
  717. sched_yield=''
  718. scriptdir='C:\p4view\Apps\ActivePerl\MSI\data\ActivePerl\Perl\bin'
  719. scriptdirexp='C:\p4view\Apps\ActivePerl\MSI\data\ActivePerl\Perl\bin'
  720. sed='sed'
  721. seedfunc='srand'
  722. selectminbits='32'
  723. selecttype='Perl_fd_set *'
  724. sendmail='blat'
  725. sh='cmd /x /c'
  726. shar=''
  727. shmattype='void *'
  728. shortsize='2'
  729. shrpenv=''
  730. sig_count='26'
  731. sig_name_init='"ZERO", "NUM01", "INT", "QUIT", "ILL", "NUM05", "NUM06", "NUM07", "FPE", "KILL", "NUM10", "SEGV", "NUM12", "PIPE", "ALRM", "TERM", "NUM16", "NUM17", "NUM18", "NUM19", "CHLD", "BREAK", "ABRT", "STOP", "NUM24", "CONT", "CLD", 0'
  732. sig_num_init='0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 20, 0'
  733. signal_t='void'
  734. sitearch='C:\p4view\Apps\ActivePerl\MSI\data\ActivePerl\Perl\site\lib'
  735. sitearchexp='C:\p4view\Apps\ActivePerl\MSI\data\ActivePerl\Perl\site\lib'
  736. sitebin='C:\p4view\Apps\ActivePerl\MSI\data\ActivePerl\Perl\site\bin'
  737. sitebinexp='C:\p4view\Apps\ActivePerl\MSI\data\ActivePerl\Perl\site\bin'
  738. sitelib='C:\p4view\Apps\ActivePerl\MSI\data\ActivePerl\Perl\site\lib'
  739. sitelib_stem=''
  740. sitelibexp='C:\p4view\Apps\ActivePerl\MSI\data\ActivePerl\Perl\site\lib'
  741. siteprefix='C:\p4view\Apps\ActivePerl\MSI\data\ActivePerl\Perl\site'
  742. siteprefixexp='C:\p4view\Apps\ActivePerl\MSI\data\ActivePerl\Perl\site'
  743. sizesize='4'
  744. sizetype='size_t'
  745. sleep=''
  746. smail=''
  747. sockethdr=''
  748. socketlib=''
  749. socksizetype='int'
  750. sort='sort'
  751. spackage='Perl5'
  752. spitshell=''
  753. src=''
  754. ssizetype='int'
  755. startperl='#!perl'
  756. stdchar='char'
  757. stdio_base='((fp)->_base)'
  758. stdio_bufsiz='((fp)->_cnt + (fp)->_ptr - (fp)->_base)'
  759. stdio_cnt='((fp)->_cnt)'
  760. stdio_filbuf=''
  761. stdio_ptr='((fp)->_ptr)'
  762. stdio_stream_array=''
  763. strings='/usr/include/string.h'
  764. submit=''
  765. subversion='1'
  766. sysman='/usr/man/man1'
  767. tail=''
  768. tar=''
  769. tbl=''
  770. tee=''
  771. test=''
  772. timeincl='/usr/include/sys/time.h '
  773. timetype='time_t'
  774. touch='touch'
  775. tr=''
  776. trnl='\012'
  777. troff=''
  778. u16size='2'
  779. u16type='unsigned short'
  780. u32size='4'
  781. u32type='unsigned long'
  782. u64size='8'
  783. u64type='unsigned __int64'
  784. u8size='1'
  785. u8type='unsigned char'
  786. uidformat='"ld"'
  787. uidsign='-1'
  788. uidsize='4'
  789. uidtype='uid_t'
  790. uname='uname'
  791. uniq='uniq'
  792. uquadtype='unsigned __int64'
  793. use5005threads='undef'
  794. use64bitall='undef'
  795. use64bitint='undef'
  796. usedl='define'
  797. useithreads='define'
  798. uselargefiles='undef'
  799. uselongdouble='undef'
  800. usemorebits='undef'
  801. usemultiplicity='define'
  802. usemymalloc='n'
  803. usenm='false'
  804. useopcode='true'
  805. useperlio='undef'
  806. useposix='true'
  807. usesfio='false'
  808. useshrplib='yes'
  809. usesocks='undef'
  810. usethreads='undef'
  811. usevendorprefix='undef'
  812. usevfork='false'
  813. usrinc='/usr/include'
  814. uuname=''
  815. uvXUformat='"lX"'
  816. uvoformat='"lo"'
  817. uvsize='4'
  818. uvtype='unsigned long'
  819. uvuformat='"lu"'
  820. uvxformat='"lx"'
  821. vendorarch=''
  822. vendorarchexp=''
  823. vendorbin=''
  824. vendorbinexp=''
  825. vendorlib=''
  826. vendorlib_stem=''
  827. vendorlibexp=''
  828. vendorprefix=''
  829. vendorprefixexp=''
  830. version='5.6.1'
  831. versiononly='undef'
  832. vi=''
  833. voidflags='15'
  834. xlibpth='/usr/lib/386 /lib/386'
  835. xs_apiversion='5.6.0'
  836. zcat=''
  837. zip='zip'
  838. !END!
  839.  
  840. my $summary = <<'!END!';
  841. Summary of my $package (revision $baserev version $PERL_VERSION subversion $PERL_SUBVERSION) configuration:
  842.   Platform:
  843.     osname=$osname, osvers=$osvers, archname=$archname
  844.     uname='$myuname'
  845.     config_args='$config_args'
  846.     hint=$hint, useposix=$useposix, d_sigaction=$d_sigaction
  847.     usethreads=$usethreads use5005threads=$use5005threads useithreads=$useithreads usemultiplicity=$usemultiplicity
  848.     useperlio=$useperlio d_sfio=$d_sfio uselargefiles=$uselargefiles usesocks=$usesocks
  849.     use64bitint=$use64bitint use64bitall=$use64bitall uselongdouble=$uselongdouble
  850.   Compiler:
  851.     cc='$cc', ccflags ='$ccflags',
  852.     optimize='$optimize',
  853.     cppflags='$cppflags'
  854.     ccversion='$ccversion', gccversion='$gccversion', gccosandvers='$gccosandvers'
  855.     intsize=$intsize, longsize=$longsize, ptrsize=$ptrsize, doublesize=$doublesize, byteorder=$byteorder
  856.     d_longlong=$d_longlong, longlongsize=$longlongsize, d_longdbl=$d_longdbl, longdblsize=$longdblsize
  857.     ivtype='$ivtype', ivsize=$ivsize, nvtype='$nvtype', nvsize=$nvsize, Off_t='$lseektype', lseeksize=$lseeksize
  858.     alignbytes=$alignbytes, usemymalloc=$usemymalloc, prototype=$prototype
  859.   Linker and Libraries:
  860.     ld='$ld', ldflags ='$ldflags'
  861.     libpth=$libpth
  862.     libs=$libs
  863.     perllibs=$perllibs
  864.     libc=$libc, so=$so, useshrplib=$useshrplib, libperl=$libperl
  865.   Dynamic Linking:
  866.     dlsrc=$dlsrc, dlext=$dlext, d_dlsymun=$d_dlsymun, ccdlflags='$ccdlflags'
  867.     cccdlflags='$cccdlflags', lddlflags='$lddlflags'
  868.  
  869. !END!
  870. my $summary_expanded = 0;
  871.  
  872. sub myconfig {
  873.     return $summary if $summary_expanded;
  874.     $summary =~ s{\$(\w+)}
  875.              { my $c = $Config{$1}; defined($c) ? $c : 'undef' }ge;
  876.     $summary_expanded = 1;
  877.     $summary;
  878. }
  879.  
  880. sub FETCH { 
  881.     # check for cached value (which may be undef so we use exists not defined)
  882.     return $_[0]->{$_[1]} if (exists $_[0]->{$_[1]});
  883.  
  884.     # Search for it in the big string 
  885.     my($value, $start, $marker, $quote_type);
  886.  
  887.     $quote_type = "'";
  888.     # Virtual entries.
  889.     if ($_[1] eq 'byteorder') {
  890.     # byteorder does exist on its own but we overlay a virtual
  891.     # dynamically recomputed value. 
  892.         my $t = $Config{ivtype};
  893.         my $s = $Config{ivsize};
  894.         my $f = $t eq 'long' ? 'L!' : $s == 8 ? 'Q': 'I';
  895.         if ($s == 4 || $s == 8) {
  896.         my $i = 0;
  897.             foreach my $c (reverse(2..$s)) { $i |= ord($c); $i <<= 8 }
  898.         $i |= ord(1);
  899.             $value = join('', unpack('a'x$s, pack($f, $i)));
  900.         } else {
  901.             $value = '?'x$s;
  902.         }
  903.     } elsif ($_[1] =~ /^((?:cc|ld)flags|libs(?:wanted)?)_nolargefiles/) {
  904.     # These are purely virtual, they do not exist, but need to
  905.     # be computed on demand for largefile-incapable extensions.
  906.     my $key = "${1}_uselargefiles";
  907.     $value = $Config{$1};
  908.     my $withlargefiles = $Config{$key};
  909.     if ($key =~ /^(?:cc|ld)flags_/) {
  910.         $value =~ s/\Q$withlargefiles\E\b//;
  911.     } elsif ($key =~ /^libs/) {
  912.         my @lflibswanted = split(' ', $Config{libswanted_uselargefiles});
  913.         if (@lflibswanted) {
  914.         my %lflibswanted;
  915.         @lflibswanted{@lflibswanted} = ();
  916.         if ($key =~ /^libs_/) {
  917.             my @libs = grep { /^-l(.+)/ &&
  918.                                       not exists $lflibswanted{$1} }
  919.                             split(' ', $Config{libs});
  920.             $Config{libs} = join(' ', @libs);
  921.         } elsif ($key =~ /^libswanted_/) {
  922.             my @libswanted = grep { not exists $lflibswanted{$_} }
  923.                                   split(' ', $Config{libswanted});
  924.             $Config{libswanted} = join(' ', @libswanted);
  925.         }
  926.         }
  927.     }
  928.     } else {
  929.     $marker = "$_[1]=";
  930.     # return undef unless (($value) = $config_sh =~ m/^$_[1]='(.*)'\s*$/m);
  931.     # Check for the common case, ' delimeted
  932.     $start = index($config_sh, "\n$marker$quote_type");
  933.     # If that failed, check for " delimited
  934.     if ($start == -1) {
  935.         $quote_type = '"';
  936.         $start = index($config_sh, "\n$marker$quote_type");
  937.     }
  938.     return undef if ( ($start == -1) &&  # in case it's first 
  939.               (substr($config_sh, 0, length($marker)) ne $marker) );
  940.     if ($start == -1) { 
  941.         # It's the very first thing we found. Skip $start forward
  942.         # and figure out the quote mark after the =.
  943.         $start = length($marker) + 1;
  944.         $quote_type = substr($config_sh, $start - 1, 1);
  945.     } 
  946.     else { 
  947.         $start += length($marker) + 2;
  948.     }
  949.     $value = substr($config_sh, $start, 
  950.             index($config_sh, "$quote_type\n", $start) - $start);
  951.     }
  952.     # If we had a double-quote, we'd better eval it so escape
  953.     # sequences and such can be interpolated. Since the incoming
  954.     # value is supposed to follow shell rules and not perl rules,
  955.     # we escape any perl variable markers
  956.     if ($quote_type eq '"') {
  957.     $value =~ s/\$/\\\$/g;
  958.     $value =~ s/\@/\\\@/g;
  959.     eval "\$value = \"$value\"";
  960.     }
  961.     #$value = sprintf($value) if $quote_type eq '"';
  962.     # So we can say "if $Config{'foo'}".
  963.     $value = undef if $value eq 'undef';
  964.     $_[0]->{$_[1]} = $value; # cache it
  965.     return $value;
  966. }
  967.  
  968. my $prevpos = 0;
  969.  
  970. sub FIRSTKEY {
  971.     $prevpos = 0;
  972.     # my($key) = $config_sh =~ m/^(.*?)=/;
  973.     substr($config_sh, 0, index($config_sh, '=') );
  974.     # $key;
  975. }
  976.  
  977. sub NEXTKEY {
  978.     # Find out how the current key's quoted so we can skip to its end.
  979.     my $quote = substr($config_sh, index($config_sh, "=", $prevpos)+1, 1);
  980.     my $pos = index($config_sh, qq($quote\n), $prevpos) + 2;
  981.     my $len = index($config_sh, "=", $pos) - $pos;
  982.     $prevpos = $pos;
  983.     $len > 0 ? substr($config_sh, $pos, $len) : undef;
  984. }
  985.  
  986. sub EXISTS { 
  987.     # exists($_[0]->{$_[1]})  or  $config_sh =~ m/^$_[1]=/m;
  988.     exists($_[0]->{$_[1]}) or
  989.     index($config_sh, "\n$_[1]='") != -1 or
  990.     substr($config_sh, 0, length($_[1])+2) eq "$_[1]='" or
  991.     index($config_sh, "\n$_[1]=\"") != -1 or
  992.     substr($config_sh, 0, length($_[1])+2) eq "$_[1]=\"" or
  993.     $_[1] =~ /^(?:(?:cc|ld)flags|libs(?:wanted)?)_nolargefiles$/;
  994. }
  995.  
  996. sub STORE  { die "\%Config::Config is read-only\n" }
  997. sub DELETE { &STORE }
  998. sub CLEAR  { &STORE }
  999.  
  1000.  
  1001. sub config_sh {
  1002.     $config_sh
  1003. }
  1004.  
  1005. sub config_re {
  1006.     my $re = shift;
  1007.     my @matches = ($config_sh =~ /^$re=.*\n/mg);
  1008.     @matches ? (print @matches) : print "$re: not found\n";
  1009. }
  1010.  
  1011. sub config_vars {
  1012.     foreach(@_){
  1013.     config_re($_), next if /\W/;
  1014.     my $v=(exists $Config{$_}) ? $Config{$_} : 'UNKNOWN';
  1015.     $v='undef' unless defined $v;
  1016.     print "$_='$v';\n";
  1017.     }
  1018. }
  1019.  
  1020. sub TIEHASH { bless {} }
  1021.  
  1022. # avoid Config..Exporter..UNIVERSAL search for DESTROY then AUTOLOAD
  1023. sub DESTROY { }
  1024.  
  1025. tie %Config, 'Config';
  1026.  
  1027. 1;
  1028. __END__
  1029.  
  1030. =head1 NAME
  1031.  
  1032. Config - access Perl configuration information
  1033.  
  1034. =head1 SYNOPSIS
  1035.  
  1036.     use Config;
  1037.     if ($Config{'cc'} =~ /gcc/) {
  1038.     print "built by gcc\n";
  1039.     } 
  1040.  
  1041.     use Config qw(myconfig config_sh config_vars);
  1042.  
  1043.     print myconfig();
  1044.  
  1045.     print config_sh();
  1046.  
  1047.     config_vars(qw(osname archname));
  1048.  
  1049.  
  1050. =head1 DESCRIPTION
  1051.  
  1052. The Config module contains all the information that was available to
  1053. the C<Configure> program at Perl build time (over 900 values).
  1054.  
  1055. Shell variables from the F<config.sh> file (written by Configure) are
  1056. stored in the readonly-variable C<%Config>, indexed by their names.
  1057.  
  1058. Values stored in config.sh as 'undef' are returned as undefined
  1059. values.  The perl C<exists> function can be used to check if a
  1060. named variable exists.
  1061.  
  1062. =over 4
  1063.  
  1064. =item myconfig()
  1065.  
  1066. Returns a textual summary of the major perl configuration values.
  1067. See also C<-V> in L<perlrun/Switches>.
  1068.  
  1069. =item config_sh()
  1070.  
  1071. Returns the entire perl configuration information in the form of the
  1072. original config.sh shell variable assignment script.
  1073.  
  1074. =item config_vars(@names)
  1075.  
  1076. Prints to STDOUT the values of the named configuration variable. Each is
  1077. printed on a separate line in the form:
  1078.  
  1079.   name='value';
  1080.  
  1081. Names which are unknown are output as C<name='UNKNOWN';>.
  1082. See also C<-V:name> in L<perlrun/Switches>.
  1083.  
  1084. =back
  1085.  
  1086. =head1 EXAMPLE
  1087.  
  1088. Here's a more sophisticated example of using %Config:
  1089.  
  1090.     use Config;
  1091.     use strict;
  1092.  
  1093.     my %sig_num;
  1094.     my @sig_name;
  1095.     unless($Config{sig_name} && $Config{sig_num}) {
  1096.     die "No sigs?";
  1097.     } else {
  1098.     my @names = split ' ', $Config{sig_name};
  1099.     @sig_num{@names} = split ' ', $Config{sig_num};
  1100.     foreach (@names) {
  1101.         $sig_name[$sig_num{$_}] ||= $_;
  1102.     }   
  1103.     }
  1104.  
  1105.     print "signal #17 = $sig_name[17]\n";
  1106.     if ($sig_num{ALRM}) { 
  1107.     print "SIGALRM is $sig_num{ALRM}\n";
  1108.     }   
  1109.  
  1110. =head1 WARNING
  1111.  
  1112. Because this information is not stored within the perl executable
  1113. itself it is possible (but unlikely) that the information does not
  1114. relate to the actual perl binary which is being used to access it.
  1115.  
  1116. The Config module is installed into the architecture and version
  1117. specific library directory ($Config{installarchlib}) and it checks the
  1118. perl version number when loaded.
  1119.  
  1120. The values stored in config.sh may be either single-quoted or
  1121. double-quoted. Double-quoted strings are handy for those cases where you
  1122. need to include escape sequences in the strings. To avoid runtime variable
  1123. interpolation, any C<$> and C<@> characters are replaced by C<\$> and
  1124. C<\@>, respectively. This isn't foolproof, of course, so don't embed C<\$>
  1125. or C<\@> in double-quoted strings unless you're willing to deal with the
  1126. consequences. (The slashes will end up escaped and the C<$> or C<@> will
  1127. trigger variable interpolation)
  1128.  
  1129. =head1 GLOSSARY
  1130.  
  1131. Most C<Config> variables are determined by the C<Configure> script
  1132. on platforms supported by it (which is most UNIX platforms).  Some
  1133. platforms have custom-made C<Config> variables, and may thus not have
  1134. some of the variables described below, or may have extraneous variables
  1135. specific to that particular port.  See the port specific documentation
  1136. in such cases.
  1137.  
  1138. =head2 _
  1139.  
  1140. =over
  1141.  
  1142. =item C<_a>
  1143.  
  1144. From F<Unix.U>:
  1145.  
  1146. This variable defines the extension used for ordinary libraries.
  1147. For unix, it is F<.a>.  The F<.> is included.  Other possible
  1148. values include F<.lib>.
  1149.  
  1150. =item C<_exe>
  1151.  
  1152. From F<Unix.U>:
  1153.  
  1154. This variable defines the extension used for executable files.
  1155. For unix it is empty.  Other possible values include F<.exe>.
  1156.  
  1157. =item C<_o>
  1158.  
  1159. From F<Unix.U>:
  1160.  
  1161. This variable defines the extension used for object files.
  1162. For unix, it is F<.o>.  The F<.> is included.  Other possible
  1163. values include F<.obj>.
  1164.  
  1165. =back
  1166.  
  1167. =head2 a
  1168.  
  1169. =over
  1170.  
  1171. =item C<afs>
  1172.  
  1173. From F<afs.U>:
  1174.  
  1175. This variable is set to C<true> if C<AFS> (Andrew File System) is used
  1176. on the system, C<false> otherwise.  It is possible to override this
  1177. with a hint value or command line option, but you'd better know
  1178. what you are doing.
  1179.  
  1180. =item C<alignbytes>
  1181.  
  1182. From F<alignbytes.U>:
  1183.  
  1184. This variable holds the number of bytes required to align a
  1185. double-- or a long double when applicable. Usual values are
  1186. 2, 4 and 8.  The default is eight, for safety.
  1187.  
  1188. =item C<ansi2knr>
  1189.  
  1190. From F<ansi2knr.U>:
  1191.  
  1192. This variable is set if the user needs to run ansi2knr.  
  1193. Currently, this is not supported, so we just abort.
  1194.  
  1195. =item C<aphostname>
  1196.  
  1197. From F<d_gethname.U>:
  1198.  
  1199. This variable contains the command which can be used to compute the
  1200. host name. The command is fully qualified by its absolute path, to make
  1201. it safe when used by a process with super-user privileges.
  1202.  
  1203. =item C<api_revision>
  1204.  
  1205. From F<patchlevel.U>:
  1206.  
  1207. The three variables, api_revision, api_version, and
  1208. api_subversion, specify the version of the oldest perl binary
  1209. compatible with the present perl.  In a full version string
  1210. such as F<5.6.1>, api_revision is the C<5>.
  1211. Prior to 5.5.640, the format was a floating point number,
  1212. like 5.00563.
  1213.  
  1214.     F<perl.c>:incpush() and F<lib/lib.pm> will automatically search in
  1215.  
  1216.     $F<sitelib/.>. for older directories back to the limit specified
  1217. by these api_ variables.  This is only useful if you have a
  1218. perl library directory tree structured like the default one.
  1219. See C<INSTALL> for how this works.  The versioned site_perl
  1220. directory was introduced in 5.005, so that is the lowest
  1221. possible value.  The version list appropriate for the current
  1222. system is determined in F<inc_version_list.U>.
  1223.  
  1224.     C<XXX> To do:  Since compatibility can depend on compile time
  1225.  
  1226.     options (such as bincompat, longlong, F<etc.>) it should
  1227. (perhaps) be set by Configure, but currently it isn't.
  1228. Currently, we read a hard-wired value from F<patchlevel.h>.
  1229. Perhaps what we ought to do is take the hard-wired value from
  1230. F<patchlevel.h> but then modify it if the current Configure
  1231. options warrant.  F<patchlevel.h> then would use an #ifdef guard.
  1232.  
  1233. =item C<api_subversion>
  1234.  
  1235. From F<patchlevel.U>:
  1236.  
  1237. The three variables, api_revision, api_version, and
  1238. api_subversion, specify the version of the oldest perl binary
  1239. compatible with the present perl.  In a full version string
  1240. such as F<5.6.1>, api_subversion is the C<1>.  See api_revision for
  1241. full details.
  1242.  
  1243. =item C<api_version>
  1244.  
  1245. From F<patchlevel.U>:
  1246.  
  1247. The three variables, api_revision, api_version, and
  1248. api_subversion, specify the version of the oldest perl binary
  1249. compatible with the present perl.  In a full version string
  1250. such as F<5.6.1>, api_version is the C<6>.  See api_revision for
  1251. full details.  As a special case, 5.5.0 is rendered in the
  1252. old-style as 5.005.  (In the 5.005_0x maintenance series,
  1253. this was the only versioned directory in $F<sitelib.>)
  1254.  
  1255. =item C<api_versionstring>
  1256.  
  1257. From F<patchlevel.U>:
  1258.  
  1259. This variable combines api_revision, api_version, and
  1260. api_subversion in a format such as 5.6.1 (or 5_6_1) suitable
  1261. for use as a directory name.  This is filesystem dependent.
  1262.  
  1263. =item C<ar>
  1264.  
  1265. From F<Loc.U>:
  1266.  
  1267. This variable is used internally by Configure to determine the
  1268. full pathname (if any) of the ar program.  After Configure runs,
  1269. the value is reset to a plain C<ar> and is not useful.
  1270.  
  1271. =item C<archlib>
  1272.  
  1273. From F<archlib.U>:
  1274.  
  1275. This variable holds the name of the directory in which the user wants
  1276. to put architecture-dependent public library files for $package.
  1277. It is most often a local directory such as F</usr/local/lib>.
  1278. Programs using this variable must be prepared to deal
  1279. with filename expansion.
  1280.  
  1281. =item C<archlibexp>
  1282.  
  1283. From F<archlib.U>:
  1284.  
  1285. This variable is the same as the archlib variable, but is
  1286. filename expanded at configuration time, for convenient use.
  1287.  
  1288. =item C<archname64>
  1289.  
  1290. From F<use64bits.U>:
  1291.  
  1292. This variable is used for the 64-bitness part of $archname.
  1293.  
  1294. =item C<archname>
  1295.  
  1296. From F<archname.U>:
  1297.  
  1298. This variable is a short name to characterize the current
  1299. architecture.  It is used mainly to construct the default archlib.
  1300.  
  1301. =item C<archobjs>
  1302.  
  1303. From F<Unix.U>:
  1304.  
  1305. This variable defines any additional objects that must be linked
  1306. in with the program on this architecture.  On unix, it is usually
  1307. empty.  It is typically used to include emulations of unix calls
  1308. or other facilities.  For perl on F<OS/2>, for example, this would
  1309. include F<os2/os2.obj>.
  1310.  
  1311. =item C<awk>
  1312.  
  1313. From F<Loc.U>:
  1314.  
  1315. This variable is used internally by Configure to determine the
  1316. full pathname (if any) of the awk program.  After Configure runs,
  1317. the value is reset to a plain C<awk> and is not useful.
  1318.  
  1319. =back
  1320.  
  1321. =head2 b
  1322.  
  1323. =over
  1324.  
  1325. =item C<baserev>
  1326.  
  1327. From F<baserev.U>:
  1328.  
  1329. The base revision level of this package, from the F<.package> file.
  1330.  
  1331. =item C<bash>
  1332.  
  1333. From F<Loc.U>:
  1334.  
  1335. This variable is defined but not used by Configure.
  1336. The value is a plain '' and is not useful.
  1337.  
  1338. =item C<bin>
  1339.  
  1340. From F<bin.U>:
  1341.  
  1342. This variable holds the name of the directory in which the user wants
  1343. to put publicly executable images for the package in question.  It
  1344. is most often a local directory such as F</usr/local/bin>. Programs using
  1345. this variable must be prepared to deal with F<~name> substitution.
  1346.  
  1347. =item C<bincompat5005>
  1348.  
  1349. From F<bincompat5005.U>:
  1350.  
  1351. This variable contains y if this version of Perl should be
  1352. binary-compatible with Perl 5.005.
  1353.  
  1354. =item C<binexp>
  1355.  
  1356. From F<bin.U>:
  1357.  
  1358. This is the same as the bin variable, but is filename expanded at
  1359. configuration time, for use in your makefiles.
  1360.  
  1361. =item C<bison>
  1362.  
  1363. From F<Loc.U>:
  1364.  
  1365. This variable is defined but not used by Configure.
  1366. The value is a plain '' and is not useful.
  1367.  
  1368. =item C<byacc>
  1369.  
  1370. From F<Loc.U>:
  1371.  
  1372. This variable is used internally by Configure to determine the
  1373. full pathname (if any) of the byacc program.  After Configure runs,
  1374. the value is reset to a plain C<byacc> and is not useful.
  1375.  
  1376. =item C<byteorder>
  1377.  
  1378. From F<byteorder.U>:
  1379.  
  1380. This variable holds the byte order. In the following, larger digits
  1381. indicate more significance.  The variable byteorder is either 4321
  1382. on a big-endian machine, or 1234 on a little-endian, or 87654321
  1383. on a Cray ... or 3412 with weird order !
  1384.  
  1385. =back
  1386.  
  1387. =head2 c
  1388.  
  1389. =over
  1390.  
  1391. =item C<c>
  1392.  
  1393. From F<n.U>:
  1394.  
  1395. This variable contains the \c string if that is what causes the echo
  1396. command to suppress newline.  Otherwise it is null.  Correct usage is
  1397. $echo $n "prompt for a question: $c".
  1398.  
  1399. =item C<castflags>
  1400.  
  1401. From F<d_castneg.U>:
  1402.  
  1403. This variable contains a flag that precise difficulties the
  1404. compiler has casting odd floating values to unsigned long:
  1405. 0 = ok
  1406. 1 = couldn't cast < 0
  1407. 2 = couldn't cast >= 0x80000000
  1408. 4 = couldn't cast in argument expression list
  1409.  
  1410. =item C<cat>
  1411.  
  1412. From F<Loc.U>:
  1413.  
  1414. This variable is used internally by Configure to determine the
  1415. full pathname (if any) of the cat program.  After Configure runs,
  1416. the value is reset to a plain C<cat> and is not useful.
  1417.  
  1418. =item C<cc>
  1419.  
  1420. From F<cc.U>:
  1421.  
  1422. This variable holds the name of a command to execute a C compiler which
  1423. can resolve multiple global references that happen to have the same
  1424. name.  Usual values are C<cc> and C<gcc>.
  1425. Fervent C<ANSI> compilers may be called C<c89>.  C<AIX> has xlc.
  1426.  
  1427. =item C<cccdlflags>
  1428.  
  1429. From F<dlsrc.U>:
  1430.  
  1431. This variable contains any special flags that might need to be
  1432. passed with C<cc -c> to compile modules to be used to create a shared
  1433. library that will be used for dynamic loading.  For hpux, this
  1434. should be +z.  It is up to the makefile to use it.
  1435.  
  1436. =item C<ccdlflags>
  1437.  
  1438. From F<dlsrc.U>:
  1439.  
  1440. This variable contains any special flags that might need to be
  1441. passed to cc to link with a shared library for dynamic loading.
  1442. It is up to the makefile to use it.  For sunos 4.1, it should
  1443. be empty.
  1444.  
  1445. =item C<ccflags>
  1446.  
  1447. From F<ccflags.U>:
  1448.  
  1449. This variable contains any additional C compiler flags desired by
  1450. the user.  It is up to the Makefile to use this.
  1451.  
  1452. =item C<ccflags_uselargefiles>
  1453.  
  1454. From F<uselfs.U>:
  1455.  
  1456. This variable contains the compiler flags needed by large file builds
  1457. and added to ccflags by hints files.
  1458.  
  1459. =item C<ccname>
  1460.  
  1461. From F<Checkcc.U>:
  1462.  
  1463. This can set either by hints files or by Configure.  If using
  1464. gcc, this is gcc, and if not, usually equal to cc, unimpressive, no?
  1465. Some platforms, however, make good use of this by storing the
  1466. flavor of the C compiler being used here.  For example if using
  1467. the Sun WorkShop suite, ccname will be C<workshop>.
  1468.  
  1469. =item C<ccsymbols>
  1470.  
  1471. From F<Cppsym.U>:
  1472.  
  1473. The variable contains the symbols defined by the C compiler alone.
  1474. The symbols defined by cpp or by cc when it calls cpp are not in
  1475. this list, see cppsymbols and cppccsymbols.
  1476. The list is a space-separated list of symbol=value tokens.
  1477.  
  1478. =item C<ccversion>
  1479.  
  1480. From F<Checkcc.U>:
  1481.  
  1482. This can set either by hints files or by Configure.  If using
  1483. a (non-gcc) vendor cc, this variable may contain a version for
  1484. the compiler.
  1485.  
  1486. =item C<cf_by>
  1487.  
  1488. From F<cf_who.U>:
  1489.  
  1490. Login name of the person who ran the Configure script and answered the
  1491. questions. This is used to tag both F<config.sh> and F<config_h.SH>.
  1492.  
  1493. =item C<cf_email>
  1494.  
  1495. From F<cf_email.U>:
  1496.  
  1497. Electronic mail address of the person who ran Configure. This can be
  1498. used by units that require the user's e-mail, like F<MailList.U>.
  1499.  
  1500. =item C<cf_time>
  1501.  
  1502. From F<cf_who.U>:
  1503.  
  1504. Holds the output of the C<date> command when the configuration file was
  1505. produced. This is used to tag both F<config.sh> and F<config_h.SH>.
  1506.  
  1507. =item C<charsize>
  1508.  
  1509. From F<charsize.U>:
  1510.  
  1511. This variable contains the value of the C<CHARSIZE> symbol, which
  1512. indicates to the C program how many bytes there are in a character.
  1513.  
  1514. =item C<chgrp>
  1515.  
  1516. From F<Loc.U>:
  1517.  
  1518. This variable is defined but not used by Configure.
  1519. The value is a plain '' and is not useful.
  1520.  
  1521. =item C<chmod>
  1522.  
  1523. From F<Loc.U>:
  1524.  
  1525. This variable is defined but not used by Configure.
  1526. The value is a plain '' and is not useful.
  1527.  
  1528. =item C<chown>
  1529.  
  1530. From F<Loc.U>:
  1531.  
  1532. This variable is defined but not used by Configure.
  1533. The value is a plain '' and is not useful.
  1534.  
  1535. =item C<clocktype>
  1536.  
  1537. From F<d_times.U>:
  1538.  
  1539. This variable holds the type returned by times(). It can be long,
  1540. or clock_t on C<BSD> sites (in which case <sys/types.h> should be
  1541. included).
  1542.  
  1543. =item C<comm>
  1544.  
  1545. From F<Loc.U>:
  1546.  
  1547. This variable is used internally by Configure to determine the
  1548. full pathname (if any) of the comm program.  After Configure runs,
  1549. the value is reset to a plain C<comm> and is not useful.
  1550.  
  1551. =item C<compress>
  1552.  
  1553. From F<Loc.U>:
  1554.  
  1555. This variable is defined but not used by Configure.
  1556. The value is a plain '' and is not useful.
  1557.  
  1558. =back
  1559.  
  1560. =head2 C
  1561.  
  1562. =over
  1563.  
  1564. =item C<CONFIGDOTSH>
  1565.  
  1566. From F<Oldsyms.U>:
  1567.  
  1568. This is set to C<true> in F<config.sh> so that a shell script
  1569. sourcing F<config.sh> can tell if it has been sourced already.
  1570.  
  1571. =item C<contains>
  1572.  
  1573. From F<contains.U>:
  1574.  
  1575. This variable holds the command to do a grep with a proper return
  1576. status.  On most sane systems it is simply C<grep>.  On insane systems
  1577. it is a grep followed by a cat followed by a test.  This variable
  1578. is primarily for the use of other Configure units.
  1579.  
  1580. =item C<cp>
  1581.  
  1582. From F<Loc.U>:
  1583.  
  1584. This variable is used internally by Configure to determine the
  1585. full pathname (if any) of the cp program.  After Configure runs,
  1586. the value is reset to a plain C<cp> and is not useful.
  1587.  
  1588. =item C<cpio>
  1589.  
  1590. From F<Loc.U>:
  1591.  
  1592. This variable is defined but not used by Configure.
  1593. The value is a plain '' and is not useful.
  1594.  
  1595. =item C<cpp>
  1596.  
  1597. From F<Loc.U>:
  1598.  
  1599. This variable is used internally by Configure to determine the
  1600. full pathname (if any) of the cpp program.  After Configure runs,
  1601. the value is reset to a plain C<cpp> and is not useful.
  1602.  
  1603. =item C<cpp_stuff>
  1604.  
  1605. From F<cpp_stuff.U>:
  1606.  
  1607. This variable contains an identification of the catenation mechanism
  1608. used by the C preprocessor.
  1609.  
  1610. =item C<cppccsymbols>
  1611.  
  1612. From F<Cppsym.U>:
  1613.  
  1614. The variable contains the symbols defined by the C compiler
  1615. when it calls cpp.  The symbols defined by the cc alone or cpp
  1616. alone are not in this list, see ccsymbols and cppsymbols.
  1617. The list is a space-separated list of symbol=value tokens.
  1618.  
  1619. =item C<cppflags>
  1620.  
  1621. From F<ccflags.U>:
  1622.  
  1623. This variable holds the flags that will be passed to the C pre-
  1624. processor. It is up to the Makefile to use it.
  1625.  
  1626. =item C<cpplast>
  1627.  
  1628. From F<cppstdin.U>:
  1629.  
  1630. This variable has the same functionality as cppminus, only it applies
  1631. to cpprun and not cppstdin.
  1632.  
  1633. =item C<cppminus>
  1634.  
  1635. From F<cppstdin.U>:
  1636.  
  1637. This variable contains the second part of the string which will invoke
  1638. the C preprocessor on the standard input and produce to standard
  1639. output.  This variable will have the value C<-> if cppstdin needs
  1640. a minus to specify standard input, otherwise the value is "".
  1641.  
  1642. =item C<cpprun>
  1643.  
  1644. From F<cppstdin.U>:
  1645.  
  1646. This variable contains the command which will invoke a C preprocessor
  1647. on standard input and put the output to stdout. It is guaranteed not
  1648. to be a wrapper and may be a null string if no preprocessor can be
  1649. made directly available. This preprocessor might be different from the
  1650. one used by the C compiler. Don't forget to append cpplast after the
  1651. preprocessor options.
  1652.  
  1653. =item C<cppstdin>
  1654.  
  1655. From F<cppstdin.U>:
  1656.  
  1657. This variable contains the command which will invoke the C
  1658. preprocessor on standard input and put the output to stdout.
  1659. It is primarily used by other Configure units that ask about
  1660. preprocessor symbols.
  1661.  
  1662. =item C<cppsymbols>
  1663.  
  1664. From F<Cppsym.U>:
  1665.  
  1666. The variable contains the symbols defined by the C preprocessor
  1667. alone.  The symbols defined by cc or by cc when it calls cpp are
  1668. not in this list, see ccsymbols and cppccsymbols.
  1669. The list is a space-separated list of symbol=value tokens.
  1670.  
  1671. =item C<crosscompile>
  1672.  
  1673. From F<crosscompile.U>:
  1674.  
  1675. This variable conditionally defines the C<CROSSCOMPILE> symbol
  1676. which signifies that the build process is be a cross-compilation.
  1677. This is normally set by hints files or from Configure command line.
  1678.  
  1679. =item C<cryptlib>
  1680.  
  1681. From F<d_crypt.U>:
  1682.  
  1683. This variable holds -lcrypt or the path to a F<libcrypt.a> archive if
  1684. the crypt() function is not defined in the standard C library. It is
  1685. up to the Makefile to use this.
  1686.  
  1687. =item C<csh>
  1688.  
  1689. From F<Loc.U>:
  1690.  
  1691. This variable is used internally by Configure to determine the
  1692. full pathname (if any) of the csh program.  After Configure runs,
  1693. the value is reset to a plain C<csh> and is not useful.
  1694.  
  1695. =back
  1696.  
  1697. =head2 d
  1698.  
  1699. =over
  1700.  
  1701. =item C<d__fwalk>
  1702.  
  1703. From F<d__fwalk.U>:
  1704.  
  1705. This variable conditionally defines C<HAS__FWALK> if _fwalk() is
  1706. available to apply a function to all the file handles.
  1707.  
  1708. =item C<d_access>
  1709.  
  1710. From F<d_access.U>:
  1711.  
  1712. This variable conditionally defines C<HAS_ACCESS> if the access() system
  1713. call is available to check for access permissions using real IDs.
  1714.  
  1715. =item C<d_accessx>
  1716.  
  1717. From F<d_accessx.U>:
  1718.  
  1719. This variable conditionally defines the C<HAS_ACCESSX> symbol, which
  1720. indicates to the C program that the accessx() routine is available.
  1721.  
  1722. =item C<d_alarm>
  1723.  
  1724. From F<d_alarm.U>:
  1725.  
  1726. This variable conditionally defines the C<HAS_ALARM> symbol, which
  1727. indicates to the C program that the alarm() routine is available.
  1728.  
  1729. =item C<d_archlib>
  1730.  
  1731. From F<archlib.U>:
  1732.  
  1733. This variable conditionally defines C<ARCHLIB> to hold the pathname
  1734. of architecture-dependent library files for $package.  If
  1735. $archlib is the same as $privlib, then this is set to undef.
  1736.  
  1737. =item C<d_atolf>
  1738.  
  1739. From F<atolf.U>:
  1740.  
  1741. This variable conditionally defines the C<HAS_ATOLF> symbol, which
  1742. indicates to the C program that the atolf() routine is available.
  1743.  
  1744. =item C<d_atoll>
  1745.  
  1746. From F<atoll.U>:
  1747.  
  1748. This variable conditionally defines the C<HAS_ATOLL> symbol, which
  1749. indicates to the C program that the atoll() routine is available.
  1750.  
  1751. =item C<d_attribut>
  1752.  
  1753. From F<d_attribut.U>:
  1754.  
  1755. This variable conditionally defines C<HASATTRIBUTE>, which
  1756. indicates the C compiler can check for function attributes,
  1757. such as printf formats.
  1758.  
  1759. =item C<d_bcmp>
  1760.  
  1761. From F<d_bcmp.U>:
  1762.  
  1763. This variable conditionally defines the C<HAS_BCMP> symbol if
  1764. the bcmp() routine is available to compare strings.
  1765.  
  1766. =item C<d_bcopy>
  1767.  
  1768. From F<d_bcopy.U>:
  1769.  
  1770. This variable conditionally defines the C<HAS_BCOPY> symbol if
  1771. the bcopy() routine is available to copy strings.
  1772.  
  1773. =item C<d_bincompat5005>
  1774.  
  1775. From F<bincompat5005.U>:
  1776.  
  1777. This variable conditionally defines BINCOMPAT5005 so that F<embed.h>
  1778. can take special action if this version of Perl should be
  1779. binary-compatible with Perl 5.005.  This is impossible for builds
  1780. that use features like threads and multiplicity it is always $undef
  1781. for those versions.
  1782.  
  1783. =item C<d_bsd>
  1784.  
  1785. From F<Guess.U>:
  1786.  
  1787. This symbol conditionally defines the symbol C<BSD> when running on a
  1788. C<BSD> system.
  1789.  
  1790. =item C<d_bsdgetpgrp>
  1791.  
  1792. From F<d_getpgrp.U>:
  1793.  
  1794. This variable conditionally defines C<USE_BSD_GETPGRP> if
  1795. getpgrp needs one arguments whereas C<USG> one needs none.
  1796.  
  1797. =item C<d_bsdsetpgrp>
  1798.  
  1799. From F<d_setpgrp.U>:
  1800.  
  1801. This variable conditionally defines C<USE_BSD_SETPGRP> if
  1802. setpgrp needs two arguments whereas C<USG> one needs none.
  1803. See also d_setpgid for a C<POSIX> interface.
  1804.  
  1805. =item C<d_bzero>
  1806.  
  1807. From F<d_bzero.U>:
  1808.  
  1809. This variable conditionally defines the C<HAS_BZERO> symbol if
  1810. the bzero() routine is available to set memory to 0.
  1811.  
  1812. =item C<d_casti32>
  1813.  
  1814. From F<d_casti32.U>:
  1815.  
  1816. This variable conditionally defines CASTI32, which indicates
  1817. whether the C compiler can cast large floats to 32-bit ints.
  1818.  
  1819. =item C<d_castneg>
  1820.  
  1821. From F<d_castneg.U>:
  1822.  
  1823. This variable conditionally defines C<CASTNEG>, which indicates
  1824. wether the C compiler can cast negative float to unsigned.
  1825.  
  1826. =item C<d_charvspr>
  1827.  
  1828. From F<d_vprintf.U>:
  1829.  
  1830. This variable conditionally defines C<CHARVSPRINTF> if this system
  1831. has vsprintf returning type (char*).  The trend seems to be to
  1832. declare it as "int vsprintf()".
  1833.  
  1834. =item C<d_chown>
  1835.  
  1836. From F<d_chown.U>:
  1837.  
  1838. This variable conditionally defines the C<HAS_CHOWN> symbol, which
  1839. indicates to the C program that the chown() routine is available.
  1840.  
  1841. =item C<d_chroot>
  1842.  
  1843. From F<d_chroot.U>:
  1844.  
  1845. This variable conditionally defines the C<HAS_CHROOT> symbol, which
  1846. indicates to the C program that the chroot() routine is available.
  1847.  
  1848. =item C<d_chsize>
  1849.  
  1850. From F<d_chsize.U>:
  1851.  
  1852. This variable conditionally defines the C<CHSIZE> symbol, which
  1853. indicates to the C program that the chsize() routine is available
  1854. to truncate files.  You might need a -lx to get this routine.
  1855.  
  1856. =item C<d_closedir>
  1857.  
  1858. From F<d_closedir.U>:
  1859.  
  1860. This variable conditionally defines C<HAS_CLOSEDIR> if closedir() is
  1861. available.
  1862.  
  1863. =item C<d_const>
  1864.  
  1865. From F<d_const.U>:
  1866.  
  1867. This variable conditionally defines the C<HASCONST> symbol, which
  1868. indicates to the C program that this C compiler knows about the
  1869. const type.
  1870.  
  1871. =item C<d_crypt>
  1872.  
  1873. From F<d_crypt.U>:
  1874.  
  1875. This variable conditionally defines the C<CRYPT> symbol, which
  1876. indicates to the C program that the crypt() routine is available
  1877. to encrypt passwords and the like.
  1878.  
  1879. =item C<d_csh>
  1880.  
  1881. From F<d_csh.U>:
  1882.  
  1883. This variable conditionally defines the C<CSH> symbol, which
  1884. indicates to the C program that the C-shell exists.
  1885.  
  1886. =item C<d_cuserid>
  1887.  
  1888. From F<d_cuserid.U>:
  1889.  
  1890. This variable conditionally defines the C<HAS_CUSERID> symbol, which
  1891. indicates to the C program that the cuserid() routine is available
  1892. to get character login names.
  1893.  
  1894. =item C<d_dbl_dig>
  1895.  
  1896. From F<d_dbl_dig.U>:
  1897.  
  1898. This variable conditionally defines d_dbl_dig if this system's
  1899. header files provide C<DBL_DIG>, which is the number of significant
  1900. digits in a double precision number.
  1901.  
  1902. =item C<d_difftime>
  1903.  
  1904. From F<d_difftime.U>:
  1905.  
  1906. This variable conditionally defines the C<HAS_DIFFTIME> symbol, which
  1907. indicates to the C program that the difftime() routine is available.
  1908.  
  1909. =item C<d_dirnamlen>
  1910.  
  1911. From F<i_dirent.U>:
  1912.  
  1913. This variable conditionally defines C<DIRNAMLEN>, which indicates
  1914. to the C program that the length of directory entry names is
  1915. provided by a d_namelen field.
  1916.  
  1917. =item C<d_dlerror>
  1918.  
  1919. From F<d_dlerror.U>:
  1920.  
  1921. This variable conditionally defines the C<HAS_DLERROR> symbol, which
  1922. indicates to the C program that the dlerror() routine is available.
  1923.  
  1924. =item C<d_dlopen>
  1925.  
  1926. From F<d_dlopen.U>:
  1927.  
  1928. This variable conditionally defines the C<HAS_DLOPEN> symbol, which
  1929. indicates to the C program that the dlopen() routine is available.
  1930.  
  1931. =item C<d_dlsymun>
  1932.  
  1933. From F<d_dlsymun.U>:
  1934.  
  1935. This variable conditionally defines C<DLSYM_NEEDS_UNDERSCORE>, which
  1936. indicates that we need to prepend an underscore to the symbol
  1937. name before calling dlsym().
  1938.  
  1939. =item C<d_dosuid>
  1940.  
  1941. From F<d_dosuid.U>:
  1942.  
  1943. This variable conditionally defines the symbol C<DOSUID>, which
  1944. tells the C program that it should insert setuid emulation code
  1945. on hosts which have setuid #! scripts disabled.
  1946.  
  1947. =item C<d_drand48proto>
  1948.  
  1949. From F<d_drand48proto.U>:
  1950.  
  1951. This variable conditionally defines the HAS_DRAND48_PROTO symbol,
  1952. which indicates to the C program that the system provides
  1953. a prototype for the drand48() function.  Otherwise, it is
  1954. up to the program to supply one.
  1955.  
  1956. =item C<d_dup2>
  1957.  
  1958. From F<d_dup2.U>:
  1959.  
  1960. This variable conditionally defines HAS_DUP2 if dup2() is
  1961. available to duplicate file descriptors.
  1962.  
  1963. =item C<d_eaccess>
  1964.  
  1965. From F<d_eaccess.U>:
  1966.  
  1967. This variable conditionally defines the C<HAS_EACCESS> symbol, which
  1968. indicates to the C program that the eaccess() routine is available.
  1969.  
  1970. =item C<d_endgrent>
  1971.  
  1972. From F<d_endgrent.U>:
  1973.  
  1974. This variable conditionally defines the C<HAS_ENDGRENT> symbol, which
  1975. indicates to the C program that the endgrent() routine is available
  1976. for sequential access of the group database.
  1977.  
  1978. =item C<d_endhent>
  1979.  
  1980. From F<d_endhent.U>:
  1981.  
  1982. This variable conditionally defines C<HAS_ENDHOSTENT> if endhostent() is
  1983. available to close whatever was being used for host queries.
  1984.  
  1985. =item C<d_endnent>
  1986.  
  1987. From F<d_endnent.U>:
  1988.  
  1989. This variable conditionally defines C<HAS_ENDNETENT> if endnetent() is
  1990. available to close whatever was being used for network queries.
  1991.  
  1992. =item C<d_endpent>
  1993.  
  1994. From F<d_endpent.U>:
  1995.  
  1996. This variable conditionally defines C<HAS_ENDPROTOENT> if endprotoent() is
  1997. available to close whatever was being used for protocol queries.
  1998.  
  1999. =item C<d_endpwent>
  2000.  
  2001. From F<d_endpwent.U>:
  2002.  
  2003. This variable conditionally defines the C<HAS_ENDPWENT> symbol, which
  2004. indicates to the C program that the endpwent() routine is available
  2005. for sequential access of the passwd database.
  2006.  
  2007. =item C<d_endsent>
  2008.  
  2009. From F<d_endsent.U>:
  2010.  
  2011. This variable conditionally defines C<HAS_ENDSERVENT> if endservent() is
  2012. available to close whatever was being used for service queries.
  2013.  
  2014. =item C<d_eofnblk>
  2015.  
  2016. From F<nblock_io.U>:
  2017.  
  2018. This variable conditionally defines C<EOF_NONBLOCK> if C<EOF> can be seen
  2019. when reading from a non-blocking F<I/O> source.
  2020.  
  2021. =item C<d_eunice>
  2022.  
  2023. From F<Guess.U>:
  2024.  
  2025. This variable conditionally defines the symbols C<EUNICE> and C<VAX>, which
  2026. alerts the C program that it must deal with ideosyncracies of C<VMS>.
  2027.  
  2028. =item C<d_fchmod>
  2029.  
  2030. From F<d_fchmod.U>:
  2031.  
  2032. This variable conditionally defines the C<HAS_FCHMOD> symbol, which
  2033. indicates to the C program that the fchmod() routine is available
  2034. to change mode of opened files.
  2035.  
  2036. =item C<d_fchown>
  2037.  
  2038. From F<d_fchown.U>:
  2039.  
  2040. This variable conditionally defines the C<HAS_FCHOWN> symbol, which
  2041. indicates to the C program that the fchown() routine is available
  2042. to change ownership of opened files.
  2043.  
  2044. =item C<d_fcntl>
  2045.  
  2046. From F<d_fcntl.U>:
  2047.  
  2048. This variable conditionally defines the C<HAS_FCNTL> symbol, and indicates
  2049. whether the fcntl() function exists
  2050.  
  2051. =item C<d_fcntl_can_lock>
  2052.  
  2053. From F<d_fcntl_can_lock.U>:
  2054.  
  2055. This variable conditionally defines the C<FCNTL_CAN_LOCK> symbol
  2056. and indicates whether file locking with fcntl() works.
  2057.  
  2058. =item C<d_fd_macros>
  2059.  
  2060. From F<d_fd_set.U>:
  2061.  
  2062. This variable contains the eventual value of the C<HAS_FD_MACROS> symbol,
  2063. which indicates if your C compiler knows about the macros which
  2064. manipulate an fd_set.
  2065.  
  2066. =item C<d_fd_set>
  2067.  
  2068. From F<d_fd_set.U>:
  2069.  
  2070. This variable contains the eventual value of the C<HAS_FD_SET> symbol,
  2071. which indicates if your C compiler knows about the fd_set typedef.
  2072.  
  2073. =item C<d_fds_bits>
  2074.  
  2075. From F<d_fd_set.U>:
  2076.  
  2077. This variable contains the eventual value of the C<HAS_FDS_BITS> symbol,
  2078. which indicates if your fd_set typedef contains the fds_bits member.
  2079. If you have an fd_set typedef, but the dweebs who installed it did
  2080. a half-fast job and neglected to provide the macros to manipulate
  2081. an fd_set, C<HAS_FDS_BITS> will let us know how to fix the gaffe.
  2082.  
  2083. =item C<d_fgetpos>
  2084.  
  2085. From F<d_fgetpos.U>:
  2086.  
  2087. This variable conditionally defines C<HAS_FGETPOS> if fgetpos() is
  2088. available to get the file position indicator.
  2089.  
  2090. =item C<d_flexfnam>
  2091.  
  2092. From F<d_flexfnam.U>:
  2093.  
  2094. This variable conditionally defines the C<FLEXFILENAMES> symbol, which
  2095. indicates that the system supports filenames longer than 14 characters.
  2096.  
  2097. =item C<d_flock>
  2098.  
  2099. From F<d_flock.U>:
  2100.  
  2101. This variable conditionally defines C<HAS_FLOCK> if flock() is
  2102. available to do file locking.
  2103.  
  2104. =item C<d_fork>
  2105.  
  2106. From F<d_fork.U>:
  2107.  
  2108. This variable conditionally defines the C<HAS_FORK> symbol, which
  2109. indicates to the C program that the fork() routine is available.
  2110.  
  2111. =item C<d_fpathconf>
  2112.  
  2113. From F<d_pathconf.U>:
  2114.  
  2115. This variable conditionally defines the C<HAS_FPATHCONF> symbol, which
  2116. indicates to the C program that the pathconf() routine is available
  2117. to determine file-system related limits and options associated
  2118. with a given open file descriptor.
  2119.  
  2120. =item C<d_fpos64_t>
  2121.  
  2122. From F<d_fpos64_t.U>:
  2123.  
  2124. This symbol will be defined if the C compiler supports fpos64_t.
  2125.  
  2126. =item C<d_frexpl>
  2127.  
  2128. From F<d_frexpl.U>:
  2129.  
  2130. This variable conditionally defines the C<HAS_FREXPL> symbol, which
  2131. indicates to the C program that the frexpl() routine is available.
  2132.  
  2133. =item C<d_fs_data_s>
  2134.  
  2135. From F<d_fs_data_s.U>:
  2136.  
  2137. This variable conditionally defines the C<HAS_STRUCT_FS_DATA> symbol,
  2138. which indicates that the struct fs_data is supported.
  2139.  
  2140. =item C<d_fseeko>
  2141.  
  2142. From F<d_fseeko.U>:
  2143.  
  2144. This variable conditionally defines the C<HAS_FSEEKO> symbol, which
  2145. indicates to the C program that the fseeko() routine is available.
  2146.  
  2147. =item C<d_fsetpos>
  2148.  
  2149. From F<d_fsetpos.U>:
  2150.  
  2151. This variable conditionally defines C<HAS_FSETPOS> if fsetpos() is
  2152. available to set the file position indicator.
  2153.  
  2154. =item C<d_fstatfs>
  2155.  
  2156. From F<d_fstatfs.U>:
  2157.  
  2158. This variable conditionally defines the C<HAS_FSTATFS> symbol, which
  2159. indicates to the C program that the fstatfs() routine is available.
  2160.  
  2161. =item C<d_fstatvfs>
  2162.  
  2163. From F<d_statvfs.U>:
  2164.  
  2165. This variable conditionally defines the C<HAS_FSTATVFS> symbol, which
  2166. indicates to the C program that the fstatvfs() routine is available.
  2167.  
  2168. =item C<d_fsync>
  2169.  
  2170. From F<d_fsync.U>:
  2171.  
  2172. This variable conditionally defines the C<HAS_FSYNC> symbol, which
  2173. indicates to the C program that the fsync() routine is available.
  2174.  
  2175. =item C<d_ftello>
  2176.  
  2177. From F<d_ftello.U>:
  2178.  
  2179. This variable conditionally defines the C<HAS_FTELLO> symbol, which
  2180. indicates to the C program that the ftello() routine is available.
  2181.  
  2182. =item C<d_ftime>
  2183.  
  2184. From F<d_ftime.U>:
  2185.  
  2186. This variable conditionally defines the C<HAS_FTIME> symbol, which indicates
  2187. that the ftime() routine exists.  The ftime() routine is basically
  2188. a sub-second accuracy clock.
  2189.  
  2190. =item C<d_Gconvert>
  2191.  
  2192. From F<d_gconvert.U>:
  2193.  
  2194. This variable holds what Gconvert is defined as to convert
  2195. floating point numbers into strings. It could be C<gconvert>
  2196. or a more C<complex> macro emulating gconvert with gcvt() or sprintf.
  2197. Possible values are:
  2198. d_Gconvert=C<gconvert((x),(n),(t),(b))>
  2199. d_Gconvert=C<gcvt((x),(n),(b))>
  2200. d_Gconvert=C<sprintf((b),F<%F<.>*g>,(n),(x))>
  2201.  
  2202. =item C<d_getcwd>
  2203.  
  2204. From F<d_getcwd.U>:
  2205.  
  2206. This variable conditionally defines the C<HAS_GETCWD> symbol, which
  2207. indicates to the C program that the getcwd() routine is available
  2208. to get the current working directory.
  2209.  
  2210. =item C<d_getespwnam>
  2211.  
  2212. From F<d_getespwnam.U>:
  2213.  
  2214. This variable conditionally defines C<HAS_GETESPWNAM> if getespwnam() is
  2215. available to retrieve enchanced (shadow) password entries by name.
  2216.  
  2217. =item C<d_getfsstat>
  2218.  
  2219. From F<d_getfsstat.U>:
  2220.  
  2221. This variable conditionally defines the C<HAS_GETFSSTAT> symbol, which
  2222. indicates to the C program that the getfsstat() routine is available.
  2223.  
  2224. =item C<d_getgrent>
  2225.  
  2226. From F<d_getgrent.U>:
  2227.  
  2228. This variable conditionally defines the C<HAS_GETGRENT> symbol, which
  2229. indicates to the C program that the getgrent() routine is available
  2230. for sequential access of the group database.
  2231.  
  2232. =item C<d_getgrps>
  2233.  
  2234. From F<d_getgrps.U>:
  2235.  
  2236. This variable conditionally defines the C<HAS_GETGROUPS> symbol, which
  2237. indicates to the C program that the getgroups() routine is available
  2238. to get the list of process groups.
  2239.  
  2240. =item C<d_gethbyaddr>
  2241.  
  2242. From F<d_gethbyad.U>:
  2243.  
  2244. This variable conditionally defines the C<HAS_GETHOSTBYADDR> symbol, which
  2245. indicates to the C program that the gethostbyaddr() routine is available
  2246. to look up hosts by their C<IP> addresses.
  2247.  
  2248. =item C<d_gethbyname>
  2249.  
  2250. From F<d_gethbynm.U>:
  2251.  
  2252. This variable conditionally defines the C<HAS_GETHOSTBYNAME> symbol, which
  2253. indicates to the C program that the gethostbyname() routine is available
  2254. to look up host names in some data base or other.
  2255.  
  2256. =item C<d_gethent>
  2257.  
  2258. From F<d_gethent.U>:
  2259.  
  2260. This variable conditionally defines C<HAS_GETHOSTENT> if gethostent() is
  2261. available to look up host names in some data base or another.
  2262.  
  2263. =item C<d_gethname>
  2264.  
  2265. From F<d_gethname.U>:
  2266.  
  2267. This variable conditionally defines the C<HAS_GETHOSTNAME> symbol, which
  2268. indicates to the C program that the gethostname() routine may be
  2269. used to derive the host name.
  2270.  
  2271. =item C<d_gethostprotos>
  2272.  
  2273. From F<d_gethostprotos.U>:
  2274.  
  2275. This variable conditionally defines the C<HAS_GETHOST_PROTOS> symbol,
  2276. which indicates to the C program that <netdb.h> supplies
  2277. prototypes for the various gethost*() functions.  
  2278. See also F<netdbtype.U> for probing for various netdb types.
  2279.  
  2280. =item C<d_getlogin>
  2281.  
  2282. From F<d_getlogin.U>:
  2283.  
  2284. This variable conditionally defines the C<HAS_GETLOGIN> symbol, which
  2285. indicates to the C program that the getlogin() routine is available
  2286. to get the login name.
  2287.  
  2288. =item C<d_getmnt>
  2289.  
  2290. From F<d_getmnt.U>:
  2291.  
  2292. This variable conditionally defines the C<HAS_GETMNT> symbol, which
  2293. indicates to the C program that the getmnt() routine is available
  2294. to retrieve one or more mount info blocks by filename.
  2295.  
  2296. =item C<d_getmntent>
  2297.  
  2298. From F<d_getmntent.U>:
  2299.  
  2300. This variable conditionally defines the C<HAS_GETMNTENT> symbol, which
  2301. indicates to the C program that the getmntent() routine is available
  2302. to iterate through mounted files to get their mount info.
  2303.  
  2304. =item C<d_getnbyaddr>
  2305.  
  2306. From F<d_getnbyad.U>:
  2307.  
  2308. This variable conditionally defines the C<HAS_GETNETBYADDR> symbol, which
  2309. indicates to the C program that the getnetbyaddr() routine is available
  2310. to look up networks by their C<IP> addresses.
  2311.  
  2312. =item C<d_getnbyname>
  2313.  
  2314. From F<d_getnbynm.U>:
  2315.  
  2316. This variable conditionally defines the C<HAS_GETNETBYNAME> symbol, which
  2317. indicates to the C program that the getnetbyname() routine is available
  2318. to look up networks by their names.
  2319.  
  2320. =item C<d_getnent>
  2321.  
  2322. From F<d_getnent.U>:
  2323.  
  2324. This variable conditionally defines C<HAS_GETNETENT> if getnetent() is
  2325. available to look up network names in some data base or another.
  2326.  
  2327. =item C<d_getnetprotos>
  2328.  
  2329. From F<d_getnetprotos.U>:
  2330.  
  2331. This variable conditionally defines the C<HAS_GETNET_PROTOS> symbol,
  2332. which indicates to the C program that <netdb.h> supplies
  2333. prototypes for the various getnet*() functions.  
  2334. See also F<netdbtype.U> for probing for various netdb types.
  2335.  
  2336. =item C<d_getpagsz>
  2337.  
  2338. From F<d_getpagsz.U>:
  2339.  
  2340. This variable conditionally defines C<HAS_GETPAGESIZE> if getpagesize()
  2341. is available to get the system page size.
  2342.  
  2343. =item C<d_getpbyname>
  2344.  
  2345. From F<d_getprotby.U>:
  2346.  
  2347. This variable conditionally defines the C<HAS_GETPROTOBYNAME> 
  2348. symbol, which indicates to the C program that the 
  2349. getprotobyname() routine is available to look up protocols
  2350. by their name.
  2351.  
  2352. =item C<d_getpbynumber>
  2353.  
  2354. From F<d_getprotby.U>:
  2355.  
  2356. This variable conditionally defines the C<HAS_GETPROTOBYNUMBER> 
  2357. symbol, which indicates to the C program that the 
  2358. getprotobynumber() routine is available to look up protocols
  2359. by their number.
  2360.  
  2361. =item C<d_getpent>
  2362.  
  2363. From F<d_getpent.U>:
  2364.  
  2365. This variable conditionally defines C<HAS_GETPROTOENT> if getprotoent() is
  2366. available to look up protocols in some data base or another.
  2367.  
  2368. =item C<d_getpgid>
  2369.  
  2370. From F<d_getpgid.U>:
  2371.  
  2372. This variable conditionally defines the C<HAS_GETPGID> symbol, which
  2373. indicates to the C program that the getpgid(pid) function
  2374. is available to get the process group id.
  2375.  
  2376. =item C<d_getpgrp2>
  2377.  
  2378. From F<d_getpgrp2.U>:
  2379.  
  2380. This variable conditionally defines the HAS_GETPGRP2 symbol, which
  2381. indicates to the C program that the getpgrp2() (as in F<DG/C<UX>>) routine
  2382. is available to get the current process group.
  2383.  
  2384. =item C<d_getpgrp>
  2385.  
  2386. From F<d_getpgrp.U>:
  2387.  
  2388. This variable conditionally defines C<HAS_GETPGRP> if getpgrp() is
  2389. available to get the current process group.
  2390.  
  2391. =item C<d_getppid>
  2392.  
  2393. From F<d_getppid.U>:
  2394.  
  2395. This variable conditionally defines the C<HAS_GETPPID> symbol, which
  2396. indicates to the C program that the getppid() routine is available
  2397. to get the parent process C<ID>.
  2398.  
  2399. =item C<d_getprior>
  2400.  
  2401. From F<d_getprior.U>:
  2402.  
  2403. This variable conditionally defines C<HAS_GETPRIORITY> if getpriority()
  2404. is available to get a process's priority.
  2405.  
  2406. =item C<d_getprotoprotos>
  2407.  
  2408. From F<d_getprotoprotos.U>:
  2409.  
  2410. This variable conditionally defines the C<HAS_GETPROTO_PROTOS> symbol,
  2411. which indicates to the C program that <netdb.h> supplies
  2412. prototypes for the various getproto*() functions.  
  2413. See also F<netdbtype.U> for probing for various netdb types.
  2414.  
  2415. =item C<d_getprpwnam>
  2416.  
  2417. From F<d_getprpwnam.U>:
  2418.  
  2419. This variable conditionally defines C<HAS_GETPRPWNAM> if getprpwnam() is
  2420. available to retrieve protected (shadow) password entries by name.
  2421.  
  2422. =item C<d_getpwent>
  2423.  
  2424. From F<d_getpwent.U>:
  2425.  
  2426. This variable conditionally defines the C<HAS_GETPWENT> symbol, which
  2427. indicates to the C program that the getpwent() routine is available
  2428. for sequential access of the passwd database.
  2429.  
  2430. =item C<d_getsbyname>
  2431.  
  2432. From F<d_getsrvby.U>:
  2433.  
  2434. This variable conditionally defines the C<HAS_GETSERVBYNAME> 
  2435. symbol, which indicates to the C program that the 
  2436. getservbyname() routine is available to look up services
  2437. by their name.
  2438.  
  2439. =item C<d_getsbyport>
  2440.  
  2441. From F<d_getsrvby.U>:
  2442.  
  2443. This variable conditionally defines the C<HAS_GETSERVBYPORT> 
  2444. symbol, which indicates to the C program that the 
  2445. getservbyport() routine is available to look up services
  2446. by their port.
  2447.  
  2448. =item C<d_getsent>
  2449.  
  2450. From F<d_getsent.U>:
  2451.  
  2452. This variable conditionally defines C<HAS_GETSERVENT> if getservent() is
  2453. available to look up network services in some data base or another.
  2454.  
  2455. =item C<d_getservprotos>
  2456.  
  2457. From F<d_getservprotos.U>:
  2458.  
  2459. This variable conditionally defines the C<HAS_GETSERV_PROTOS> symbol,
  2460. which indicates to the C program that <netdb.h> supplies
  2461. prototypes for the various getserv*() functions.  
  2462. See also F<netdbtype.U> for probing for various netdb types.
  2463.  
  2464. =item C<d_getspnam>
  2465.  
  2466. From F<d_getspnam.U>:
  2467.  
  2468. This variable conditionally defines C<HAS_GETSPNAM> if getspnam() is
  2469. available to retrieve SysV shadow password entries by name.
  2470.  
  2471. =item C<d_gettimeod>
  2472.  
  2473. From F<d_ftime.U>:
  2474.  
  2475. This variable conditionally defines the C<HAS_GETTIMEOFDAY> symbol, which
  2476. indicates that the gettimeofday() system call exists (to obtain a
  2477. sub-second accuracy clock). You should probably include <sys/resource.h>.
  2478.  
  2479. =item C<d_gnulibc>
  2480.  
  2481. From F<d_gnulibc.U>:
  2482.  
  2483. Defined if we're dealing with the C<GNU> C Library.
  2484.  
  2485. =item C<d_grpasswd>
  2486.  
  2487. From F<i_grp.U>:
  2488.  
  2489. This variable conditionally defines C<GRPASSWD>, which indicates
  2490. that struct group in <grp.h> contains gr_passwd.
  2491.  
  2492. =item C<d_hasmntopt>
  2493.  
  2494. From F<d_hasmntopt.U>:
  2495.  
  2496. This variable conditionally defines the C<HAS_HASMNTOPT> symbol, which
  2497. indicates to the C program that the hasmntopt() routine is available
  2498. to query the mount options of file systems.
  2499.  
  2500. =item C<d_htonl>
  2501.  
  2502. From F<d_htonl.U>:
  2503.  
  2504. This variable conditionally defines C<HAS_HTONL> if htonl() and its
  2505. friends are available to do network order byte swapping.
  2506.  
  2507. =item C<d_iconv>
  2508.  
  2509. From F<d_iconv.U>:
  2510.  
  2511. This variable conditionally defines the C<HAS_ICONV> symbol, which
  2512. indicates to the C program that the iconv() routine is available.
  2513.  
  2514. =item C<d_index>
  2515.  
  2516. From F<d_strchr.U>:
  2517.  
  2518. This variable conditionally defines C<HAS_INDEX> if index() and
  2519. rindex() are available for string searching.
  2520.  
  2521. =item C<d_inetaton>
  2522.  
  2523. From F<d_inetaton.U>:
  2524.  
  2525. This variable conditionally defines the C<HAS_INET_ATON> symbol, which
  2526. indicates to the C program that the inet_aton() function is available
  2527. to parse C<IP> address C<dotted-quad> strings.
  2528.  
  2529. =item C<d_int64_t>
  2530.  
  2531. From F<d_int64_t.U>:
  2532.  
  2533. This symbol will be defined if the C compiler supports int64_t.
  2534.  
  2535. =item C<d_isascii>
  2536.  
  2537. From F<d_isascii.U>:
  2538.  
  2539. This variable conditionally defines the C<HAS_ISASCII> constant,
  2540. which indicates to the C program that isascii() is available.
  2541.  
  2542. =item C<d_isnan>
  2543.  
  2544. From F<d_isnan.U>:
  2545.  
  2546. This variable conditionally defines the C<HAS_ISNAN> symbol, which
  2547. indicates to the C program that the isnan() routine is available.
  2548.  
  2549. =item C<d_isnanl>
  2550.  
  2551. From F<d_isnanl.U>:
  2552.  
  2553. This variable conditionally defines the C<HAS_ISNANL> symbol, which
  2554. indicates to the C program that the isnanl() routine is available.
  2555.  
  2556. =item C<d_killpg>
  2557.  
  2558. From F<d_killpg.U>:
  2559.  
  2560. This variable conditionally defines the C<HAS_KILLPG> symbol, which
  2561. indicates to the C program that the killpg() routine is available
  2562. to kill process groups.
  2563.  
  2564. =item C<d_lchown>
  2565.  
  2566. From F<d_lchown.U>:
  2567.  
  2568. This variable conditionally defines the C<HAS_LCHOWN> symbol, which
  2569. indicates to the C program that the lchown() routine is available
  2570. to operate on a symbolic link (instead of following the link).
  2571.  
  2572. =item C<d_ldbl_dig>
  2573.  
  2574. From F<d_ldbl_dig.U>:
  2575.  
  2576. This variable conditionally defines d_ldbl_dig if this system's
  2577. header files provide C<LDBL_DIG>, which is the number of significant
  2578. digits in a long double precision number.
  2579.  
  2580. =item C<d_link>
  2581.  
  2582. From F<d_link.U>:
  2583.  
  2584. This variable conditionally defines C<HAS_LINK> if link() is
  2585. available to create hard links.
  2586.  
  2587. =item C<d_locconv>
  2588.  
  2589. From F<d_locconv.U>:
  2590.  
  2591. This variable conditionally defines C<HAS_LOCALECONV> if localeconv() is
  2592. available for numeric and monetary formatting conventions.
  2593.  
  2594. =item C<d_lockf>
  2595.  
  2596. From F<d_lockf.U>:
  2597.  
  2598. This variable conditionally defines C<HAS_LOCKF> if lockf() is
  2599. available to do file locking.
  2600.  
  2601. =item C<d_longdbl>
  2602.  
  2603. From F<d_longdbl.U>:
  2604.  
  2605. This variable conditionally defines C<HAS_LONG_DOUBLE> if 
  2606. the long double type is supported.
  2607.  
  2608. =item C<d_longlong>
  2609.  
  2610. From F<d_longlong.U>:
  2611.  
  2612. This variable conditionally defines C<HAS_LONG_LONG> if 
  2613. the long long type is supported.
  2614.  
  2615. =item C<d_lseekproto>
  2616.  
  2617. From F<d_lseekproto.U>:
  2618.  
  2619. This variable conditionally defines the C<HAS_LSEEK_PROTO> symbol,
  2620. which indicates to the C program that the system provides
  2621. a prototype for the lseek() function.  Otherwise, it is
  2622. up to the program to supply one.
  2623.  
  2624. =item C<d_lstat>
  2625.  
  2626. From F<d_lstat.U>:
  2627.  
  2628. This variable conditionally defines C<HAS_LSTAT> if lstat() is
  2629. available to do file stats on symbolic links.
  2630.  
  2631. =item C<d_madvise>
  2632.  
  2633. From F<d_madvise.U>:
  2634.  
  2635. This variable conditionally defines C<HAS_MADVISE> if madvise() is
  2636. available to map a file into memory.
  2637.  
  2638. =item C<d_mblen>
  2639.  
  2640. From F<d_mblen.U>:
  2641.  
  2642. This variable conditionally defines the C<HAS_MBLEN> symbol, which
  2643. indicates to the C program that the mblen() routine is available
  2644. to find the number of bytes in a multibye character.
  2645.  
  2646. =item C<d_mbstowcs>
  2647.  
  2648. From F<d_mbstowcs.U>:
  2649.  
  2650. This variable conditionally defines the C<HAS_MBSTOWCS> symbol, which
  2651. indicates to the C program that the mbstowcs() routine is available
  2652. to convert a multibyte string into a wide character string.
  2653.  
  2654. =item C<d_mbtowc>
  2655.  
  2656. From F<d_mbtowc.U>:
  2657.  
  2658. This variable conditionally defines the C<HAS_MBTOWC> symbol, which
  2659. indicates to the C program that the mbtowc() routine is available
  2660. to convert multibyte to a wide character.
  2661.  
  2662. =item C<d_memchr>
  2663.  
  2664. From F<d_memchr.U>:
  2665.  
  2666. This variable conditionally defines the C<HAS_MEMCHR> symbol, which
  2667. indicates to the C program that the memchr() routine is available
  2668. to locate characters within a C string.
  2669.  
  2670. =item C<d_memcmp>
  2671.  
  2672. From F<d_memcmp.U>:
  2673.  
  2674. This variable conditionally defines the C<HAS_MEMCMP> symbol, which
  2675. indicates to the C program that the memcmp() routine is available
  2676. to compare blocks of memory.
  2677.  
  2678. =item C<d_memcpy>
  2679.  
  2680. From F<d_memcpy.U>:
  2681.  
  2682. This variable conditionally defines the C<HAS_MEMCPY> symbol, which
  2683. indicates to the C program that the memcpy() routine is available
  2684. to copy blocks of memory.
  2685.  
  2686. =item C<d_memmove>
  2687.  
  2688. From F<d_memmove.U>:
  2689.  
  2690. This variable conditionally defines the C<HAS_MEMMOVE> symbol, which
  2691. indicates to the C program that the memmove() routine is available
  2692. to copy potentatially overlapping blocks of memory.
  2693.  
  2694. =item C<d_memset>
  2695.  
  2696. From F<d_memset.U>:
  2697.  
  2698. This variable conditionally defines the C<HAS_MEMSET> symbol, which
  2699. indicates to the C program that the memset() routine is available
  2700. to set blocks of memory.
  2701.  
  2702. =item C<d_mkdir>
  2703.  
  2704. From F<d_mkdir.U>:
  2705.  
  2706. This variable conditionally defines the C<HAS_MKDIR> symbol, which
  2707. indicates to the C program that the mkdir() routine is available
  2708. to create F<directories.>.
  2709.  
  2710. =item C<d_mkdtemp>
  2711.  
  2712. From F<d_mkdtemp.U>:
  2713.  
  2714. This variable conditionally defines the C<HAS_MKDTEMP> symbol, which
  2715. indicates to the C program that the mkdtemp() routine is available
  2716. to exclusively create a uniquely named temporary directory.
  2717.  
  2718. =item C<d_mkfifo>
  2719.  
  2720. From F<d_mkfifo.U>:
  2721.  
  2722. This variable conditionally defines the C<HAS_MKFIFO> symbol, which
  2723. indicates to the C program that the mkfifo() routine is available.
  2724.  
  2725. =item C<d_mkstemp>
  2726.  
  2727. From F<d_mkstemp.U>:
  2728.  
  2729. This variable conditionally defines the C<HAS_MKSTEMP> symbol, which
  2730. indicates to the C program that the mkstemp() routine is available
  2731. to exclusively create and open a uniquely named temporary file.
  2732.  
  2733. =item C<d_mkstemps>
  2734.  
  2735. From F<d_mkstemps.U>:
  2736.  
  2737. This variable conditionally defines the C<HAS_MKSTEMPS> symbol, which
  2738. indicates to the C program that the mkstemps() routine is available
  2739. to exclusively create and open a uniquely named (with a suffix)
  2740. temporary file.
  2741.  
  2742. =item C<d_mktime>
  2743.  
  2744. From F<d_mktime.U>:
  2745.  
  2746. This variable conditionally defines the C<HAS_MKTIME> symbol, which
  2747. indicates to the C program that the mktime() routine is available.
  2748.  
  2749. =item C<d_mmap>
  2750.  
  2751. From F<d_mmap.U>:
  2752.  
  2753. This variable conditionally defines C<HAS_MMAP> if mmap() is
  2754. available to map a file into memory.
  2755.  
  2756. =item C<d_modfl>
  2757.  
  2758. From F<d_modfl.U>:
  2759.  
  2760. This variable conditionally defines the C<HAS_MODFL> symbol, which
  2761. indicates to the C program that the modfl() routine is available.
  2762.  
  2763. =item C<d_mprotect>
  2764.  
  2765. From F<d_mprotect.U>:
  2766.  
  2767. This variable conditionally defines C<HAS_MPROTECT> if mprotect() is
  2768. available to modify the access protection of a memory mapped file.
  2769.  
  2770. =item C<d_msg>
  2771.  
  2772. From F<d_msg.U>:
  2773.  
  2774. This variable conditionally defines the C<HAS_MSG> symbol, which
  2775. indicates that the entire msg*(2) library is present.
  2776.  
  2777. =item C<d_msg_ctrunc>
  2778.  
  2779. From F<d_socket.U>:
  2780.  
  2781. This variable conditionally defines the C<HAS_MSG_CTRUNC> symbol,
  2782. which indicates that the C<MSG_CTRUNC> is available.  #ifdef is
  2783. not enough because it may be an enum, glibc has been known to do this.
  2784.  
  2785. =item C<d_msg_dontroute>
  2786.  
  2787. From F<d_socket.U>:
  2788.  
  2789. This variable conditionally defines the C<HAS_MSG_DONTROUTE> symbol,
  2790. which indicates that the C<MSG_DONTROUTE> is available.  #ifdef is
  2791. not enough because it may be an enum, glibc has been known to do this.
  2792.  
  2793. =item C<d_msg_oob>
  2794.  
  2795. From F<d_socket.U>:
  2796.  
  2797. This variable conditionally defines the C<HAS_MSG_OOB> symbol,
  2798. which indicates that the C<MSG_OOB> is available.  #ifdef is
  2799. not enough because it may be an enum, glibc has been known to do this.
  2800.  
  2801. =item C<d_msg_peek>
  2802.  
  2803. From F<d_socket.U>:
  2804.  
  2805. This variable conditionally defines the C<HAS_MSG_PEEK> symbol,
  2806. which indicates that the C<MSG_PEEK> is available.  #ifdef is
  2807. not enough because it may be an enum, glibc has been known to do this.
  2808.  
  2809. =item C<d_msg_proxy>
  2810.  
  2811. From F<d_socket.U>:
  2812.  
  2813. This variable conditionally defines the C<HAS_MSG_PROXY> symbol,
  2814. which indicates that the C<MSG_PROXY> is available.  #ifdef is
  2815. not enough because it may be an enum, glibc has been known to do this.
  2816.  
  2817. =item C<d_msgctl>
  2818.  
  2819. From F<d_msgctl.U>:
  2820.  
  2821. This variable conditionally defines the C<HAS_MSGCTL> symbol, which
  2822. indicates to the C program that the msgctl() routine is available.
  2823.  
  2824. =item C<d_msgget>
  2825.  
  2826. From F<d_msgget.U>:
  2827.  
  2828. This variable conditionally defines the C<HAS_MSGGET> symbol, which
  2829. indicates to the C program that the msgget() routine is available.
  2830.  
  2831. =item C<d_msgrcv>
  2832.  
  2833. From F<d_msgrcv.U>:
  2834.  
  2835. This variable conditionally defines the C<HAS_MSGRCV> symbol, which
  2836. indicates to the C program that the msgrcv() routine is available.
  2837.  
  2838. =item C<d_msgsnd>
  2839.  
  2840. From F<d_msgsnd.U>:
  2841.  
  2842. This variable conditionally defines the C<HAS_MSGSND> symbol, which
  2843. indicates to the C program that the msgsnd() routine is available.
  2844.  
  2845. =item C<d_msync>
  2846.  
  2847. From F<d_msync.U>:
  2848.  
  2849. This variable conditionally defines C<HAS_MSYNC> if msync() is
  2850. available to synchronize a mapped file.
  2851.  
  2852. =item C<d_munmap>
  2853.  
  2854. From F<d_munmap.U>:
  2855.  
  2856. This variable conditionally defines C<HAS_MUNMAP> if munmap() is
  2857. available to unmap a region mapped by mmap().
  2858.  
  2859. =item C<d_mymalloc>
  2860.  
  2861. From F<mallocsrc.U>:
  2862.  
  2863. This variable conditionally defines C<MYMALLOC> in case other parts
  2864. of the source want to take special action if C<MYMALLOC> is used.
  2865. This may include different sorts of profiling or error detection.
  2866.  
  2867. =item C<d_nice>
  2868.  
  2869. From F<d_nice.U>:
  2870.  
  2871. This variable conditionally defines the C<HAS_NICE> symbol, which
  2872. indicates to the C program that the nice() routine is available.
  2873.  
  2874. =item C<d_nv_preserves_uv>
  2875.  
  2876. From F<perlxv.U>:
  2877.  
  2878. This variable indicates whether a variable of type nvtype
  2879. can preserve all the bits a variable of type uvtype.
  2880.  
  2881. =item C<d_nv_preserves_uv_bits>
  2882.  
  2883. From F<perlxv.U>:
  2884.  
  2885. This variable indicates how many of bits type uvtype
  2886. a variable nvtype can preserve.
  2887.  
  2888. =item C<d_off64_t>
  2889.  
  2890. From F<d_off64_t.U>:
  2891.  
  2892. This symbol will be defined if the C compiler supports off64_t.
  2893.  
  2894. =item C<d_old_pthread_create_joinable>
  2895.  
  2896. From F<d_pthrattrj.U>:
  2897.  
  2898. This variable conditionally defines pthread_create_joinable.
  2899. undef if F<pthread.h> defines C<PTHREAD_CREATE_JOINABLE>.
  2900.  
  2901. =item C<d_oldpthreads>
  2902.  
  2903. From F<usethreads.U>:
  2904.  
  2905. This variable conditionally defines the C<OLD_PTHREADS_API> symbol,
  2906. and indicates that Perl should be built to use the old
  2907. draft C<POSIX> threads C<API>.  This is only potentially meaningful if
  2908. usethreads is set.
  2909.  
  2910. =item C<d_oldsock>
  2911.  
  2912. From F<d_socket.U>:
  2913.  
  2914. This variable conditionally defines the C<OLDSOCKET> symbol, which
  2915. indicates that the C<BSD> socket interface is based on 4.1c and not 4.2.
  2916.  
  2917. =item C<d_open3>
  2918.  
  2919. From F<d_open3.U>:
  2920.  
  2921. This variable conditionally defines the HAS_OPEN3 manifest constant,
  2922. which indicates to the C program that the 3 argument version of
  2923. the open(2) function is available.
  2924.  
  2925. =item C<d_pathconf>
  2926.  
  2927. From F<d_pathconf.U>:
  2928.  
  2929. This variable conditionally defines the C<HAS_PATHCONF> symbol, which
  2930. indicates to the C program that the pathconf() routine is available
  2931. to determine file-system related limits and options associated
  2932. with a given filename.
  2933.  
  2934. =item C<d_pause>
  2935.  
  2936. From F<d_pause.U>:
  2937.  
  2938. This variable conditionally defines the C<HAS_PAUSE> symbol, which
  2939. indicates to the C program that the pause() routine is available
  2940. to suspend a process until a signal is received.
  2941.  
  2942. =item C<d_perl_otherlibdirs>
  2943.  
  2944. From F<otherlibdirs.U>:
  2945.  
  2946. This variable conditionally defines C<PERL_OTHERLIBDIRS>, which
  2947. contains a colon-separated set of paths for the perl binary to
  2948. include in @C<INC>.  See also otherlibdirs.
  2949.  
  2950. =item C<d_phostname>
  2951.  
  2952. From F<d_gethname.U>:
  2953.  
  2954. This variable conditionally defines the C<HAS_PHOSTNAME> symbol, which
  2955. contains the shell command which, when fed to popen(), may be
  2956. used to derive the host name.
  2957.  
  2958. =item C<d_pipe>
  2959.  
  2960. From F<d_pipe.U>:
  2961.  
  2962. This variable conditionally defines the C<HAS_PIPE> symbol, which
  2963. indicates to the C program that the pipe() routine is available
  2964. to create an inter-process channel.
  2965.  
  2966. =item C<d_poll>
  2967.  
  2968. From F<d_poll.U>:
  2969.  
  2970. This variable conditionally defines the C<HAS_POLL> symbol, which
  2971. indicates to the C program that the poll() routine is available
  2972. to poll active file descriptors.
  2973.  
  2974. =item C<d_portable>
  2975.  
  2976. From F<d_portable.U>:
  2977.  
  2978. This variable conditionally defines the C<PORTABLE> symbol, which
  2979. indicates to the C program that it should not assume that it is
  2980. running on the machine it was compiled on.
  2981.  
  2982. =item C<d_PRId64>
  2983.  
  2984. From F<quadfio.U>:
  2985.  
  2986. This variable conditionally defines the PERL_PRId64 symbol, which
  2987. indiciates that stdio has a symbol to print 64-bit decimal numbers.
  2988.  
  2989. =item C<d_PRIeldbl>
  2990.  
  2991. From F<longdblfio.U>:
  2992.  
  2993. This variable conditionally defines the PERL_PRIfldbl symbol, which
  2994. indiciates that stdio has a symbol to print long doubles.
  2995.  
  2996. =item C<d_PRIEUldbl>
  2997.  
  2998. From F<longdblfio.U>:
  2999.  
  3000. This variable conditionally defines the PERL_PRIfldbl symbol, which
  3001. indiciates that stdio has a symbol to print long doubles.
  3002. The C<U> in the name is to separate this from d_PRIeldbl so that even
  3003. case-blind systems can see the difference.
  3004.  
  3005. =item C<d_PRIfldbl>
  3006.  
  3007. From F<longdblfio.U>:
  3008.  
  3009. This variable conditionally defines the PERL_PRIfldbl symbol, which
  3010. indiciates that stdio has a symbol to print long doubles.
  3011.  
  3012. =item C<d_PRIFUldbl>
  3013.  
  3014. From F<longdblfio.U>:
  3015.  
  3016. This variable conditionally defines the PERL_PRIfldbl symbol, which
  3017. indiciates that stdio has a symbol to print long doubles.
  3018. The C<U> in the name is to separate this from d_PRIfldbl so that even
  3019. case-blind systems can see the difference.
  3020.  
  3021. =item C<d_PRIgldbl>
  3022.  
  3023. From F<longdblfio.U>:
  3024.  
  3025. This variable conditionally defines the PERL_PRIfldbl symbol, which
  3026. indiciates that stdio has a symbol to print long doubles.
  3027.  
  3028. =item C<d_PRIGUldbl>
  3029.  
  3030. From F<longdblfio.U>:
  3031.  
  3032. This variable conditionally defines the PERL_PRIfldbl symbol, which
  3033. indiciates that stdio has a symbol to print long doubles.
  3034. The C<U> in the name is to separate this from d_PRIgldbl so that even
  3035. case-blind systems can see the difference.
  3036.  
  3037. =item C<d_PRIi64>
  3038.  
  3039. From F<quadfio.U>:
  3040.  
  3041. This variable conditionally defines the PERL_PRIi64 symbol, which
  3042. indiciates that stdio has a symbol to print 64-bit decimal numbers.
  3043.  
  3044. =item C<d_PRIo64>
  3045.  
  3046. From F<quadfio.U>:
  3047.  
  3048. This variable conditionally defines the PERL_PRIo64 symbol, which
  3049. indiciates that stdio has a symbol to print 64-bit octal numbers.
  3050.  
  3051. =item C<d_PRIu64>
  3052.  
  3053. From F<quadfio.U>:
  3054.  
  3055. This variable conditionally defines the PERL_PRIu64 symbol, which
  3056. indiciates that stdio has a symbol to print 64-bit unsigned decimal
  3057. numbers.
  3058.  
  3059. =item C<d_PRIx64>
  3060.  
  3061. From F<quadfio.U>:
  3062.  
  3063. This variable conditionally defines the PERL_PRIx64 symbol, which
  3064. indiciates that stdio has a symbol to print 64-bit hexadecimal numbers.
  3065.  
  3066. =item C<d_PRIXU64>
  3067.  
  3068. From F<quadfio.U>:
  3069.  
  3070. This variable conditionally defines the PERL_PRIXU64 symbol, which
  3071. indiciates that stdio has a symbol to print 64-bit hExADECimAl numbers.
  3072. The C<U> in the name is to separate this from d_PRIx64 so that even
  3073. case-blind systems can see the difference.
  3074.  
  3075. =item C<d_pthread_atfork>
  3076.  
  3077. From F<d_pthread_atfork.U>:
  3078.  
  3079. This variable conditionally defines the C<HAS_PTHREAD_ATFORK> symbol,
  3080. which indicates to the C program that the pthread_atfork()
  3081. routine is available.
  3082.  
  3083. =item C<d_pthread_yield>
  3084.  
  3085. From F<d_pthread_y.U>:
  3086.  
  3087. This variable conditionally defines the C<HAS_PTHREAD_YIELD>
  3088. symbol if the pthread_yield routine is available to yield
  3089. the execution of the current thread.
  3090.  
  3091. =item C<d_pwage>
  3092.  
  3093. From F<i_pwd.U>:
  3094.  
  3095. This variable conditionally defines C<PWAGE>, which indicates
  3096. that struct passwd contains pw_age.
  3097.  
  3098. =item C<d_pwchange>
  3099.  
  3100. From F<i_pwd.U>:
  3101.  
  3102. This variable conditionally defines C<PWCHANGE>, which indicates
  3103. that struct passwd contains pw_change.
  3104.  
  3105. =item C<d_pwclass>
  3106.  
  3107. From F<i_pwd.U>:
  3108.  
  3109. This variable conditionally defines C<PWCLASS>, which indicates
  3110. that struct passwd contains pw_class.
  3111.  
  3112. =item C<d_pwcomment>
  3113.  
  3114. From F<i_pwd.U>:
  3115.  
  3116. This variable conditionally defines C<PWCOMMENT>, which indicates
  3117. that struct passwd contains pw_comment.
  3118.  
  3119. =item C<d_pwexpire>
  3120.  
  3121. From F<i_pwd.U>:
  3122.  
  3123. This variable conditionally defines C<PWEXPIRE>, which indicates
  3124. that struct passwd contains pw_expire.
  3125.  
  3126. =item C<d_pwgecos>
  3127.  
  3128. From F<i_pwd.U>:
  3129.  
  3130. This variable conditionally defines C<PWGECOS>, which indicates
  3131. that struct passwd contains pw_gecos.
  3132.  
  3133. =item C<d_pwpasswd>
  3134.  
  3135. From F<i_pwd.U>:
  3136.  
  3137. This variable conditionally defines C<PWPASSWD>, which indicates
  3138. that struct passwd contains pw_passwd.
  3139.  
  3140. =item C<d_pwquota>
  3141.  
  3142. From F<i_pwd.U>:
  3143.  
  3144. This variable conditionally defines C<PWQUOTA>, which indicates
  3145. that struct passwd contains pw_quota.
  3146.  
  3147. =item C<d_qgcvt>
  3148.  
  3149. From F<d_qgcvt.U>:
  3150.  
  3151. This variable conditionally defines the C<HAS_QGCVT> symbol, which
  3152. indicates to the C program that the qgcvt() routine is available.
  3153.  
  3154. =item C<d_quad>
  3155.  
  3156. From F<quadtype.U>:
  3157.  
  3158. This variable, if defined, tells that there's a 64-bit integer type,
  3159. quadtype.
  3160.  
  3161. =item C<d_readdir>
  3162.  
  3163. From F<d_readdir.U>:
  3164.  
  3165. This variable conditionally defines C<HAS_READDIR> if readdir() is
  3166. available to read directory entries.
  3167.  
  3168. =item C<d_readlink>
  3169.  
  3170. From F<d_readlink.U>:
  3171.  
  3172. This variable conditionally defines the C<HAS_READLINK> symbol, which
  3173. indicates to the C program that the readlink() routine is available
  3174. to read the value of a symbolic link.
  3175.  
  3176. =item C<d_rename>
  3177.  
  3178. From F<d_rename.U>:
  3179.  
  3180. This variable conditionally defines the C<HAS_RENAME> symbol, which
  3181. indicates to the C program that the rename() routine is available
  3182. to rename files.
  3183.  
  3184. =item C<d_rewinddir>
  3185.  
  3186. From F<d_readdir.U>:
  3187.  
  3188. This variable conditionally defines C<HAS_REWINDDIR> if rewinddir() is
  3189. available.
  3190.  
  3191. =item C<d_rmdir>
  3192.  
  3193. From F<d_rmdir.U>:
  3194.  
  3195. This variable conditionally defines C<HAS_RMDIR> if rmdir() is
  3196. available to remove directories.
  3197.  
  3198. =item C<d_safebcpy>
  3199.  
  3200. From F<d_safebcpy.U>:
  3201.  
  3202. This variable conditionally defines the C<HAS_SAFE_BCOPY> symbol if
  3203. the bcopy() routine can do overlapping copies.
  3204.  
  3205. =item C<d_safemcpy>
  3206.  
  3207. From F<d_safemcpy.U>:
  3208.  
  3209. This variable conditionally defines the C<HAS_SAFE_MEMCPY> symbol if
  3210. the memcpy() routine can do overlapping copies.
  3211.  
  3212. =item C<d_sanemcmp>
  3213.  
  3214. From F<d_sanemcmp.U>:
  3215.  
  3216. This variable conditionally defines the C<HAS_SANE_MEMCMP> symbol if
  3217. the memcpy() routine is available and can be used to compare relative
  3218. magnitudes of chars with their high bits set.
  3219.  
  3220. =item C<d_sbrkproto>
  3221.  
  3222. From F<d_sbrkproto.U>:
  3223.  
  3224. This variable conditionally defines the C<HAS_SBRK_PROTO> symbol,
  3225. which indicates to the C program that the system provides
  3226. a prototype for the sbrk() function.  Otherwise, it is
  3227. up to the program to supply one.
  3228.  
  3229. =item C<d_sched_yield>
  3230.  
  3231. From F<d_pthread_y.U>:
  3232.  
  3233. This variable conditionally defines the C<HAS_SCHED_YIELD>
  3234. symbol if the sched_yield routine is available to yield
  3235. the execution of the current thread.
  3236.  
  3237. =item C<d_scm_rights>
  3238.  
  3239. From F<d_socket.U>:
  3240.  
  3241. This variable conditionally defines the C<HAS_SCM_RIGHTS> symbol,
  3242. which indicates that the C<SCM_RIGHTS> is available.  #ifdef is
  3243. not enough because it may be an enum, glibc has been known to do this.
  3244.  
  3245. =item C<d_SCNfldbl>
  3246.  
  3247. From F<longdblfio.U>:
  3248.  
  3249. This variable conditionally defines the PERL_PRIfldbl symbol, which
  3250. indiciates that stdio has a symbol to scan long doubles.
  3251.  
  3252. =item C<d_seekdir>
  3253.  
  3254. From F<d_readdir.U>:
  3255.  
  3256. This variable conditionally defines C<HAS_SEEKDIR> if seekdir() is
  3257. available.
  3258.  
  3259. =item C<d_select>
  3260.  
  3261. From F<d_select.U>:
  3262.  
  3263. This variable conditionally defines C<HAS_SELECT> if select() is
  3264. available to select active file descriptors. A <sys/time.h>
  3265. inclusion may be necessary for the timeout field.
  3266.  
  3267. =item C<d_sem>
  3268.  
  3269. From F<d_sem.U>:
  3270.  
  3271. This variable conditionally defines the C<HAS_SEM> symbol, which
  3272. indicates that the entire sem*(2) library is present.
  3273.  
  3274. =item C<d_semctl>
  3275.  
  3276. From F<d_semctl.U>:
  3277.  
  3278. This variable conditionally defines the C<HAS_SEMCTL> symbol, which
  3279. indicates to the C program that the semctl() routine is available.
  3280.  
  3281. =item C<d_semctl_semid_ds>
  3282.  
  3283. From F<d_union_semun.U>:
  3284.  
  3285. This variable conditionally defines C<USE_SEMCTL_SEMID_DS>, which
  3286. indicates that struct semid_ds * is to be used for semctl C<IPC_STAT>.
  3287.  
  3288. =item C<d_semctl_semun>
  3289.  
  3290. From F<d_union_semun.U>:
  3291.  
  3292. This variable conditionally defines C<USE_SEMCTL_SEMUN>, which
  3293. indicates that union semun is to be used for semctl C<IPC_STAT>.
  3294.  
  3295. =item C<d_semget>
  3296.  
  3297. From F<d_semget.U>:
  3298.  
  3299. This variable conditionally defines the C<HAS_SEMGET> symbol, which
  3300. indicates to the C program that the semget() routine is available.
  3301.  
  3302. =item C<d_semop>
  3303.  
  3304. From F<d_semop.U>:
  3305.  
  3306. This variable conditionally defines the C<HAS_SEMOP> symbol, which
  3307. indicates to the C program that the semop() routine is available.
  3308.  
  3309. =item C<d_setegid>
  3310.  
  3311. From F<d_setegid.U>:
  3312.  
  3313. This variable conditionally defines the C<HAS_SETEGID> symbol, which
  3314. indicates to the C program that the setegid() routine is available
  3315. to change the effective gid of the current program.
  3316.  
  3317. =item C<d_seteuid>
  3318.  
  3319. From F<d_seteuid.U>:
  3320.  
  3321. This variable conditionally defines the C<HAS_SETEUID> symbol, which
  3322. indicates to the C program that the seteuid() routine is available
  3323. to change the effective uid of the current program.
  3324.  
  3325. =item C<d_setgrent>
  3326.  
  3327. From F<d_setgrent.U>:
  3328.  
  3329. This variable conditionally defines the C<HAS_SETGRENT> symbol, which
  3330. indicates to the C program that the setgrent() routine is available
  3331. for initializing sequential access to the group database.
  3332.  
  3333. =item C<d_setgrps>
  3334.  
  3335. From F<d_setgrps.U>:
  3336.  
  3337. This variable conditionally defines the C<HAS_SETGROUPS> symbol, which
  3338. indicates to the C program that the setgroups() routine is available
  3339. to set the list of process groups.
  3340.  
  3341. =item C<d_sethent>
  3342.  
  3343. From F<d_sethent.U>:
  3344.  
  3345. This variable conditionally defines C<HAS_SETHOSTENT> if sethostent() is
  3346. available.
  3347.  
  3348. =item C<d_setlinebuf>
  3349.  
  3350. From F<d_setlnbuf.U>:
  3351.  
  3352. This variable conditionally defines the C<HAS_SETLINEBUF> symbol, which
  3353. indicates to the C program that the setlinebuf() routine is available
  3354. to change stderr or stdout from block-buffered or unbuffered to a
  3355. line-buffered mode.
  3356.  
  3357. =item C<d_setlocale>
  3358.  
  3359. From F<d_setlocale.U>:
  3360.  
  3361. This variable conditionally defines C<HAS_SETLOCALE> if setlocale() is
  3362. available to handle locale-specific ctype implementations.
  3363.  
  3364. =item C<d_setnent>
  3365.  
  3366. From F<d_setnent.U>:
  3367.  
  3368. This variable conditionally defines C<HAS_SETNETENT> if setnetent() is
  3369. available.
  3370.  
  3371. =item C<d_setpent>
  3372.  
  3373. From F<d_setpent.U>:
  3374.  
  3375. This variable conditionally defines C<HAS_SETPROTOENT> if setprotoent() is
  3376. available.
  3377.  
  3378. =item C<d_setpgid>
  3379.  
  3380. From F<d_setpgid.U>:
  3381.  
  3382. This variable conditionally defines the C<HAS_SETPGID> symbol if the
  3383. setpgid(pid, gpid) function is available to set process group C<ID>.
  3384.  
  3385. =item C<d_setpgrp2>
  3386.  
  3387. From F<d_setpgrp2.U>:
  3388.  
  3389. This variable conditionally defines the HAS_SETPGRP2 symbol, which
  3390. indicates to the C program that the setpgrp2() (as in F<DG/C<UX>>) routine
  3391. is available to set the current process group.
  3392.  
  3393. =item C<d_setpgrp>
  3394.  
  3395. From F<d_setpgrp.U>:
  3396.  
  3397. This variable conditionally defines C<HAS_SETPGRP> if setpgrp() is
  3398. available to set the current process group.
  3399.  
  3400. =item C<d_setprior>
  3401.  
  3402. From F<d_setprior.U>:
  3403.  
  3404. This variable conditionally defines C<HAS_SETPRIORITY> if setpriority()
  3405. is available to set a process's priority.
  3406.  
  3407. =item C<d_setproctitle>
  3408.  
  3409. From F<d_setproctitle.U>:
  3410.  
  3411. This variable conditionally defines the C<HAS_SETPROCTITLE> symbol,
  3412. which indicates to the C program that the setproctitle() routine
  3413. is available.
  3414.  
  3415. =item C<d_setpwent>
  3416.  
  3417. From F<d_setpwent.U>:
  3418.  
  3419. This variable conditionally defines the C<HAS_SETPWENT> symbol, which
  3420. indicates to the C program that the setpwent() routine is available
  3421. for initializing sequential access to the passwd database.
  3422.  
  3423. =item C<d_setregid>
  3424.  
  3425. From F<d_setregid.U>:
  3426.  
  3427. This variable conditionally defines C<HAS_SETREGID> if setregid() is
  3428. available to change the real and effective gid of the current
  3429. process.
  3430.  
  3431. =item C<d_setresgid>
  3432.  
  3433. From F<d_setregid.U>:
  3434.  
  3435. This variable conditionally defines C<HAS_SETRESGID> if setresgid() is
  3436. available to change the real, effective and saved gid of the current
  3437. process.
  3438.  
  3439. =item C<d_setresuid>
  3440.  
  3441. From F<d_setreuid.U>:
  3442.  
  3443. This variable conditionally defines C<HAS_SETREUID> if setresuid() is
  3444. available to change the real, effective and saved uid of the current
  3445. process.
  3446.  
  3447. =item C<d_setreuid>
  3448.  
  3449. From F<d_setreuid.U>:
  3450.  
  3451. This variable conditionally defines C<HAS_SETREUID> if setreuid() is
  3452. available to change the real and effective uid of the current
  3453. process.
  3454.  
  3455. =item C<d_setrgid>
  3456.  
  3457. From F<d_setrgid.U>:
  3458.  
  3459. This variable conditionally defines the C<HAS_SETRGID> symbol, which
  3460. indicates to the C program that the setrgid() routine is available
  3461. to change the real gid of the current program.
  3462.  
  3463. =item C<d_setruid>
  3464.  
  3465. From F<d_setruid.U>:
  3466.  
  3467. This variable conditionally defines the C<HAS_SETRUID> symbol, which
  3468. indicates to the C program that the setruid() routine is available
  3469. to change the real uid of the current program.
  3470.  
  3471. =item C<d_setsent>
  3472.  
  3473. From F<d_setsent.U>:
  3474.  
  3475. This variable conditionally defines C<HAS_SETSERVENT> if setservent() is
  3476. available.
  3477.  
  3478. =item C<d_setsid>
  3479.  
  3480. From F<d_setsid.U>:
  3481.  
  3482. This variable conditionally defines C<HAS_SETSID> if setsid() is
  3483. available to set the process group C<ID>.
  3484.  
  3485. =item C<d_setvbuf>
  3486.  
  3487. From F<d_setvbuf.U>:
  3488.  
  3489. This variable conditionally defines the C<HAS_SETVBUF> symbol, which
  3490. indicates to the C program that the setvbuf() routine is available
  3491. to change buffering on an open stdio stream.
  3492.  
  3493. =item C<d_sfio>
  3494.  
  3495. From F<d_sfio.U>:
  3496.  
  3497. This variable conditionally defines the C<USE_SFIO> symbol,
  3498. and indicates whether sfio is available (and should be used).
  3499.  
  3500. =item C<d_shm>
  3501.  
  3502. From F<d_shm.U>:
  3503.  
  3504. This variable conditionally defines the C<HAS_SHM> symbol, which
  3505. indicates that the entire shm*(2) library is present.
  3506.  
  3507. =item C<d_shmat>
  3508.  
  3509. From F<d_shmat.U>:
  3510.  
  3511. This variable conditionally defines the C<HAS_SHMAT> symbol, which
  3512. indicates to the C program that the shmat() routine is available.
  3513.  
  3514. =item C<d_shmatprototype>
  3515.  
  3516. From F<d_shmat.U>:
  3517.  
  3518. This variable conditionally defines the C<HAS_SHMAT_PROTOTYPE> 
  3519. symbol, which indicates that F<sys/shm.h> has a prototype for
  3520. shmat.
  3521.  
  3522. =item C<d_shmctl>
  3523.  
  3524. From F<d_shmctl.U>:
  3525.  
  3526. This variable conditionally defines the C<HAS_SHMCTL> symbol, which
  3527. indicates to the C program that the shmctl() routine is available.
  3528.  
  3529. =item C<d_shmdt>
  3530.  
  3531. From F<d_shmdt.U>:
  3532.  
  3533. This variable conditionally defines the C<HAS_SHMDT> symbol, which
  3534. indicates to the C program that the shmdt() routine is available.
  3535.  
  3536. =item C<d_shmget>
  3537.  
  3538. From F<d_shmget.U>:
  3539.  
  3540. This variable conditionally defines the C<HAS_SHMGET> symbol, which
  3541. indicates to the C program that the shmget() routine is available.
  3542.  
  3543. =item C<d_sigaction>
  3544.  
  3545. From F<d_sigaction.U>:
  3546.  
  3547. This variable conditionally defines the C<HAS_SIGACTION> symbol, which
  3548. indicates that the Vr4 sigaction() routine is available.
  3549.  
  3550. =item C<d_sigprocmask>
  3551.  
  3552. From F<d_sigprocmask.U>:
  3553.  
  3554. This variable conditionally defines C<HAS_SIGPROCMASK>
  3555. if sigprocmask() is available to examine or change the signal mask
  3556. of the calling process.
  3557.  
  3558. =item C<d_sigsetjmp>
  3559.  
  3560. From F<d_sigsetjmp.U>:
  3561.  
  3562. This variable conditionally defines the C<HAS_SIGSETJMP> symbol,
  3563. which indicates that the sigsetjmp() routine is available to
  3564. call setjmp() and optionally save the process's signal mask.
  3565.  
  3566. =item C<d_socket>
  3567.  
  3568. From F<d_socket.U>:
  3569.  
  3570. This variable conditionally defines C<HAS_SOCKET>, which indicates
  3571. that the C<BSD> socket interface is supported.
  3572.  
  3573. =item C<d_socklen_t>
  3574.  
  3575. From F<d_socklen_t.U>:
  3576.  
  3577. This symbol will be defined if the C compiler supports socklen_t.
  3578.  
  3579. =item C<d_sockpair>
  3580.  
  3581. From F<d_socket.U>:
  3582.  
  3583. This variable conditionally defines the C<HAS_SOCKETPAIR> symbol, which
  3584. indicates that the C<BSD> socketpair() is supported.
  3585.  
  3586. =item C<d_socks5_init>
  3587.  
  3588. From F<d_socks5_init.U>:
  3589.  
  3590. This variable conditionally defines the HAS_SOCKS5_INIT symbol, which
  3591. indicates to the C program that the socks5_init() routine is available.
  3592.  
  3593. =item C<d_sqrtl>
  3594.  
  3595. From F<d_sqrtl.U>:
  3596.  
  3597. This variable conditionally defines the C<HAS_SQRTL> symbol, which
  3598. indicates to the C program that the sqrtl() routine is available.
  3599.  
  3600. =item C<d_statblks>
  3601.  
  3602. From F<d_statblks.U>:
  3603.  
  3604. This variable conditionally defines C<USE_STAT_BLOCKS>
  3605. if this system has a stat structure declaring
  3606. st_blksize and st_blocks.
  3607.  
  3608. =item C<d_statfs_f_flags>
  3609.  
  3610. From F<d_statfs_f_flags.U>:
  3611.  
  3612. This variable conditionally defines the C<HAS_STRUCT_STATFS_F_FLAGS>
  3613. symbol, which indicates to struct statfs from has f_flags member.
  3614. This kind of struct statfs is coming from F<sys/mount.h> (C<BSD>),
  3615. not from F<sys/statfs.h> (C<SYSV>).
  3616.  
  3617. =item C<d_statfs_s>
  3618.  
  3619. From F<d_statfs_s.U>:
  3620.  
  3621. This variable conditionally defines the C<HAS_STRUCT_STATFS> symbol,
  3622. which indicates that the struct statfs is supported.
  3623.  
  3624. =item C<d_statvfs>
  3625.  
  3626. From F<d_statvfs.U>:
  3627.  
  3628. This variable conditionally defines the C<HAS_STATVFS> symbol, which
  3629. indicates to the C program that the statvfs() routine is available.
  3630.  
  3631. =item C<d_stdio_cnt_lval>
  3632.  
  3633. From F<d_stdstdio.U>:
  3634.  
  3635. This variable conditionally defines C<STDIO_CNT_LVALUE> if the
  3636. C<FILE_cnt> macro can be used as an lvalue.
  3637.  
  3638. =item C<d_stdio_ptr_lval>
  3639.  
  3640. From F<d_stdstdio.U>:
  3641.  
  3642. This variable conditionally defines C<STDIO_PTR_LVALUE> if the
  3643. C<FILE_ptr> macro can be used as an lvalue.
  3644.  
  3645. =item C<d_stdio_ptr_lval_nochange_cnt>
  3646.  
  3647. From F<d_stdstdio.U>:
  3648.  
  3649. This symbol is defined if using the C<FILE_ptr> macro as an lvalue
  3650. to increase the pointer by n leaves File_cnt(fp) unchanged.
  3651.  
  3652. =item C<d_stdio_ptr_lval_sets_cnt>
  3653.  
  3654. From F<d_stdstdio.U>:
  3655.  
  3656. This symbol is defined if using the C<FILE_ptr> macro as an lvalue
  3657. to increase the pointer by n has the side effect of decreasing the
  3658. value of File_cnt(fp) by n.
  3659.  
  3660. =item C<d_stdio_stream_array>
  3661.  
  3662. From F<stdio_streams.U>:
  3663.  
  3664. This variable tells whether there is an array holding
  3665. the stdio streams.
  3666.  
  3667. =item C<d_stdiobase>
  3668.  
  3669. From F<d_stdstdio.U>:
  3670.  
  3671. This variable conditionally defines C<USE_STDIO_BASE> if this system
  3672. has a C<FILE> structure declaring a usable _base field (or equivalent)
  3673. in F<stdio.h>.
  3674.  
  3675. =item C<d_stdstdio>
  3676.  
  3677. From F<d_stdstdio.U>:
  3678.  
  3679. This variable conditionally defines C<USE_STDIO_PTR> if this system
  3680. has a C<FILE> structure declaring usable _ptr and _cnt fields (or
  3681. equivalent) in F<stdio.h>.
  3682.  
  3683. =item C<d_strchr>
  3684.  
  3685. From F<d_strchr.U>:
  3686.  
  3687. This variable conditionally defines C<HAS_STRCHR> if strchr() and
  3688. strrchr() are available for string searching.
  3689.  
  3690. =item C<d_strcoll>
  3691.  
  3692. From F<d_strcoll.U>:
  3693.  
  3694. This variable conditionally defines C<HAS_STRCOLL> if strcoll() is
  3695. available to compare strings using collating information.
  3696.  
  3697. =item C<d_strctcpy>
  3698.  
  3699. From F<d_strctcpy.U>:
  3700.  
  3701. This variable conditionally defines the C<USE_STRUCT_COPY> symbol, which
  3702. indicates to the C program that this C compiler knows how to copy
  3703. structures.
  3704.  
  3705. =item C<d_strerrm>
  3706.  
  3707. From F<d_strerror.U>:
  3708.  
  3709. This variable holds what Strerrr is defined as to translate an error
  3710. code condition into an error message string. It could be C<strerror>
  3711. or a more C<complex> macro emulating strrror with sys_errlist[], or the
  3712. C<unknown> string when both strerror and sys_errlist are missing.
  3713.  
  3714. =item C<d_strerror>
  3715.  
  3716. From F<d_strerror.U>:
  3717.  
  3718. This variable conditionally defines C<HAS_STRERROR> if strerror() is
  3719. available to translate error numbers to strings.
  3720.  
  3721. =item C<d_strtod>
  3722.  
  3723. From F<d_strtod.U>:
  3724.  
  3725. This variable conditionally defines the C<HAS_STRTOD> symbol, which
  3726. indicates to the C program that the strtod() routine is available
  3727. to provide better numeric string conversion than atof().
  3728.  
  3729. =item C<d_strtol>
  3730.  
  3731. From F<d_strtol.U>:
  3732.  
  3733. This variable conditionally defines the C<HAS_STRTOL> symbol, which
  3734. indicates to the C program that the strtol() routine is available
  3735. to provide better numeric string conversion than atoi() and friends.
  3736.  
  3737. =item C<d_strtold>
  3738.  
  3739. From F<d_strtold.U>:
  3740.  
  3741. This variable conditionally defines the C<HAS_STRTOLD> symbol, which
  3742. indicates to the C program that the strtold() routine is available.
  3743.  
  3744. =item C<d_strtoll>
  3745.  
  3746. From F<d_strtoll.U>:
  3747.  
  3748. This variable conditionally defines the C<HAS_STRTOLL> symbol, which
  3749. indicates to the C program that the strtoll() routine is available.
  3750.  
  3751. =item C<d_strtoq>
  3752.  
  3753. From F<d_strtoq.U>:
  3754.  
  3755. This variable conditionally defines the C<HAS_STRTOQ> symbol, which
  3756. indicates to the C program that the strtoq() routine is available.
  3757.  
  3758. =item C<d_strtoul>
  3759.  
  3760. From F<d_strtoul.U>:
  3761.  
  3762. This variable conditionally defines the C<HAS_STRTOUL> symbol, which
  3763. indicates to the C program that the strtoul() routine is available
  3764. to provide conversion of strings to unsigned long.
  3765.  
  3766. =item C<d_strtoull>
  3767.  
  3768. From F<d_strtoull.U>:
  3769.  
  3770. This variable conditionally defines the C<HAS_STRTOULL> symbol, which
  3771. indicates to the C program that the strtoull() routine is available.
  3772.  
  3773. =item C<d_strtouq>
  3774.  
  3775. From F<d_strtouq.U>:
  3776.  
  3777. This variable conditionally defines the C<HAS_STRTOUQ> symbol, which
  3778. indicates to the C program that the strtouq() routine is available.
  3779.  
  3780. =item C<d_strxfrm>
  3781.  
  3782. From F<d_strxfrm.U>:
  3783.  
  3784. This variable conditionally defines C<HAS_STRXFRM> if strxfrm() is
  3785. available to transform strings.
  3786.  
  3787. =item C<d_suidsafe>
  3788.  
  3789. From F<d_dosuid.U>:
  3790.  
  3791. This variable conditionally defines C<SETUID_SCRIPTS_ARE_SECURE_NOW>
  3792. if setuid scripts can be secure.  This test looks in F</dev/fd/>.
  3793.  
  3794. =item C<d_symlink>
  3795.  
  3796. From F<d_symlink.U>:
  3797.  
  3798. This variable conditionally defines the C<HAS_SYMLINK> symbol, which
  3799. indicates to the C program that the symlink() routine is available
  3800. to create symbolic links.
  3801.  
  3802. =item C<d_syscall>
  3803.  
  3804. From F<d_syscall.U>:
  3805.  
  3806. This variable conditionally defines C<HAS_SYSCALL> if syscall() is
  3807. available call arbitrary system calls.
  3808.  
  3809. =item C<d_sysconf>
  3810.  
  3811. From F<d_sysconf.U>:
  3812.  
  3813. This variable conditionally defines the C<HAS_SYSCONF> symbol, which
  3814. indicates to the C program that the sysconf() routine is available
  3815. to determine system related limits and options.
  3816.  
  3817. =item C<d_sysernlst>
  3818.  
  3819. From F<d_strerror.U>:
  3820.  
  3821. This variable conditionally defines C<HAS_SYS_ERRNOLIST> if sys_errnolist[]
  3822. is available to translate error numbers to the symbolic name.
  3823.  
  3824. =item C<d_syserrlst>
  3825.  
  3826. From F<d_strerror.U>:
  3827.  
  3828. This variable conditionally defines C<HAS_SYS_ERRLIST> if sys_errlist[] is
  3829. available to translate error numbers to strings.
  3830.  
  3831. =item C<d_system>
  3832.  
  3833. From F<d_system.U>:
  3834.  
  3835. This variable conditionally defines C<HAS_SYSTEM> if system() is
  3836. available to issue a shell command.
  3837.  
  3838. =item C<d_tcgetpgrp>
  3839.  
  3840. From F<d_tcgtpgrp.U>:
  3841.  
  3842. This variable conditionally defines the C<HAS_TCGETPGRP> symbol, which
  3843. indicates to the C program that the tcgetpgrp() routine is available.
  3844. to get foreground process group C<ID>.
  3845.  
  3846. =item C<d_tcsetpgrp>
  3847.  
  3848. From F<d_tcstpgrp.U>:
  3849.  
  3850. This variable conditionally defines the C<HAS_TCSETPGRP> symbol, which
  3851. indicates to the C program that the tcsetpgrp() routine is available
  3852. to set foreground process group C<ID>.
  3853.  
  3854. =item C<d_telldir>
  3855.  
  3856. From F<d_readdir.U>:
  3857.  
  3858. This variable conditionally defines C<HAS_TELLDIR> if telldir() is
  3859. available.
  3860.  
  3861. =item C<d_telldirproto>
  3862.  
  3863. From F<d_telldirproto.U>:
  3864.  
  3865. This variable conditionally defines the C<HAS_TELLDIR_PROTO> symbol,
  3866. which indicates to the C program that the system provides
  3867. a prototype for the telldir() function.  Otherwise, it is
  3868. up to the program to supply one.
  3869.  
  3870. =item C<d_time>
  3871.  
  3872. From F<d_time.U>:
  3873.  
  3874. This variable conditionally defines the C<HAS_TIME> symbol, which indicates
  3875. that the time() routine exists.  The time() routine is normaly
  3876. provided on C<UNIX> systems.
  3877.  
  3878. =item C<d_times>
  3879.  
  3880. From F<d_times.U>:
  3881.  
  3882. This variable conditionally defines the C<HAS_TIMES> symbol, which indicates
  3883. that the times() routine exists.  The times() routine is normaly
  3884. provided on C<UNIX> systems. You may have to include <sys/times.h>.
  3885.  
  3886. =item C<d_truncate>
  3887.  
  3888. From F<d_truncate.U>:
  3889.  
  3890. This variable conditionally defines C<HAS_TRUNCATE> if truncate() is
  3891. available to truncate files.
  3892.  
  3893. =item C<d_tzname>
  3894.  
  3895. From F<d_tzname.U>:
  3896.  
  3897. This variable conditionally defines C<HAS_TZNAME> if tzname[] is
  3898. available to access timezone names.
  3899.  
  3900. =item C<d_umask>
  3901.  
  3902. From F<d_umask.U>:
  3903.  
  3904. This variable conditionally defines the C<HAS_UMASK> symbol, which
  3905. indicates to the C program that the umask() routine is available.
  3906. to set and get the value of the file creation mask.
  3907.  
  3908. =item C<d_uname>
  3909.  
  3910. From F<d_gethname.U>:
  3911.  
  3912. This variable conditionally defines the C<HAS_UNAME> symbol, which
  3913. indicates to the C program that the uname() routine may be
  3914. used to derive the host name.
  3915.  
  3916. =item C<d_union_semun>
  3917.  
  3918. From F<d_union_semun.U>:
  3919.  
  3920. This variable conditionally defines C<HAS_UNION_SEMUN> if the
  3921. union semun is defined by including <sys/sem.h>.
  3922.  
  3923. =item C<d_ustat>
  3924.  
  3925. From F<d_ustat.U>:
  3926.  
  3927. This variable conditionally defines C<HAS_USTAT> if ustat() is
  3928. available to query file system statistics by dev_t.
  3929.  
  3930. =item C<d_vendorarch>
  3931.  
  3932. From F<vendorarch.U>:
  3933.  
  3934. This variable conditionally defined C<PERL_VENDORARCH>.
  3935.  
  3936. =item C<d_vendorbin>
  3937.  
  3938. From F<vendorbin.U>:
  3939.  
  3940. This variable conditionally defines C<PERL_VENDORBIN>.
  3941.  
  3942. =item C<d_vendorlib>
  3943.  
  3944. From F<vendorlib.U>:
  3945.  
  3946. This variable conditionally defines C<PERL_VENDORLIB>.
  3947.  
  3948. =item C<d_vfork>
  3949.  
  3950. From F<d_vfork.U>:
  3951.  
  3952. This variable conditionally defines the C<HAS_VFORK> symbol, which
  3953. indicates the vfork() routine is available.
  3954.  
  3955. =item C<d_void_closedir>
  3956.  
  3957. From F<d_closedir.U>:
  3958.  
  3959. This variable conditionally defines C<VOID_CLOSEDIR> if closedir()
  3960. does not return a value.
  3961.  
  3962. =item C<d_voidsig>
  3963.  
  3964. From F<d_voidsig.U>:
  3965.  
  3966. This variable conditionally defines C<VOIDSIG> if this system
  3967. declares "void (*signal(...))()" in F<signal.h>.  The old way was to
  3968. declare it as "int (*signal(...))()".
  3969.  
  3970. =item C<d_voidtty>
  3971.  
  3972. From F<i_sysioctl.U>:
  3973.  
  3974. This variable conditionally defines C<USE_IOCNOTTY> to indicate that the
  3975. ioctl() call with C<TIOCNOTTY> should be used to void tty association.
  3976. Otherwise (on C<USG> probably), it is enough to close the standard file
  3977. decriptors and do a setpgrp().
  3978.  
  3979. =item C<d_volatile>
  3980.  
  3981. From F<d_volatile.U>:
  3982.  
  3983. This variable conditionally defines the C<HASVOLATILE> symbol, which
  3984. indicates to the C program that this C compiler knows about the
  3985. volatile declaration.
  3986.  
  3987. =item C<d_vprintf>
  3988.  
  3989. From F<d_vprintf.U>:
  3990.  
  3991. This variable conditionally defines the C<HAS_VPRINTF> symbol, which
  3992. indicates to the C program that the vprintf() routine is available
  3993. to printf with a pointer to an argument list.
  3994.  
  3995. =item C<d_wait4>
  3996.  
  3997. From F<d_wait4.U>:
  3998.  
  3999. This variable conditionally defines the HAS_WAIT4 symbol, which
  4000. indicates the wait4() routine is available.
  4001.  
  4002. =item C<d_waitpid>
  4003.  
  4004. From F<d_waitpid.U>:
  4005.  
  4006. This variable conditionally defines C<HAS_WAITPID> if waitpid() is
  4007. available to wait for child process.
  4008.  
  4009. =item C<d_wcstombs>
  4010.  
  4011. From F<d_wcstombs.U>:
  4012.  
  4013. This variable conditionally defines the C<HAS_WCSTOMBS> symbol, which
  4014. indicates to the C program that the wcstombs() routine is available
  4015. to convert wide character strings to multibyte strings.
  4016.  
  4017. =item C<d_wctomb>
  4018.  
  4019. From F<d_wctomb.U>:
  4020.  
  4021. This variable conditionally defines the C<HAS_WCTOMB> symbol, which
  4022. indicates to the C program that the wctomb() routine is available
  4023. to convert a wide character to a multibyte.
  4024.  
  4025. =item C<d_xenix>
  4026.  
  4027. From F<Guess.U>:
  4028.  
  4029. This variable conditionally defines the symbol C<XENIX>, which alerts
  4030. the C program that it runs under Xenix.
  4031.  
  4032. =item C<date>
  4033.  
  4034. From F<Loc.U>:
  4035.  
  4036. This variable is used internally by Configure to determine the
  4037. full pathname (if any) of the date program.  After Configure runs,
  4038. the value is reset to a plain C<date> and is not useful.
  4039.  
  4040. =item C<db_hashtype>
  4041.  
  4042. From F<i_db.U>:
  4043.  
  4044. This variable contains the type of the hash structure element
  4045. in the <db.h> header file.  In older versions of C<DB>, it was
  4046. int, while in newer ones it is u_int32_t.
  4047.  
  4048. =item C<db_prefixtype>
  4049.  
  4050. From F<i_db.U>:
  4051.  
  4052. This variable contains the type of the prefix structure element
  4053. in the <db.h> header file.  In older versions of C<DB>, it was
  4054. int, while in newer ones it is size_t.
  4055.  
  4056. =item C<defvoidused>
  4057.  
  4058. From F<voidflags.U>:
  4059.  
  4060. This variable contains the default value of the C<VOIDUSED> symbol (15).
  4061.  
  4062. =item C<direntrytype>
  4063.  
  4064. From F<i_dirent.U>:
  4065.  
  4066. This symbol is set to C<struct direct> or C<struct dirent> depending on
  4067. whether dirent is available or not. You should use this pseudo type to
  4068. portably declare your directory entries.
  4069.  
  4070. =item C<dlext>
  4071.  
  4072. From F<dlext.U>:
  4073.  
  4074. This variable contains the extension that is to be used for the
  4075. dynamically loaded modules that perl generaties.
  4076.  
  4077. =item C<dlsrc>
  4078.  
  4079. From F<dlsrc.U>:
  4080.  
  4081. This variable contains the name of the dynamic loading file that
  4082. will be used with the package.
  4083.  
  4084. =item C<doublesize>
  4085.  
  4086. From F<doublesize.U>:
  4087.  
  4088. This variable contains the value of the C<DOUBLESIZE> symbol, which
  4089. indicates to the C program how many bytes there are in a double.
  4090.  
  4091. =item C<drand01>
  4092.  
  4093. From F<randfunc.U>:
  4094.  
  4095. Indicates the macro to be used to generate normalized
  4096. random numbers.  Uses randfunc, often divided by
  4097. (double) (((unsigned long) 1 << randbits)) in order to
  4098. normalize the result.
  4099. In C programs, the macro C<Drand01> is mapped to drand01.
  4100.  
  4101. =item C<dynamic_ext>
  4102.  
  4103. From F<Extensions.U>:
  4104.  
  4105. This variable holds a list of C<XS> extension files we want to
  4106. link dynamically into the package.  It is used by Makefile.
  4107.  
  4108. =back
  4109.  
  4110. =head2 e
  4111.  
  4112. =over
  4113.  
  4114. =item C<eagain>
  4115.  
  4116. From F<nblock_io.U>:
  4117.  
  4118. This variable bears the symbolic errno code set by read() when no
  4119. data is present on the file and non-blocking F<I/O> was enabled (otherwise,
  4120. read() blocks naturally).
  4121.  
  4122. =item C<ebcdic>
  4123.  
  4124. From F<ebcdic.U>:
  4125.  
  4126. This variable conditionally defines C<EBCDIC> if this
  4127. system uses C<EBCDIC> encoding.  Among other things, this
  4128. means that the character ranges are not contiguous.
  4129. See F<trnl.U>
  4130.  
  4131. =item C<echo>
  4132.  
  4133. From F<Loc.U>:
  4134.  
  4135. This variable is used internally by Configure to determine the
  4136. full pathname (if any) of the echo program.  After Configure runs,
  4137. the value is reset to a plain C<echo> and is not useful.
  4138.  
  4139. =item C<egrep>
  4140.  
  4141. From F<Loc.U>:
  4142.  
  4143. This variable is used internally by Configure to determine the
  4144. full pathname (if any) of the egrep program.  After Configure runs,
  4145. the value is reset to a plain C<egrep> and is not useful.
  4146.  
  4147. =item C<emacs>
  4148.  
  4149. From F<Loc.U>:
  4150.  
  4151. This variable is defined but not used by Configure.
  4152. The value is a plain '' and is not useful.
  4153.  
  4154. =item C<eunicefix>
  4155.  
  4156. From F<Init.U>:
  4157.  
  4158. When running under Eunice this variable contains a command which will
  4159. convert a shell script to the proper form of text file for it to be
  4160. executable by the shell.  On other systems it is a no-op.
  4161.  
  4162. =item C<exe_ext>
  4163.  
  4164. From F<Unix.U>:
  4165.  
  4166. This is an old synonym for _exe.
  4167.  
  4168. =item C<expr>
  4169.  
  4170. From F<Loc.U>:
  4171.  
  4172. This variable is used internally by Configure to determine the
  4173. full pathname (if any) of the expr program.  After Configure runs,
  4174. the value is reset to a plain C<expr> and is not useful.
  4175.  
  4176. =item C<extensions>
  4177.  
  4178. From F<Extensions.U>:
  4179.  
  4180. This variable holds a list of all extension files (both C<XS> and
  4181. non-xs linked into the package.  It is propagated to F<Config.pm>
  4182. and is typically used to test whether a particular extesion 
  4183. is available.
  4184.  
  4185. =back
  4186.  
  4187. =head2 f
  4188.  
  4189. =over
  4190.  
  4191. =item C<fflushall>
  4192.  
  4193. From F<fflushall.U>:
  4194.  
  4195. This symbol, if defined, tells that to flush
  4196. all pending stdio output one must loop through all
  4197. the stdio file handles stored in an array and fflush them.
  4198. Note that if fflushNULL is defined, fflushall will not
  4199. even be probed for and will be left undefined.
  4200.  
  4201. =item C<fflushNULL>
  4202.  
  4203. From F<fflushall.U>:
  4204.  
  4205. This symbol, if defined, tells that fflush(C<NULL>) does flush
  4206. all pending stdio output.
  4207.  
  4208. =item C<find>
  4209.  
  4210. From F<Loc.U>:
  4211.  
  4212. This variable is defined but not used by Configure.
  4213. The value is a plain '' and is not useful.
  4214.  
  4215. =item C<firstmakefile>
  4216.  
  4217. From F<Unix.U>:
  4218.  
  4219. This variable defines the first file searched by make.  On unix,
  4220. it is makefile (then Makefile).  On case-insensitive systems,
  4221. it might be something else.  This is only used to deal with
  4222. convoluted make depend tricks.
  4223.  
  4224. =item C<flex>
  4225.  
  4226. From F<Loc.U>:
  4227.  
  4228. This variable is defined but not used by Configure.
  4229. The value is a plain '' and is not useful.
  4230.  
  4231. =item C<fpossize>
  4232.  
  4233. From F<fpossize.U>:
  4234.  
  4235. This variable contains the size of a fpostype in bytes.
  4236.  
  4237. =item C<fpostype>
  4238.  
  4239. From F<fpostype.U>:
  4240.  
  4241. This variable defines Fpos_t to be something like fpos_t, long, 
  4242. uint, or whatever type is used to declare file positions in libc.
  4243.  
  4244. =item C<freetype>
  4245.  
  4246. From F<mallocsrc.U>:
  4247.  
  4248. This variable contains the return type of free().  It is usually
  4249. void, but occasionally int.
  4250.  
  4251. =item C<full_ar>
  4252.  
  4253. From F<Loc_ar.U>:
  4254.  
  4255. This variable contains the full pathname to C<ar>, whether or
  4256. not the user has specified C<portability>.  This is only used
  4257. in the F<Makefile.SH>.
  4258.  
  4259. =item C<full_csh>
  4260.  
  4261. From F<d_csh.U>:
  4262.  
  4263. This variable contains the full pathname to C<csh>, whether or
  4264. not the user has specified C<portability>.  This is only used
  4265. in the compiled C program, and we assume that all systems which
  4266. can share this executable will have the same full pathname to
  4267. F<csh.>
  4268.  
  4269. =item C<full_sed>
  4270.  
  4271. From F<Loc_sed.U>:
  4272.  
  4273. This variable contains the full pathname to C<sed>, whether or
  4274. not the user has specified C<portability>.  This is only used
  4275. in the compiled C program, and we assume that all systems which
  4276. can share this executable will have the same full pathname to
  4277. F<sed.>
  4278.  
  4279. =back
  4280.  
  4281. =head2 g
  4282.  
  4283. =over
  4284.  
  4285. =item C<gccosandvers>
  4286.  
  4287. From F<gccvers.U>:
  4288.  
  4289. If C<GNU> cc (gcc) is used, this variable the operating system and
  4290. version used to compile the gcc.  It is set to '' if not gcc,
  4291. or if nothing useful can be parsed as the os version.
  4292.  
  4293. =item C<gccversion>
  4294.  
  4295. From F<gccvers.U>:
  4296.  
  4297. If C<GNU> cc (gcc) is used, this variable holds C<1> or C<2> to 
  4298. indicate whether the compiler is version 1 or 2.  This is used in
  4299. setting some of the default cflags.  It is set to '' if not gcc.
  4300.  
  4301. =item C<gidformat>
  4302.  
  4303. From F<gidf.U>:
  4304.  
  4305. This variable contains the format string used for printing a Gid_t.
  4306.  
  4307. =item C<gidsign>
  4308.  
  4309. From F<gidsign.U>:
  4310.  
  4311. This variable contains the signedness of a gidtype.
  4312. 1 for unsigned, -1 for signed.
  4313.  
  4314. =item C<gidsize>
  4315.  
  4316. From F<gidsize.U>:
  4317.  
  4318. This variable contains the size of a gidtype in bytes.
  4319.  
  4320. =item C<gidtype>
  4321.  
  4322. From F<gidtype.U>:
  4323.  
  4324. This variable defines Gid_t to be something like gid_t, int,
  4325. ushort, or whatever type is used to declare the return type
  4326. of getgid().  Typically, it is the type of group ids in the kernel.
  4327.  
  4328. =item C<glibpth>
  4329.  
  4330. From F<libpth.U>:
  4331.  
  4332. This variable holds the general path (space-separated) used to
  4333. find libraries.  It may contain directories that do not exist on
  4334. this platform, libpth is the cleaned-up version.
  4335.  
  4336. =item C<grep>
  4337.  
  4338. From F<Loc.U>:
  4339.  
  4340. This variable is used internally by Configure to determine the
  4341. full pathname (if any) of the grep program.  After Configure runs,
  4342. the value is reset to a plain C<grep> and is not useful.
  4343.  
  4344. =item C<groupcat>
  4345.  
  4346. From F<nis.U>:
  4347.  
  4348. This variable contains a command that produces the text of the
  4349. F</etc/group> file.  This is normally "cat F</etc/group>", but can be
  4350. "ypcat group" when C<NIS> is used.
  4351. On some systems, such as os390, there may be no equivalent
  4352. command, in which case this variable is unset.
  4353.  
  4354. =item C<groupstype>
  4355.  
  4356. From F<groupstype.U>:
  4357.  
  4358. This variable defines Groups_t to be something like gid_t, int, 
  4359. ushort, or whatever type is used for the second argument to
  4360. getgroups() and setgroups().  Usually, this is the same as
  4361. gidtype (gid_t), but sometimes it isn't.
  4362.  
  4363. =item C<gzip>
  4364.  
  4365. From F<Loc.U>:
  4366.  
  4367. This variable is used internally by Configure to determine the
  4368. full pathname (if any) of the gzip program.  After Configure runs,
  4369. the value is reset to a plain C<gzip> and is not useful.
  4370.  
  4371. =back
  4372.  
  4373. =head2 h
  4374.  
  4375. =over
  4376.  
  4377. =item C<h_fcntl>
  4378.  
  4379. From F<h_fcntl.U>:
  4380.  
  4381. This is variable gets set in various places to tell i_fcntl that
  4382. <fcntl.h> should be included.
  4383.  
  4384. =item C<h_sysfile>
  4385.  
  4386. From F<h_sysfile.U>:
  4387.  
  4388. This is variable gets set in various places to tell i_sys_file that
  4389. <sys/file.h> should be included.
  4390.  
  4391. =item C<hint>
  4392.  
  4393. From F<Oldconfig.U>:
  4394.  
  4395. Gives the type of hints used for previous answers. May be one of
  4396. C<default>, C<recommended> or C<previous>.
  4397.  
  4398. =item C<hostcat>
  4399.  
  4400. From F<nis.U>:
  4401.  
  4402. This variable contains a command that produces the text of the
  4403. F</etc/hosts> file.  This is normally "cat F</etc/hosts>", but can be
  4404. "ypcat hosts" when C<NIS> is used.
  4405. On some systems, such as os390, there may be no equivalent
  4406. command, in which case this variable is unset.
  4407.  
  4408. =back
  4409.  
  4410. =head2 i
  4411.  
  4412. =over
  4413.  
  4414. =item C<i16size>
  4415.  
  4416. From F<perlxv.U>:
  4417.  
  4418. This variable is the size of an I16 in bytes.
  4419.  
  4420. =item C<i16type>
  4421.  
  4422. From F<perlxv.U>:
  4423.  
  4424. This variable contains the C type used for Perl's I16.
  4425.  
  4426. =item C<i32size>
  4427.  
  4428. From F<perlxv.U>:
  4429.  
  4430. This variable is the size of an I32 in bytes.
  4431.  
  4432. =item C<i32type>
  4433.  
  4434. From F<perlxv.U>:
  4435.  
  4436. This variable contains the C type used for Perl's I32.
  4437.  
  4438. =item C<i64size>
  4439.  
  4440. From F<perlxv.U>:
  4441.  
  4442. This variable is the size of an I64 in bytes.
  4443.  
  4444. =item C<i64type>
  4445.  
  4446. From F<perlxv.U>:
  4447.  
  4448. This variable contains the C type used for Perl's I64.
  4449.  
  4450. =item C<i8size>
  4451.  
  4452. From F<perlxv.U>:
  4453.  
  4454. This variable is the size of an I8 in bytes.
  4455.  
  4456. =item C<i8type>
  4457.  
  4458. From F<perlxv.U>:
  4459.  
  4460. This variable contains the C type used for Perl's I8.
  4461.  
  4462. =item C<i_arpainet>
  4463.  
  4464. From F<i_arpainet.U>:
  4465.  
  4466. This variable conditionally defines the C<I_ARPA_INET> symbol,
  4467. and indicates whether a C program should include <arpa/inet.h>.
  4468.  
  4469. =item C<i_bsdioctl>
  4470.  
  4471. From F<i_sysioctl.U>:
  4472.  
  4473. This variable conditionally defines the C<I_SYS_BSDIOCTL> symbol, which
  4474. indicates to the C program that <sys/bsdioctl.h> exists and should
  4475. be included.
  4476.  
  4477. =item C<i_db>
  4478.  
  4479. From F<i_db.U>:
  4480.  
  4481. This variable conditionally defines the C<I_DB> symbol, and indicates
  4482. whether a C program may include Berkeley's C<DB> include file <db.h>.
  4483.  
  4484. =item C<i_dbm>
  4485.  
  4486. From F<i_dbm.U>:
  4487.  
  4488. This variable conditionally defines the C<I_DBM> symbol, which
  4489. indicates to the C program that <dbm.h> exists and should
  4490. be included.
  4491.  
  4492. =item C<i_dirent>
  4493.  
  4494. From F<i_dirent.U>:
  4495.  
  4496. This variable conditionally defines C<I_DIRENT>, which indicates
  4497. to the C program that it should include <dirent.h>.
  4498.  
  4499. =item C<i_dld>
  4500.  
  4501. From F<i_dld.U>:
  4502.  
  4503. This variable conditionally defines the C<I_DLD> symbol, which
  4504. indicates to the C program that <dld.h> (C<GNU> dynamic loading)
  4505. exists and should be included.
  4506.  
  4507. =item C<i_dlfcn>
  4508.  
  4509. From F<i_dlfcn.U>:
  4510.  
  4511. This variable conditionally defines the C<I_DLFCN> symbol, which
  4512. indicates to the C program that <dlfcn.h> exists and should
  4513. be included.
  4514.  
  4515. =item C<i_fcntl>
  4516.  
  4517. From F<i_fcntl.U>:
  4518.  
  4519. This variable controls the value of C<I_FCNTL> (which tells
  4520. the C program to include <fcntl.h>).
  4521.  
  4522. =item C<i_float>
  4523.  
  4524. From F<i_float.U>:
  4525.  
  4526. This variable conditionally defines the C<I_FLOAT> symbol, and indicates
  4527. whether a C program may include <float.h> to get symbols like C<DBL_MAX>
  4528. or C<DBL_MIN>, F<i.e>. machine dependent floating point values.
  4529.  
  4530. =item C<i_gdbm>
  4531.  
  4532. From F<i_gdbm.U>:
  4533.  
  4534. This variable conditionally defines the C<I_GDBM> symbol, which
  4535. indicates to the C program that <gdbm.h> exists and should
  4536. be included.
  4537.  
  4538. =item C<i_grp>
  4539.  
  4540. From F<i_grp.U>:
  4541.  
  4542. This variable conditionally defines the C<I_GRP> symbol, and indicates
  4543. whether a C program should include <grp.h>.
  4544.  
  4545. =item C<i_iconv>
  4546.  
  4547. From F<i_iconv.U>:
  4548.  
  4549. This variable conditionally defines the C<I_ICONV> symbol, and indicates
  4550. whether a C program should include <iconv.h>.
  4551.  
  4552. =item C<i_ieeefp>
  4553.  
  4554. From F<i_ieeefp.U>:
  4555.  
  4556. This variable conditionally defines the C<I_IEEEFP> symbol, and indicates
  4557. whether a C program should include <ieeefp.h>.
  4558.  
  4559. =item C<i_inttypes>
  4560.  
  4561. From F<i_inttypes.U>:
  4562.  
  4563. This variable conditionally defines the C<I_INTTYPES> symbol,
  4564. and indicates whether a C program should include <inttypes.h>.
  4565.  
  4566. =item C<i_libutil>
  4567.  
  4568. From F<i_libutil.U>:
  4569.  
  4570. This variable conditionally defines the C<I_LIBUTIL> symbol, and indicates
  4571. whether a C program should include <libutil.h>.
  4572.  
  4573. =item C<i_limits>
  4574.  
  4575. From F<i_limits.U>:
  4576.  
  4577. This variable conditionally defines the C<I_LIMITS> symbol, and indicates
  4578. whether a C program may include <limits.h> to get symbols like C<WORD_BIT>
  4579. and friends.
  4580.  
  4581. =item C<i_locale>
  4582.  
  4583. From F<i_locale.U>:
  4584.  
  4585. This variable conditionally defines the C<I_LOCALE> symbol,
  4586. and indicates whether a C program should include <locale.h>.
  4587.  
  4588. =item C<i_machcthr>
  4589.  
  4590. From F<i_machcthr.U>:
  4591.  
  4592. This variable conditionally defines the C<I_MACH_CTHREADS> symbol,
  4593. and indicates whether a C program should include <mach/cthreads.h>.
  4594.  
  4595. =item C<i_malloc>
  4596.  
  4597. From F<i_malloc.U>:
  4598.  
  4599. This variable conditionally defines the C<I_MALLOC> symbol, and indicates
  4600. whether a C program should include <malloc.h>.
  4601.  
  4602. =item C<i_math>
  4603.  
  4604. From F<i_math.U>:
  4605.  
  4606. This variable conditionally defines the C<I_MATH> symbol, and indicates
  4607. whether a C program may include <math.h>.
  4608.  
  4609. =item C<i_memory>
  4610.  
  4611. From F<i_memory.U>:
  4612.  
  4613. This variable conditionally defines the C<I_MEMORY> symbol, and indicates
  4614. whether a C program should include <memory.h>.
  4615.  
  4616. =item C<i_mntent>
  4617.  
  4618. From F<i_mntent.U>:
  4619.  
  4620. This variable conditionally defines the C<I_MNTENT> symbol, and indicates
  4621. whether a C program should include <mntent.h>.
  4622.  
  4623. =item C<i_ndbm>
  4624.  
  4625. From F<i_ndbm.U>:
  4626.  
  4627. This variable conditionally defines the C<I_NDBM> symbol, which
  4628. indicates to the C program that <ndbm.h> exists and should
  4629. be included.
  4630.  
  4631. =item C<i_netdb>
  4632.  
  4633. From F<i_netdb.U>:
  4634.  
  4635. This variable conditionally defines the C<I_NETDB> symbol, and indicates
  4636. whether a C program should include <netdb.h>.
  4637.  
  4638. =item C<i_neterrno>
  4639.  
  4640. From F<i_neterrno.U>:
  4641.  
  4642. This variable conditionally defines the C<I_NET_ERRNO> symbol, which
  4643. indicates to the C program that <net/errno.h> exists and should
  4644. be included.
  4645.  
  4646. =item C<i_netinettcp>
  4647.  
  4648. From F<i_netinettcp.U>:
  4649.  
  4650. This variable conditionally defines the C<I_NETINET_TCP> symbol,
  4651. and indicates whether a C program should include <netinet/tcp.h>.
  4652.  
  4653. =item C<i_niin>
  4654.  
  4655. From F<i_niin.U>:
  4656.  
  4657. This variable conditionally defines C<I_NETINET_IN>, which indicates
  4658. to the C program that it should include <netinet/in.h>. Otherwise,
  4659. you may try <sys/in.h>.
  4660.  
  4661. =item C<i_poll>
  4662.  
  4663. From F<i_poll.U>:
  4664.  
  4665. This variable conditionally defines the C<I_POLL> symbol, and indicates
  4666. whether a C program should include <poll.h>.
  4667.  
  4668. =item C<i_prot>
  4669.  
  4670. From F<i_prot.U>:
  4671.  
  4672. This variable conditionally defines the C<I_PROT> symbol, and indicates
  4673. whether a C program should include <prot.h>.
  4674.  
  4675. =item C<i_pthread>
  4676.  
  4677. From F<i_pthread.U>:
  4678.  
  4679. This variable conditionally defines the C<I_PTHREAD> symbol,
  4680. and indicates whether a C program should include <pthread.h>.
  4681.  
  4682. =item C<i_pwd>
  4683.  
  4684. From F<i_pwd.U>:
  4685.  
  4686. This variable conditionally defines C<I_PWD>, which indicates
  4687. to the C program that it should include <pwd.h>.
  4688.  
  4689. =item C<i_rpcsvcdbm>
  4690.  
  4691. From F<i_dbm.U>:
  4692.  
  4693. This variable conditionally defines the C<I_RPCSVC_DBM> symbol, which
  4694. indicates to the C program that <rpcsvc/dbm.h> exists and should
  4695. be included.  Some System V systems might need this instead of <dbm.h>.
  4696.  
  4697. =item C<i_sfio>
  4698.  
  4699. From F<i_sfio.U>:
  4700.  
  4701. This variable conditionally defines the C<I_SFIO> symbol,
  4702. and indicates whether a C program should include <sfio.h>.
  4703.  
  4704. =item C<i_sgtty>
  4705.  
  4706. From F<i_termio.U>:
  4707.  
  4708. This variable conditionally defines the C<I_SGTTY> symbol, which
  4709. indicates to the C program that it should include <sgtty.h> rather
  4710. than <termio.h>.
  4711.  
  4712. =item C<i_shadow>
  4713.  
  4714. From F<i_shadow.U>:
  4715.  
  4716. This variable conditionally defines the C<I_SHADOW> symbol, and indicates
  4717. whether a C program should include <shadow.h>.
  4718.  
  4719. =item C<i_socks>
  4720.  
  4721. From F<i_socks.U>:
  4722.  
  4723. This variable conditionally defines the C<I_SOCKS> symbol, and indicates
  4724. whether a C program should include <socks.h>.
  4725.  
  4726. =item C<i_stdarg>
  4727.  
  4728. From F<i_varhdr.U>:
  4729.  
  4730. This variable conditionally defines the C<I_STDARG> symbol, which
  4731. indicates to the C program that <stdarg.h> exists and should
  4732. be included.
  4733.  
  4734. =item C<i_stddef>
  4735.  
  4736. From F<i_stddef.U>:
  4737.  
  4738. This variable conditionally defines the C<I_STDDEF> symbol, which
  4739. indicates to the C program that <stddef.h> exists and should
  4740. be included.
  4741.  
  4742. =item C<i_stdlib>
  4743.  
  4744. From F<i_stdlib.U>:
  4745.  
  4746. This variable conditionally defines the C<I_STDLIB> symbol, which
  4747. indicates to the C program that <stdlib.h> exists and should
  4748. be included.
  4749.  
  4750. =item C<i_string>
  4751.  
  4752. From F<i_string.U>:
  4753.  
  4754. This variable conditionally defines the C<I_STRING> symbol, which
  4755. indicates that <string.h> should be included rather than <strings.h>.
  4756.  
  4757. =item C<i_sunmath>
  4758.  
  4759. From F<i_sunmath.U>:
  4760.  
  4761. This variable conditionally defines the C<I_SUNMATH> symbol, and indicates
  4762. whether a C program should include <sunmath.h>.
  4763.  
  4764. =item C<i_sysaccess>
  4765.  
  4766. From F<i_sysaccess.U>:
  4767.  
  4768. This variable conditionally defines the C<I_SYS_ACCESS> symbol,
  4769. and indicates whether a C program should include <sys/access.h>.
  4770.  
  4771. =item C<i_sysdir>
  4772.  
  4773. From F<i_sysdir.U>:
  4774.  
  4775. This variable conditionally defines the C<I_SYS_DIR> symbol, and indicates
  4776. whether a C program should include <sys/dir.h>.
  4777.  
  4778. =item C<i_sysfile>
  4779.  
  4780. From F<i_sysfile.U>:
  4781.  
  4782. This variable conditionally defines the C<I_SYS_FILE> symbol, and indicates
  4783. whether a C program should include <sys/file.h> to get C<R_OK> and friends.
  4784.  
  4785. =item C<i_sysfilio>
  4786.  
  4787. From F<i_sysioctl.U>:
  4788.  
  4789. This variable conditionally defines the C<I_SYS_FILIO> symbol, which
  4790. indicates to the C program that <sys/filio.h> exists and should
  4791. be included in preference to <sys/ioctl.h>.
  4792.  
  4793. =item C<i_sysin>
  4794.  
  4795. From F<i_niin.U>:
  4796.  
  4797. This variable conditionally defines C<I_SYS_IN>, which indicates
  4798. to the C program that it should include <sys/in.h> instead of
  4799. <netinet/in.h>.
  4800.  
  4801. =item C<i_sysioctl>
  4802.  
  4803. From F<i_sysioctl.U>:
  4804.  
  4805. This variable conditionally defines the C<I_SYS_IOCTL> symbol, which
  4806. indicates to the C program that <sys/ioctl.h> exists and should
  4807. be included.
  4808.  
  4809. =item C<i_syslog>
  4810.  
  4811. From F<i_syslog.U>:
  4812.  
  4813. This variable conditionally defines the C<I_SYSLOG> symbol,
  4814. and indicates whether a C program should include <syslog.h>.
  4815.  
  4816. =item C<i_sysmman>
  4817.  
  4818. From F<i_sysmman.U>:
  4819.  
  4820. This variable conditionally defines the C<I_SYS_MMAN> symbol, and
  4821. indicates whether a C program should include <sys/mman.h>.
  4822.  
  4823. =item C<i_sysmode>
  4824.  
  4825. From F<i_sysmode.U>:
  4826.  
  4827. This variable conditionally defines the C<I_SYSMODE> symbol,
  4828. and indicates whether a C program should include <sys/mode.h>.
  4829.  
  4830. =item C<i_sysmount>
  4831.  
  4832. From F<i_sysmount.U>:
  4833.  
  4834. This variable conditionally defines the C<I_SYSMOUNT> symbol,
  4835. and indicates whether a C program should include <sys/mount.h>.
  4836.  
  4837. =item C<i_sysndir>
  4838.  
  4839. From F<i_sysndir.U>:
  4840.  
  4841. This variable conditionally defines the C<I_SYS_NDIR> symbol, and indicates
  4842. whether a C program should include <sys/ndir.h>.
  4843.  
  4844. =item C<i_sysparam>
  4845.  
  4846. From F<i_sysparam.U>:
  4847.  
  4848. This variable conditionally defines the C<I_SYS_PARAM> symbol, and indicates
  4849. whether a C program should include <sys/param.h>.
  4850.  
  4851. =item C<i_sysresrc>
  4852.  
  4853. From F<i_sysresrc.U>:
  4854.  
  4855. This variable conditionally defines the C<I_SYS_RESOURCE> symbol,
  4856. and indicates whether a C program should include <sys/resource.h>.
  4857.  
  4858. =item C<i_syssecrt>
  4859.  
  4860. From F<i_syssecrt.U>:
  4861.  
  4862. This variable conditionally defines the C<I_SYS_SECURITY> symbol,
  4863. and indicates whether a C program should include <sys/security.h>.
  4864.  
  4865. =item C<i_sysselct>
  4866.  
  4867. From F<i_sysselct.U>:
  4868.  
  4869. This variable conditionally defines C<I_SYS_SELECT>, which indicates
  4870. to the C program that it should include <sys/select.h> in order to
  4871. get the definition of struct timeval.
  4872.  
  4873. =item C<i_syssockio>
  4874.  
  4875. From F<i_sysioctl.U>:
  4876.  
  4877. This variable conditionally defines C<I_SYS_SOCKIO> to indicate to the
  4878. C program that socket ioctl codes may be found in <sys/sockio.h>
  4879. instead of <sys/ioctl.h>.
  4880.  
  4881. =item C<i_sysstat>
  4882.  
  4883. From F<i_sysstat.U>:
  4884.  
  4885. This variable conditionally defines the C<I_SYS_STAT> symbol,
  4886. and indicates whether a C program should include <sys/stat.h>.
  4887.  
  4888. =item C<i_sysstatfs>
  4889.  
  4890. From F<i_sysstatfs.U>:
  4891.  
  4892. This variable conditionally defines the C<I_SYSSTATFS> symbol,
  4893. and indicates whether a C program should include <sys/statfs.h>.
  4894.  
  4895. =item C<i_sysstatvfs>
  4896.  
  4897. From F<i_sysstatvfs.U>:
  4898.  
  4899. This variable conditionally defines the C<I_SYSSTATVFS> symbol,
  4900. and indicates whether a C program should include <sys/statvfs.h>.
  4901.  
  4902. =item C<i_systime>
  4903.  
  4904. From F<i_time.U>:
  4905.  
  4906. This variable conditionally defines C<I_SYS_TIME>, which indicates
  4907. to the C program that it should include <sys/time.h>.
  4908.  
  4909. =item C<i_systimek>
  4910.  
  4911. From F<i_time.U>:
  4912.  
  4913. This variable conditionally defines C<I_SYS_TIME_KERNEL>, which
  4914. indicates to the C program that it should include <sys/time.h>
  4915. with C<KERNEL> defined.
  4916.  
  4917. =item C<i_systimes>
  4918.  
  4919. From F<i_systimes.U>:
  4920.  
  4921. This variable conditionally defines the C<I_SYS_TIMES> symbol, and indicates
  4922. whether a C program should include <sys/times.h>.
  4923.  
  4924. =item C<i_systypes>
  4925.  
  4926. From F<i_systypes.U>:
  4927.  
  4928. This variable conditionally defines the C<I_SYS_TYPES> symbol,
  4929. and indicates whether a C program should include <sys/types.h>.
  4930.  
  4931. =item C<i_sysuio>
  4932.  
  4933. From F<i_sysuio.U>:
  4934.  
  4935. This variable conditionally defines the C<I_SYSUIO> symbol, and indicates
  4936. whether a C program should include <sys/uio.h>.
  4937.  
  4938. =item C<i_sysun>
  4939.  
  4940. From F<i_sysun.U>:
  4941.  
  4942. This variable conditionally defines C<I_SYS_UN>, which indicates
  4943. to the C program that it should include <sys/un.h> to get C<UNIX>
  4944. domain socket definitions.
  4945.  
  4946. =item C<i_sysutsname>
  4947.  
  4948. From F<i_sysutsname.U>:
  4949.  
  4950. This variable conditionally defines the C<I_SYSUTSNAME> symbol,
  4951. and indicates whether a C program should include <sys/utsname.h>.
  4952.  
  4953. =item C<i_sysvfs>
  4954.  
  4955. From F<i_sysvfs.U>:
  4956.  
  4957. This variable conditionally defines the C<I_SYSVFS> symbol,
  4958. and indicates whether a C program should include <sys/vfs.h>.
  4959.  
  4960. =item C<i_syswait>
  4961.  
  4962. From F<i_syswait.U>:
  4963.  
  4964. This variable conditionally defines C<I_SYS_WAIT>, which indicates
  4965. to the C program that it should include <sys/wait.h>.
  4966.  
  4967. =item C<i_termio>
  4968.  
  4969. From F<i_termio.U>:
  4970.  
  4971. This variable conditionally defines the C<I_TERMIO> symbol, which
  4972. indicates to the C program that it should include <termio.h> rather
  4973. than <sgtty.h>.
  4974.  
  4975. =item C<i_termios>
  4976.  
  4977. From F<i_termio.U>:
  4978.  
  4979. This variable conditionally defines the C<I_TERMIOS> symbol, which
  4980. indicates to the C program that the C<POSIX> <termios.h> file is
  4981. to be included.
  4982.  
  4983. =item C<i_time>
  4984.  
  4985. From F<i_time.U>:
  4986.  
  4987. This variable conditionally defines C<I_TIME>, which indicates
  4988. to the C program that it should include <time.h>.
  4989.  
  4990. =item C<i_unistd>
  4991.  
  4992. From F<i_unistd.U>:
  4993.  
  4994. This variable conditionally defines the C<I_UNISTD> symbol, and indicates
  4995. whether a C program should include <unistd.h>.
  4996.  
  4997. =item C<i_ustat>
  4998.  
  4999. From F<i_ustat.U>:
  5000.  
  5001. This variable conditionally defines the C<I_USTAT> symbol, and indicates
  5002. whether a C program should include <ustat.h>.
  5003.  
  5004. =item C<i_utime>
  5005.  
  5006. From F<i_utime.U>:
  5007.  
  5008. This variable conditionally defines the C<I_UTIME> symbol, and indicates
  5009. whether a C program should include <utime.h>.
  5010.  
  5011. =item C<i_values>
  5012.  
  5013. From F<i_values.U>:
  5014.  
  5015. This variable conditionally defines the C<I_VALUES> symbol, and indicates
  5016. whether a C program may include <values.h> to get symbols like C<MAXLONG>
  5017. and friends.
  5018.  
  5019. =item C<i_varargs>
  5020.  
  5021. From F<i_varhdr.U>:
  5022.  
  5023. This variable conditionally defines C<I_VARARGS>, which indicates
  5024. to the C program that it should include <varargs.h>.
  5025.  
  5026. =item C<i_varhdr>
  5027.  
  5028. From F<i_varhdr.U>:
  5029.  
  5030. Contains the name of the header to be included to get va_dcl definition.
  5031. Typically one of F<varargs.h> or F<stdarg.h>.
  5032.  
  5033. =item C<i_vfork>
  5034.  
  5035. From F<i_vfork.U>:
  5036.  
  5037. This variable conditionally defines the C<I_VFORK> symbol, and indicates
  5038. whether a C program should include F<vfork.h>.
  5039.  
  5040. =item C<ignore_versioned_solibs>
  5041.  
  5042. From F<libs.U>:
  5043.  
  5044. This variable should be non-empty if non-versioned shared
  5045. libraries (F<libfoo.so.x.y>) are to be ignored (because they
  5046. cannot be linked against).
  5047.  
  5048. =item C<inc_version_list>
  5049.  
  5050. From F<inc_version_list.U>:
  5051.  
  5052. This variable specifies the list of subdirectories in over
  5053. which F<perl.c>:incpush() and F<lib/lib.pm> will automatically
  5054. search when adding directories to @C<INC>.  The elements in
  5055. the list are separated by spaces.  This is only useful
  5056. if you have a perl library directory tree structured like the
  5057. default one.  See C<INSTALL> for how this works.  The versioned
  5058. site_perl directory was introduced in 5.005, so that is the
  5059. lowest possible value.
  5060.  
  5061. =item C<inc_version_list_init>
  5062.  
  5063. From F<inc_version_list.U>:
  5064.  
  5065. This variable holds the same list as inc_version_list, but
  5066. each item is enclosed in double quotes and separated by commas, 
  5067. suitable for use in the C<PERL_INC_VERSION_LIST> initialization.
  5068.  
  5069. =item C<incpath>
  5070.  
  5071. From F<usrinc.U>:
  5072.  
  5073. This variable must preceed the normal include path to get hte
  5074. right one, as in F<$F<incpath/usr/include>> or F<$F<incpath/usr/lib>>.
  5075. Value can be "" or F</bsd43> on mips.
  5076.  
  5077. =item C<inews>
  5078.  
  5079. From F<Loc.U>:
  5080.  
  5081. This variable is defined but not used by Configure.
  5082. The value is a plain '' and is not useful.
  5083.  
  5084. =item C<installarchlib>
  5085.  
  5086. From F<archlib.U>:
  5087.  
  5088. This variable is really the same as archlibexp but may differ on
  5089. those systems using C<AFS>. For extra portability, only this variable
  5090. should be used in makefiles.
  5091.  
  5092. =item C<installbin>
  5093.  
  5094. From F<bin.U>:
  5095.  
  5096. This variable is the same as binexp unless C<AFS> is running in which case
  5097. the user is explicitely prompted for it. This variable should always
  5098. be used in your makefiles for maximum portability.
  5099.  
  5100. =item C<installman1dir>
  5101.  
  5102. From F<man1dir.U>:
  5103.  
  5104. This variable is really the same as man1direxp, unless you are using
  5105. C<AFS> in which case it points to the F<read/write> location whereas
  5106. man1direxp only points to the read-only access location. For extra
  5107. portability, you should only use this variable within your makefiles.
  5108.  
  5109. =item C<installman3dir>
  5110.  
  5111. From F<man3dir.U>:
  5112.  
  5113. This variable is really the same as man3direxp, unless you are using
  5114. C<AFS> in which case it points to the F<read/write> location whereas
  5115. man3direxp only points to the read-only access location. For extra
  5116. portability, you should only use this variable within your makefiles.
  5117.  
  5118. =item C<installprefix>
  5119.  
  5120. From F<installprefix.U>:
  5121.  
  5122. This variable holds the name of the directory below which 
  5123. "make install" will install the package.  For most users, this
  5124. is the same as prefix.  However, it is useful for
  5125. installing the software into a different (usually temporary)
  5126. location after which it can be bundled up and moved somehow
  5127. to the final location specified by prefix.
  5128.  
  5129. =item C<installprefixexp>
  5130.  
  5131. From F<installprefix.U>:
  5132.  
  5133. This variable holds the full absolute path of installprefix
  5134. with all F<~>-expansion done.
  5135.  
  5136. =item C<installprivlib>
  5137.  
  5138. From F<privlib.U>:
  5139.  
  5140. This variable is really the same as privlibexp but may differ on
  5141. those systems using C<AFS>. For extra portability, only this variable
  5142. should be used in makefiles.
  5143.  
  5144. =item C<installscript>
  5145.  
  5146. From F<scriptdir.U>:
  5147.  
  5148. This variable is usually the same as scriptdirexp, unless you are on
  5149. a system running C<AFS>, in which case they may differ slightly. You
  5150. should always use this variable within your makefiles for portability.
  5151.  
  5152. =item C<installsitearch>
  5153.  
  5154. From F<sitearch.U>:
  5155.  
  5156. This variable is really the same as sitearchexp but may differ on
  5157. those systems using C<AFS>. For extra portability, only this variable
  5158. should be used in makefiles.
  5159.  
  5160. =item C<installsitebin>
  5161.  
  5162. From F<sitebin.U>:
  5163.  
  5164. This variable is usually the same as sitebinexp, unless you are on
  5165. a system running C<AFS>, in which case they may differ slightly. You
  5166. should always use this variable within your makefiles for portability.
  5167.  
  5168. =item C<installsitelib>
  5169.  
  5170. From F<sitelib.U>:
  5171.  
  5172. This variable is really the same as sitelibexp but may differ on
  5173. those systems using C<AFS>. For extra portability, only this variable
  5174. should be used in makefiles.
  5175.  
  5176. =item C<installstyle>
  5177.  
  5178. From F<installstyle.U>:
  5179.  
  5180. This variable describes the C<style> of the perl installation.
  5181. This is intended to be useful for tools that need to
  5182. manipulate entire perl distributions.  Perl itself doesn't use
  5183. this to find its libraries -- the library directories are
  5184. stored directly in F<Config.pm>.  Currently, there are only two
  5185. styles:  C<lib> and F<lib/perl5>.  The default library locations
  5186. (e.g. privlib, sitelib) are either $F<prefix/lib> or
  5187. $F<prefix/lib/perl5>.  The former is useful if $prefix is a
  5188. directory dedicated to perl (e.g. F</opt/perl>), while the latter
  5189. is useful if $prefix is shared by many packages, e.g. if
  5190. $prefix=F</usr/local>.
  5191.  
  5192.     This may later be extended to include other information, so
  5193.  
  5194.     be careful with pattern-matching on the results.
  5195.  
  5196.     For compatibility with F<perl5.005> and earlier, the default
  5197.  
  5198.     setting is based on whether or not $prefix contains the string
  5199. C<perl>.
  5200.  
  5201. =item C<installusrbinperl>
  5202.  
  5203. From F<instubperl.U>:
  5204.  
  5205. This variable tells whether Perl should be installed also as
  5206. F</usr/bin/perl> in addition to
  5207. $F<installbin/perl>
  5208.  
  5209. =item C<installvendorarch>
  5210.  
  5211. From F<vendorarch.U>:
  5212.  
  5213. This variable is really the same as vendorarchexp but may differ on
  5214. those systems using C<AFS>. For extra portability, only this variable
  5215. should be used in makefiles.
  5216.  
  5217. =item C<installvendorbin>
  5218.  
  5219. From F<vendorbin.U>:
  5220.  
  5221. This variable is really the same as vendorbinexp but may differ on
  5222. those systems using C<AFS>. For extra portability, only this variable
  5223. should be used in makefiles.
  5224.  
  5225. =item C<installvendorlib>
  5226.  
  5227. From F<vendorlib.U>:
  5228.  
  5229. This variable is really the same as vendorlibexp but may differ on
  5230. those systems using C<AFS>. For extra portability, only this variable
  5231. should be used in makefiles.
  5232.  
  5233. =item C<intsize>
  5234.  
  5235. From F<intsize.U>:
  5236.  
  5237. This variable contains the value of the C<INTSIZE> symbol, which
  5238. indicates to the C program how many bytes there are in an int.
  5239.  
  5240. =item C<issymlink>
  5241.  
  5242. From F<issymlink.U>:
  5243.  
  5244. This variable holds the test command to test for a symbolic link
  5245. (if they are supported).  Typical values include C<test -h> and
  5246. C<test -L>.
  5247.  
  5248. =item C<ivdformat>
  5249.  
  5250. From F<perlxvf.U>:
  5251.  
  5252. This variable contains the format string used for printing
  5253. a Perl C<IV> as a signed decimal integer. 
  5254.  
  5255. =item C<ivsize>
  5256.  
  5257. From F<perlxv.U>:
  5258.  
  5259. This variable is the size of an C<IV> in bytes.
  5260.  
  5261. =item C<ivtype>
  5262.  
  5263. From F<perlxv.U>:
  5264.  
  5265. This variable contains the C type used for Perl's C<IV>.
  5266.  
  5267. =back
  5268.  
  5269. =head2 k
  5270.  
  5271. =over
  5272.  
  5273. =item C<known_extensions>
  5274.  
  5275. From F<Extensions.U>:
  5276.  
  5277. This variable holds a list of all C<XS> extensions included in 
  5278. the package.
  5279.  
  5280. =item C<ksh>
  5281.  
  5282. From F<Loc.U>:
  5283.  
  5284. This variable is defined but not used by Configure.
  5285. The value is a plain '' and is not useful.
  5286.  
  5287. =back
  5288.  
  5289. =head2 l
  5290.  
  5291. =over
  5292.  
  5293. =item C<ld>
  5294.  
  5295. From F<dlsrc.U>:
  5296.  
  5297. This variable indicates the program to be used to link
  5298. libraries for dynamic loading.  On some systems, it is C<ld>.
  5299. On C<ELF> systems, it should be $cc.  Mostly, we'll try to respect
  5300. the hint file setting.
  5301.  
  5302. =item C<lddlflags>
  5303.  
  5304. From F<dlsrc.U>:
  5305.  
  5306. This variable contains any special flags that might need to be
  5307. passed to $ld to create a shared library suitable for dynamic
  5308. loading.  It is up to the makefile to use it.  For hpux, it
  5309. should be C<-b>.  For sunos 4.1, it is empty.
  5310.  
  5311. =item C<ldflags>
  5312.  
  5313. From F<ccflags.U>:
  5314.  
  5315. This variable contains any additional C loader flags desired by
  5316. the user.  It is up to the Makefile to use this.
  5317.  
  5318. =item C<ldflags_uselargefiles>
  5319.  
  5320. From F<uselfs.U>:
  5321.  
  5322. This variable contains the loader flags needed by large file builds
  5323. and added to ldflags by hints files.
  5324.  
  5325. =item C<ldlibpthname>
  5326.  
  5327. From F<libperl.U>:
  5328.  
  5329. This variable holds the name of the shared library
  5330. search path, often C<LD_LIBRARY_PATH>.  To get an empty
  5331. string, the hints file must set this to C<none>.
  5332.  
  5333. =item C<less>
  5334.  
  5335. From F<Loc.U>:
  5336.  
  5337. This variable is used internally by Configure to determine the
  5338. full pathname (if any) of the less program.  After Configure runs,
  5339. the value is reset to a plain C<less> and is not useful.
  5340.  
  5341. =item C<lib_ext>
  5342.  
  5343. From F<Unix.U>:
  5344.  
  5345. This is an old synonym for _a.
  5346.  
  5347. =item C<libc>
  5348.  
  5349. From F<libc.U>:
  5350.  
  5351. This variable contains the location of the C library.
  5352.  
  5353. =item C<libperl>
  5354.  
  5355. From F<libperl.U>:
  5356.  
  5357. The perl executable is obtained by linking F<perlmain.c> with
  5358. libperl, any static extensions (usually just DynaLoader),
  5359. and any other libraries needed on this system.  libperl
  5360. is usually F<libperl.a>, but can also be F<libperl.so.xxx> if
  5361. the user wishes to build a perl executable with a shared
  5362. library.
  5363.  
  5364. =item C<libpth>
  5365.  
  5366. From F<libpth.U>:
  5367.  
  5368. This variable holds the general path (space-separated) used to find
  5369. libraries. It is intended to be used by other units.
  5370.  
  5371. =item C<libs>
  5372.  
  5373. From F<libs.U>:
  5374.  
  5375. This variable holds the additional libraries we want to use.
  5376. It is up to the Makefile to deal with it.
  5377.  
  5378. =item C<libsdirs>
  5379.  
  5380. From F<libs.U>:
  5381.  
  5382. This variable holds the directory names aka dirnames of the libraries
  5383. we found and accepted, duplicates are removed.
  5384.  
  5385. =item C<libsfiles>
  5386.  
  5387. From F<libs.U>:
  5388.  
  5389. This variable holds the filenames aka basenames of the libraries
  5390. we found and accepted.
  5391.  
  5392. =item C<libsfound>
  5393.  
  5394. From F<libs.U>:
  5395.  
  5396. This variable holds the full pathnames of the libraries
  5397. we found and accepted.
  5398.  
  5399. =item C<libspath>
  5400.  
  5401. From F<libs.U>:
  5402.  
  5403. This variable holds the directory names probed for libraries.
  5404.  
  5405. =item C<libswanted>
  5406.  
  5407. From F<Myinit.U>:
  5408.  
  5409. This variable holds a list of all the libraries we want to
  5410. search.  The order is chosen to pick up the c library
  5411. ahead of ucb or bsd libraries for SVR4.
  5412.  
  5413. =item C<libswanted_uselargefiles>
  5414.  
  5415. From F<uselfs.U>:
  5416.  
  5417. This variable contains the libraries needed by large file builds
  5418. and added to ldflags by hints files.  It is a space separated list
  5419. of the library names without the C<lib> prefix or any suffix, just
  5420. like F<libswanted.>.
  5421.  
  5422. =item C<line>
  5423.  
  5424. From F<Loc.U>:
  5425.  
  5426. This variable is defined but not used by Configure.
  5427. The value is a plain '' and is not useful.
  5428.  
  5429. =item C<lint>
  5430.  
  5431. From F<Loc.U>:
  5432.  
  5433. This variable is defined but not used by Configure.
  5434. The value is a plain '' and is not useful.
  5435.  
  5436. =item C<lkflags>
  5437.  
  5438. From F<ccflags.U>:
  5439.  
  5440. This variable contains any additional C partial linker flags desired by
  5441. the user.  It is up to the Makefile to use this.
  5442.  
  5443. =item C<ln>
  5444.  
  5445. From F<Loc.U>:
  5446.  
  5447. This variable is used internally by Configure to determine the
  5448. full pathname (if any) of the ln program.  After Configure runs,
  5449. the value is reset to a plain C<ln> and is not useful.
  5450.  
  5451. =item C<lns>
  5452.  
  5453. From F<lns.U>:
  5454.  
  5455. This variable holds the name of the command to make 
  5456. symbolic links (if they are supported).  It can be used
  5457. in the Makefile. It is either C<ln -s> or C<ln>
  5458.  
  5459. =item C<locincpth>
  5460.  
  5461. From F<ccflags.U>:
  5462.  
  5463. This variable contains a list of additional directories to be
  5464. searched by the compiler.  The appropriate C<-I> directives will
  5465. be added to ccflags.  This is intended to simplify setting
  5466. local directories from the Configure command line.
  5467. It's not much, but it parallels the loclibpth stuff in F<libpth.U>.
  5468.  
  5469. =item C<loclibpth>
  5470.  
  5471. From F<libpth.U>:
  5472.  
  5473. This variable holds the paths (space-separated) used to find local
  5474. libraries.  It is prepended to libpth, and is intended to be easily
  5475. set from the command line.
  5476.  
  5477. =item C<longdblsize>
  5478.  
  5479. From F<d_longdbl.U>:
  5480.  
  5481. This variable contains the value of the C<LONG_DOUBLESIZE> symbol, which
  5482. indicates to the C program how many bytes there are in a long double,
  5483. if this system supports long doubles.
  5484.  
  5485. =item C<longlongsize>
  5486.  
  5487. From F<d_longlong.U>:
  5488.  
  5489. This variable contains the value of the C<LONGLONGSIZE> symbol, which
  5490. indicates to the C program how many bytes there are in a long long,
  5491. if this system supports long long.
  5492.  
  5493. =item C<longsize>
  5494.  
  5495. From F<intsize.U>:
  5496.  
  5497. This variable contains the value of the C<LONGSIZE> symbol, which
  5498. indicates to the C program how many bytes there are in a long.
  5499.  
  5500. =item C<lp>
  5501.  
  5502. From F<Loc.U>:
  5503.  
  5504. This variable is defined but not used by Configure.
  5505. The value is a plain '' and is not useful.
  5506.  
  5507. =item C<lpr>
  5508.  
  5509. From F<Loc.U>:
  5510.  
  5511. This variable is defined but not used by Configure.
  5512. The value is a plain '' and is not useful.
  5513.  
  5514. =item C<ls>
  5515.  
  5516. From F<Loc.U>:
  5517.  
  5518. This variable is used internally by Configure to determine the
  5519. full pathname (if any) of the ls program.  After Configure runs,
  5520. the value is reset to a plain C<ls> and is not useful.
  5521.  
  5522. =item C<lseeksize>
  5523.  
  5524. From F<lseektype.U>:
  5525.  
  5526. This variable defines lseektype to be something like off_t, long, 
  5527. or whatever type is used to declare lseek offset's type in the
  5528. kernel (which also appears to be lseek's return type).
  5529.  
  5530. =item C<lseektype>
  5531.  
  5532. From F<lseektype.U>:
  5533.  
  5534. This variable defines lseektype to be something like off_t, long, 
  5535. or whatever type is used to declare lseek offset's type in the
  5536. kernel (which also appears to be lseek's return type).
  5537.  
  5538. =back
  5539.  
  5540. =head2 m
  5541.  
  5542. =over
  5543.  
  5544. =item C<mail>
  5545.  
  5546. From F<Loc.U>:
  5547.  
  5548. This variable is defined but not used by Configure.
  5549. The value is a plain '' and is not useful.
  5550.  
  5551. =item C<mailx>
  5552.  
  5553. From F<Loc.U>:
  5554.  
  5555. This variable is defined but not used by Configure.
  5556. The value is a plain '' and is not useful.
  5557.  
  5558. =item C<make>
  5559.  
  5560. From F<Loc.U>:
  5561.  
  5562. This variable is used internally by Configure to determine the
  5563. full pathname (if any) of the make program.  After Configure runs,
  5564. the value is reset to a plain C<make> and is not useful.
  5565.  
  5566. =item C<make_set_make>
  5567.  
  5568. From F<make.U>:
  5569.  
  5570. Some versions of C<make> set the variable C<MAKE>.  Others do not.
  5571. This variable contains the string to be included in F<Makefile.SH>
  5572. so that C<MAKE> is set if needed, and not if not needed.
  5573. Possible values are:
  5574. make_set_make=C<#>        # If your make program handles this for you,
  5575. make_set_make=C<MAKE=$make>    # if it doesn't.
  5576. I used a comment character so that we can distinguish a
  5577. C<set> value (from a previous F<config.sh> or Configure C<-D> option)
  5578. from an uncomputed value.
  5579.  
  5580. =item C<mallocobj>
  5581.  
  5582. From F<mallocsrc.U>:
  5583.  
  5584. This variable contains the name of the F<malloc.o> that this package
  5585. generates, if that F<malloc.o> is preferred over the system malloc.
  5586. Otherwise the value is null.  This variable is intended for generating
  5587. Makefiles.  See mallocsrc.
  5588.  
  5589. =item C<mallocsrc>
  5590.  
  5591. From F<mallocsrc.U>:
  5592.  
  5593. This variable contains the name of the F<malloc.c> that comes with
  5594. the package, if that F<malloc.c> is preferred over the system malloc.
  5595. Otherwise the value is null.  This variable is intended for generating
  5596. Makefiles.
  5597.  
  5598. =item C<malloctype>
  5599.  
  5600. From F<mallocsrc.U>:
  5601.  
  5602. This variable contains the kind of ptr returned by malloc and realloc.
  5603.  
  5604. =item C<man1dir>
  5605.  
  5606. From F<man1dir.U>:
  5607.  
  5608. This variable contains the name of the directory in which manual
  5609. source pages are to be put.  It is the responsibility of the
  5610. F<Makefile.SH> to get the value of this into the proper command.
  5611. You must be prepared to do the F<~name> expansion yourself.
  5612.  
  5613. =item C<man1direxp>
  5614.  
  5615. From F<man1dir.U>:
  5616.  
  5617. This variable is the same as the man1dir variable, but is filename
  5618. expanded at configuration time, for convenient use in makefiles.
  5619.  
  5620. =item C<man1ext>
  5621.  
  5622. From F<man1dir.U>:
  5623.  
  5624. This variable contains the extension that the manual page should
  5625. have: one of C<n>, C<l>, or C<1>.  The Makefile must supply the F<.>.
  5626. See man1dir.
  5627.  
  5628. =item C<man3dir>
  5629.  
  5630. From F<man3dir.U>:
  5631.  
  5632. This variable contains the name of the directory in which manual
  5633. source pages are to be put.  It is the responsibility of the
  5634. F<Makefile.SH> to get the value of this into the proper command.
  5635. You must be prepared to do the F<~name> expansion yourself.
  5636.  
  5637. =item C<man3direxp>
  5638.  
  5639. From F<man3dir.U>:
  5640.  
  5641. This variable is the same as the man3dir variable, but is filename
  5642. expanded at configuration time, for convenient use in makefiles.
  5643.  
  5644. =item C<man3ext>
  5645.  
  5646. From F<man3dir.U>:
  5647.  
  5648. This variable contains the extension that the manual page should
  5649. have: one of C<n>, C<l>, or C<3>.  The Makefile must supply the F<.>.
  5650. See man3dir.
  5651.  
  5652. =back
  5653.  
  5654. =head2 M
  5655.  
  5656. =over
  5657.  
  5658. =item C<Mcc>
  5659.  
  5660. From F<Loc.U>:
  5661.  
  5662. This variable is used internally by Configure to determine the
  5663. full pathname (if any) of the Mcc program.  After Configure runs,
  5664. the value is reset to a plain C<Mcc> and is not useful.
  5665.  
  5666. =item C<mips_type>
  5667.  
  5668. From F<usrinc.U>:
  5669.  
  5670. This variable holds the environment type for the mips system.
  5671. Possible values are "BSD 4.3" and "System V".
  5672.  
  5673. =item C<mkdir>
  5674.  
  5675. From F<Loc.U>:
  5676.  
  5677. This variable is used internally by Configure to determine the
  5678. full pathname (if any) of the mkdir program.  After Configure runs,
  5679. the value is reset to a plain C<mkdir> and is not useful.
  5680.  
  5681. =item C<mmaptype>
  5682.  
  5683. From F<d_mmap.U>:
  5684.  
  5685. This symbol contains the type of pointer returned by mmap()
  5686. (and simultaneously the type of the first argument).
  5687. It can be C<void *> or C<caddr_t>.
  5688.  
  5689. =item C<modetype>
  5690.  
  5691. From F<modetype.U>:
  5692.  
  5693. This variable defines modetype to be something like mode_t, 
  5694. int, unsigned short, or whatever type is used to declare file 
  5695. modes for system calls.
  5696.  
  5697. =item C<more>
  5698.  
  5699. From F<Loc.U>:
  5700.  
  5701. This variable is used internally by Configure to determine the
  5702. full pathname (if any) of the more program.  After Configure runs,
  5703. the value is reset to a plain C<more> and is not useful.
  5704.  
  5705. =item C<multiarch>
  5706.  
  5707. From F<multiarch.U>:
  5708.  
  5709. This variable conditionally defines the C<MULTIARCH> symbol
  5710. which signifies the presence of multiplatform files.
  5711. This is normally set by hints files.
  5712.  
  5713. =item C<mv>
  5714.  
  5715. From F<Loc.U>:
  5716.  
  5717. This variable is defined but not used by Configure.
  5718. The value is a plain '' and is not useful.
  5719.  
  5720. =item C<myarchname>
  5721.  
  5722. From F<archname.U>:
  5723.  
  5724. This variable holds the architecture name computed by Configure in
  5725. a previous run. It is not intended to be perused by any user and
  5726. should never be set in a hint file.
  5727.  
  5728. =item C<mydomain>
  5729.  
  5730. From F<myhostname.U>:
  5731.  
  5732. This variable contains the eventual value of the C<MYDOMAIN> symbol,
  5733. which is the domain of the host the program is going to run on.
  5734. The domain must be appended to myhostname to form a complete host name.
  5735. The dot comes with mydomain, and need not be supplied by the program.
  5736.  
  5737. =item C<myhostname>
  5738.  
  5739. From F<myhostname.U>:
  5740.  
  5741. This variable contains the eventual value of the C<MYHOSTNAME> symbol,
  5742. which is the name of the host the program is going to run on.
  5743. The domain is not kept with hostname, but must be gotten from mydomain.
  5744. The dot comes with mydomain, and need not be supplied by the program.
  5745.  
  5746. =item C<myuname>
  5747.  
  5748. From F<Oldconfig.U>:
  5749.  
  5750. The output of C<uname -a> if available, otherwise the hostname. On Xenix,
  5751. pseudo variables assignments in the output are stripped, thank you. The
  5752. whole thing is then lower-cased.
  5753.  
  5754. =back
  5755.  
  5756. =head2 n
  5757.  
  5758. =over
  5759.  
  5760. =item C<n>
  5761.  
  5762. From F<n.U>:
  5763.  
  5764. This variable contains the C<-n> flag if that is what causes the echo
  5765. command to suppress newline.  Otherwise it is null.  Correct usage is
  5766. $echo $n "prompt for a question: $c".
  5767.  
  5768. =item C<need_va_copy>
  5769.  
  5770. From F<need_va_copy.U>:
  5771.  
  5772. This symbol, if defined, indicates that the system stores
  5773. the variable argument list datatype, va_list, in a format
  5774. that cannot be copied by simple assignment, so that some
  5775. other means must be used when copying is required.
  5776. As such systems vary in their provision (or non-provision)
  5777. of copying mechanisms, F<handy.h> defines a platform-
  5778. C<independent> macro, Perl_va_copy(src, dst), to do the job.
  5779.  
  5780. =item C<netdb_hlen_type>
  5781.  
  5782. From F<netdbtype.U>:
  5783.  
  5784. This variable holds the type used for the 2nd argument to
  5785. gethostbyaddr().  Usually, this is int or size_t or unsigned.
  5786. This is only useful if you have gethostbyaddr(), naturally.
  5787.  
  5788. =item C<netdb_host_type>
  5789.  
  5790. From F<netdbtype.U>:
  5791.  
  5792. This variable holds the type used for the 1st argument to
  5793. gethostbyaddr().  Usually, this is char * or void *,  possibly
  5794. with or without a const prefix.
  5795. This is only useful if you have gethostbyaddr(), naturally.
  5796.  
  5797. =item C<netdb_name_type>
  5798.  
  5799. From F<netdbtype.U>:
  5800.  
  5801. This variable holds the type used for the argument to
  5802. gethostbyname().  Usually, this is char * or const char *.
  5803. This is only useful if you have gethostbyname(), naturally.
  5804.  
  5805. =item C<netdb_net_type>
  5806.  
  5807. From F<netdbtype.U>:
  5808.  
  5809. This variable holds the type used for the 1st argument to
  5810. getnetbyaddr().  Usually, this is int or long.
  5811. This is only useful if you have getnetbyaddr(), naturally.
  5812.  
  5813. =item C<nm>
  5814.  
  5815. From F<Loc.U>:
  5816.  
  5817. This variable is used internally by Configure to determine the
  5818. full pathname (if any) of the nm program.  After Configure runs,
  5819. the value is reset to a plain C<nm> and is not useful.
  5820.  
  5821. =item C<nm_opt>
  5822.  
  5823. From F<usenm.U>:
  5824.  
  5825. This variable holds the options that may be necessary for nm.
  5826.  
  5827. =item C<nm_so_opt>
  5828.  
  5829. From F<usenm.U>:
  5830.  
  5831. This variable holds the options that may be necessary for nm
  5832. to work on a shared library but that can not be used on an
  5833. archive library.  Currently, this is only used by Linux, where
  5834. nm --dynamic is *required* to get symbols from an C<ELF> library which
  5835. has been stripped, but nm --dynamic is *fatal* on an archive library.
  5836. Maybe Linux should just always set usenm=false.
  5837.  
  5838. =item C<nonxs_ext>
  5839.  
  5840. From F<Extensions.U>:
  5841.  
  5842. This variable holds a list of all non-xs extensions included
  5843. in the package.  All of them will be built.
  5844.  
  5845. =item C<nroff>
  5846.  
  5847. From F<Loc.U>:
  5848.  
  5849. This variable is used internally by Configure to determine the
  5850. full pathname (if any) of the nroff program.  After Configure runs,
  5851. the value is reset to a plain C<nroff> and is not useful.
  5852.  
  5853. =item C<nveformat>
  5854.  
  5855. From F<perlxvf.U>:
  5856.  
  5857. This variable contains the format string used for printing
  5858. a Perl C<NV> using %e-ish floating point format.
  5859.  
  5860. =item C<nvEUformat>
  5861.  
  5862. From F<perlxvf.U>:
  5863.  
  5864. This variable contains the format string used for printing
  5865. a Perl C<NV> using %E-ish floating point format.
  5866.  
  5867. =item C<nvfformat>
  5868.  
  5869. From F<perlxvf.U>:
  5870.  
  5871. This variable confains the format string used for printing
  5872. a Perl C<NV> using %f-ish floating point format.
  5873.  
  5874. =item C<nvFUformat>
  5875.  
  5876. From F<perlxvf.U>:
  5877.  
  5878. This variable confains the format string used for printing
  5879. a Perl C<NV> using %F-ish floating point format.
  5880.  
  5881. =item C<nvgformat>
  5882.  
  5883. From F<perlxvf.U>:
  5884.  
  5885. This variable contains the format string used for printing
  5886. a Perl C<NV> using %g-ish floating point format.
  5887.  
  5888. =item C<nvGUformat>
  5889.  
  5890. From F<perlxvf.U>:
  5891.  
  5892. This variable contains the format string used for printing
  5893. a Perl C<NV> using %G-ish floating point format.
  5894.  
  5895. =item C<nvsize>
  5896.  
  5897. From F<perlxv.U>:
  5898.  
  5899. This variable is the size of an C<NV> in bytes.
  5900.  
  5901. =item C<nvtype>
  5902.  
  5903. From F<perlxv.U>:
  5904.  
  5905. This variable contains the C type used for Perl's C<NV>.
  5906.  
  5907. =back
  5908.  
  5909. =head2 o
  5910.  
  5911. =over
  5912.  
  5913. =item C<o_nonblock>
  5914.  
  5915. From F<nblock_io.U>:
  5916.  
  5917. This variable bears the symbol value to be used during open() or fcntl()
  5918. to turn on non-blocking F<I/O> for a file descriptor. If you wish to switch
  5919. between blocking and non-blocking, you may try ioctl(C<FIOSNBIO>) instead,
  5920. but that is only supported by some devices.
  5921.  
  5922. =item C<obj_ext>
  5923.  
  5924. From F<Unix.U>:
  5925.  
  5926. This is an old synonym for _o.
  5927.  
  5928. =item C<old_pthread_create_joinable>
  5929.  
  5930. From F<d_pthrattrj.U>:
  5931.  
  5932. This variable defines the constant to use for creating joinable
  5933. (aka undetached) pthreads.  Unused if F<pthread.h> defines
  5934. C<PTHREAD_CREATE_JOINABLE>.  If used, possible values are
  5935. C<PTHREAD_CREATE_UNDETACHED> and C<__UNDETACHED>.
  5936.  
  5937. =item C<optimize>
  5938.  
  5939. From F<ccflags.U>:
  5940.  
  5941. This variable contains any F<optimizer/debugger> flag that should be used.
  5942. It is up to the Makefile to use it.
  5943.  
  5944. =item C<orderlib>
  5945.  
  5946. From F<orderlib.U>:
  5947.  
  5948. This variable is C<true> if the components of libraries must be ordered
  5949. (with `lorder $* | tsort`) before placing them in an archive.  Set to
  5950. C<false> if ranlib or ar can generate random libraries.
  5951.  
  5952. =item C<osname>
  5953.  
  5954. From F<Oldconfig.U>:
  5955.  
  5956. This variable contains the operating system name (e.g. sunos,
  5957. solaris, hpux, F<etc.>).  It can be useful later on for setting
  5958. defaults.  Any spaces are replaced with underscores.  It is set
  5959. to a null string if we can't figure it out.
  5960.  
  5961. =item C<osvers>
  5962.  
  5963. From F<Oldconfig.U>:
  5964.  
  5965. This variable contains the operating system version (e.g.
  5966. 4.1.3, 5.2, F<etc.>).  It is primarily used for helping select
  5967. an appropriate hints file, but might be useful elsewhere for
  5968. setting defaults.  It is set to '' if we can't figure it out.
  5969. We try to be flexible about how much of the version number
  5970. to keep, e.g. if 4.1.1, 4.1.2, and 4.1.3 are essentially the
  5971. same for this package, hints files might just be F<os_4.0> or
  5972. F<os_4.1>, F<etc.>, not keeping separate files for each little release.
  5973.  
  5974. =item C<otherlibdirs>
  5975.  
  5976. From F<otherlibdirs.U>:
  5977.  
  5978. This variable contains a colon-separated set of paths for the perl
  5979. binary to search for additional library files or modules.
  5980. These directories will be tacked to the end of @C<INC>.
  5981. Perl will automatically search below each path for version-
  5982. and architecture-specific directories.  See inc_version_list
  5983. for more details.
  5984. A value of C< > means C<none> and is used to preserve this value
  5985. for the next run through Configure.
  5986.  
  5987. =back
  5988.  
  5989. =head2 p
  5990.  
  5991. =over
  5992.  
  5993. =item C<package>
  5994.  
  5995. From F<package.U>:
  5996.  
  5997. This variable contains the name of the package being constructed.
  5998. It is primarily intended for the use of later Configure units.
  5999.  
  6000. =item C<pager>
  6001.  
  6002. From F<pager.U>:
  6003.  
  6004. This variable contains the name of the preferred pager on the system.
  6005. Usual values are (the full pathnames of) more, less, pg, or cat.
  6006.  
  6007. =item C<passcat>
  6008.  
  6009. From F<nis.U>:
  6010.  
  6011. This variable contains a command that produces the text of the
  6012. F</etc/passwd> file.  This is normally "cat F</etc/passwd>", but can be
  6013. "ypcat passwd" when C<NIS> is used.
  6014. On some systems, such as os390, there may be no equivalent
  6015. command, in which case this variable is unset.
  6016.  
  6017. =item C<patchlevel>
  6018.  
  6019. From F<patchlevel.U>:
  6020.  
  6021. The patchlevel level of this package.
  6022. The value of patchlevel comes from the F<patchlevel.h> file.
  6023. In a version number such as 5.6.1, this is the C<6>.
  6024. In F<patchlevel.h>, this is referred to as C<PERL_VERSION>.
  6025.  
  6026. =item C<path_sep>
  6027.  
  6028. From F<Unix.U>:
  6029.  
  6030. This is an old synonym for p_ in F<Head.U>, the character
  6031. used to separate elements in the command shell search C<PATH>.
  6032.  
  6033. =item C<perl5>
  6034.  
  6035. From F<perl5.U>:
  6036.  
  6037. This variable contains the full path (if any) to a previously
  6038. installed F<perl5.005> or later suitable for running the script
  6039. to determine inc_version_list.
  6040.  
  6041. =item C<perl>
  6042.  
  6043. From F<Loc.U>:
  6044.  
  6045. This variable is defined but not used by Configure.
  6046. The value is a plain '' and is not useful.
  6047.  
  6048. =back
  6049.  
  6050. =head2 P
  6051.  
  6052. =over
  6053.  
  6054. =item C<PERL_REVISION>
  6055.  
  6056. From F<Oldsyms.U>:
  6057.  
  6058. In a Perl version number such as 5.6.2, this is the 5.
  6059. This value is manually set in F<patchlevel.h>
  6060.  
  6061. =item C<PERL_SUBVERSION>
  6062.  
  6063. From F<Oldsyms.U>:
  6064.  
  6065. In a Perl version number such as 5.6.2, this is the 2.
  6066. Values greater than 50 represent potentially unstable
  6067. development subversions.
  6068. This value is manually set in F<patchlevel.h>
  6069.  
  6070. =item C<PERL_VERSION>
  6071.  
  6072. From F<Oldsyms.U>:
  6073.  
  6074. In a Perl version number such as 5.6.2, this is the 6.
  6075. This value is manually set in F<patchlevel.h>
  6076.  
  6077. =item C<perladmin>
  6078.  
  6079. From F<perladmin.U>:
  6080.  
  6081. Electronic mail address of the perl5 administrator.
  6082.  
  6083. =item C<perllibs>
  6084.  
  6085. From F<End.U>:
  6086.  
  6087. The list of libraries needed by Perl only (any libraries needed
  6088. by extensions only will by dropped, if using dynamic loading).
  6089.  
  6090. =item C<perlpath>
  6091.  
  6092. From F<perlpath.U>:
  6093.  
  6094. This variable contains the eventual value of the C<PERLPATH> symbol,
  6095. which contains the name of the perl interpreter to be used in
  6096. shell scripts and in the "eval C<exec>" idiom.
  6097.  
  6098. =item C<pg>
  6099.  
  6100. From F<Loc.U>:
  6101.  
  6102. This variable is used internally by Configure to determine the
  6103. full pathname (if any) of the pg program.  After Configure runs,
  6104. the value is reset to a plain C<pg> and is not useful.
  6105.  
  6106. =item C<phostname>
  6107.  
  6108. From F<myhostname.U>:
  6109.  
  6110. This variable contains the eventual value of the C<PHOSTNAME> symbol,
  6111. which is a command that can be fed to popen() to get the host name.
  6112. The program should probably not presume that the domain is or isn't
  6113. there already.
  6114.  
  6115. =item C<pidtype>
  6116.  
  6117. From F<pidtype.U>:
  6118.  
  6119. This variable defines C<PIDTYPE> to be something like pid_t, int, 
  6120. ushort, or whatever type is used to declare process ids in the kernel.
  6121.  
  6122. =item C<plibpth>
  6123.  
  6124. From F<libpth.U>:
  6125.  
  6126. Holds the private path used by Configure to find out the libraries.
  6127. Its value is prepend to libpth. This variable takes care of special
  6128. machines, like the mips.  Usually, it should be empty.
  6129.  
  6130. =item C<pm_apiversion>
  6131.  
  6132. From F<xs_apiversion.U>:
  6133.  
  6134. This variable contains the version of the oldest perl
  6135. compatible with the present perl.  (That is, pure perl modules
  6136. written for $pm_apiversion will still work for the current
  6137. version).  F<perl.c>:incpush() and F<lib/lib.pm> will automatically
  6138. search in $sitelib for older directories across major versions
  6139. back to pm_apiversion.  This is only useful if you have a perl
  6140. library directory tree structured like the default one.  The
  6141. versioned site_perl library was introduced in 5.005, so that's
  6142. the default setting for this variable.  It's hard to imagine
  6143. it changing before Perl6.  It is included here for symmetry
  6144. with xs_apiveprsion -- the searching algorithms will
  6145. (presumably) be similar.
  6146. See the C<INSTALL> file for how this works.
  6147.  
  6148. =item C<pmake>
  6149.  
  6150. From F<Loc.U>:
  6151.  
  6152. This variable is defined but not used by Configure.
  6153. The value is a plain '' and is not useful.
  6154.  
  6155. =item C<pr>
  6156.  
  6157. From F<Loc.U>:
  6158.  
  6159. This variable is defined but not used by Configure.
  6160. The value is a plain '' and is not useful.
  6161.  
  6162. =item C<prefix>
  6163.  
  6164. From F<prefix.U>:
  6165.  
  6166. This variable holds the name of the directory below which the
  6167. user will install the package.  Usually, this is F</usr/local>, and
  6168. executables go in F</usr/local/bin>, library stuff in F</usr/local/lib>,
  6169. man pages in F</usr/local/man>, etc.  It is only used to set defaults
  6170. for things in F<bin.U>, F<mansrc.U>, F<privlib.U>, or F<scriptdir.U>.
  6171.  
  6172. =item C<prefixexp>
  6173.  
  6174. From F<prefix.U>:
  6175.  
  6176. This variable holds the full absolute path of the directory below
  6177. which the user will install the package.  Derived from prefix.
  6178.  
  6179. =item C<privlib>
  6180.  
  6181. From F<privlib.U>:
  6182.  
  6183. This variable contains the eventual value of the C<PRIVLIB> symbol,
  6184. which is the name of the private library for this package.  It may
  6185. have a F<~> on the front. It is up to the makefile to eventually create
  6186. this directory while performing installation (with F<~> substitution).
  6187.  
  6188. =item C<privlibexp>
  6189.  
  6190. From F<privlib.U>:
  6191.  
  6192. This variable is the F<~name> expanded version of privlib, so that you
  6193. may use it directly in Makefiles or shell scripts.
  6194.  
  6195. =item C<prototype>
  6196.  
  6197. From F<prototype.U>:
  6198.  
  6199. This variable holds the eventual value of C<CAN_PROTOTYPE>, which
  6200. indicates the C compiler can handle funciton prototypes.
  6201.  
  6202. =item C<ptrsize>
  6203.  
  6204. From F<ptrsize.U>:
  6205.  
  6206. This variable contains the value of the C<PTRSIZE> symbol, which
  6207. indicates to the C program how many bytes there are in a pointer.
  6208.  
  6209. =back
  6210.  
  6211. =head2 q
  6212.  
  6213. =over
  6214.  
  6215. =item C<quadkind>
  6216.  
  6217. From F<quadtype.U>:
  6218.  
  6219. This variable, if defined, encodes the type of a quad:
  6220. 1 = int, 2 = long, 3 = long long, 4 = int64_t.
  6221.  
  6222. =item C<quadtype>
  6223.  
  6224. From F<quadtype.U>:
  6225.  
  6226. This variable defines Quad_t to be something like long, int, 
  6227. long long, int64_t, or whatever type is used for 64-bit integers.
  6228.  
  6229. =back
  6230.  
  6231. =head2 r
  6232.  
  6233. =over
  6234.  
  6235. =item C<randbits>
  6236.  
  6237. From F<randfunc.U>:
  6238.  
  6239. Indicates how many bits are produced by the function used to
  6240. generate normalized random numbers.
  6241.  
  6242. =item C<randfunc>
  6243.  
  6244. From F<randfunc.U>:
  6245.  
  6246. Indicates the name of the random number function to use.
  6247. Values include drand48, random, and rand. In C programs,
  6248. the C<Drand01> macro is defined to generate uniformly distributed
  6249. random numbers over the range [0., 1.[ (see drand01 and nrand).
  6250.  
  6251. =item C<randseedtype>
  6252.  
  6253. From F<randfunc.U>:
  6254.  
  6255. Indicates the type of the argument of the seedfunc.
  6256.  
  6257. =item C<ranlib>
  6258.  
  6259. From F<orderlib.U>:
  6260.  
  6261. This variable is set to the pathname of the ranlib program, if it is
  6262. needed to generate random libraries.  Set to C<:> if ar can generate
  6263. random libraries or if random libraries are not supported
  6264.  
  6265. =item C<rd_nodata>
  6266.  
  6267. From F<nblock_io.U>:
  6268.  
  6269. This variable holds the return code from read() when no data is
  6270. present. It should be -1, but some systems return 0 when C<O_NDELAY> is
  6271. used, which is a shame because you cannot make the difference between
  6272. no data and an F<EOF.>. Sigh!
  6273.  
  6274. =item C<revision>
  6275.  
  6276. From F<patchlevel.U>:
  6277.  
  6278. The value of revision comes from the F<patchlevel.h> file.
  6279. In a version number such as 5.6.1, this is the C<5>.
  6280. In F<patchlevel.h>, this is referred to as C<PERL_REVISION>.
  6281.  
  6282. =item C<rm>
  6283.  
  6284. From F<Loc.U>:
  6285.  
  6286. This variable is used internally by Configure to determine the
  6287. full pathname (if any) of the rm program.  After Configure runs,
  6288. the value is reset to a plain C<rm> and is not useful.
  6289.  
  6290. =item C<rmail>
  6291.  
  6292. From F<Loc.U>:
  6293.  
  6294. This variable is defined but not used by Configure.
  6295. The value is a plain '' and is not useful.
  6296.  
  6297. =item C<runnm>
  6298.  
  6299. From F<usenm.U>:
  6300.  
  6301. This variable contains C<true> or C<false> depending whether the
  6302. nm extraction should be performed or not, according to the value
  6303. of usenm and the flags on the Configure command line.
  6304.  
  6305. =back
  6306.  
  6307. =head2 s
  6308.  
  6309. =over
  6310.  
  6311. =item C<sched_yield>
  6312.  
  6313. From F<d_pthread_y.U>:
  6314.  
  6315. This variable defines the way to yield the execution
  6316. of the current thread.
  6317.  
  6318. =item C<scriptdir>
  6319.  
  6320. From F<scriptdir.U>:
  6321.  
  6322. This variable holds the name of the directory in which the user wants
  6323. to put publicly scripts for the package in question.  It is either
  6324. the same directory as for binaries, or a special one that can be
  6325. mounted across different architectures, like F</usr/share>. Programs
  6326. must be prepared to deal with F<~name> expansion.
  6327.  
  6328. =item C<scriptdirexp>
  6329.  
  6330. From F<scriptdir.U>:
  6331.  
  6332. This variable is the same as scriptdir, but is filename expanded
  6333. at configuration time, for programs not wanting to bother with it.
  6334.  
  6335. =item C<sed>
  6336.  
  6337. From F<Loc.U>:
  6338.  
  6339. This variable is used internally by Configure to determine the
  6340. full pathname (if any) of the sed program.  After Configure runs,
  6341. the value is reset to a plain C<sed> and is not useful.
  6342.  
  6343. =item C<seedfunc>
  6344.  
  6345. From F<randfunc.U>:
  6346.  
  6347. Indicates the random number generating seed function.
  6348. Values include srand48, srandom, and srand.
  6349.  
  6350. =item C<selectminbits>
  6351.  
  6352. From F<selectminbits.U>:
  6353.  
  6354. This variable holds the minimum number of bits operated by select.
  6355. That is, if you do select(n, ...), how many bits at least will be
  6356. cleared in the masks if some activity is detected.  Usually this
  6357. is either n or 32*ceil(F<n/32>), especially many little-endians do
  6358. the latter.  This is only useful if you have select(), naturally.
  6359.  
  6360. =item C<selecttype>
  6361.  
  6362. From F<selecttype.U>:
  6363.  
  6364. This variable holds the type used for the 2nd, 3rd, and 4th
  6365. arguments to select.  Usually, this is C<fd_set *>, if C<HAS_FD_SET>
  6366. is defined, and C<int *> otherwise.  This is only useful if you 
  6367. have select(), naturally.
  6368.  
  6369. =item C<sendmail>
  6370.  
  6371. From F<Loc.U>:
  6372.  
  6373. This variable is defined but not used by Configure.
  6374. The value is a plain '' and is not useful.
  6375.  
  6376. =item C<sh>
  6377.  
  6378. From F<sh.U>:
  6379.  
  6380. This variable contains the full pathname of the shell used
  6381. on this system to execute Bourne shell scripts.  Usually, this will be
  6382. F</bin/sh>, though it's possible that some systems will have F</bin/ksh>,
  6383. F</bin/pdksh>, F</bin/ash>, F</bin/bash>, or even something such as
  6384. D:F</bin/sh.exe>.
  6385. This unit comes before F<Options.U>, so you can't set sh with a C<-D>
  6386. option, though you can override this (and startsh)
  6387. with C<-O -Dsh=F</bin/whatever> -Dstartsh=whatever>
  6388.  
  6389. =item C<shar>
  6390.  
  6391. From F<Loc.U>:
  6392.  
  6393. This variable is defined but not used by Configure.
  6394. The value is a plain '' and is not useful.
  6395.  
  6396. =item C<sharpbang>
  6397.  
  6398. From F<spitshell.U>:
  6399.  
  6400. This variable contains the string #! if this system supports that
  6401. construct.
  6402.  
  6403. =item C<shmattype>
  6404.  
  6405. From F<d_shmat.U>:
  6406.  
  6407. This symbol contains the type of pointer returned by shmat().
  6408. It can be C<void *> or C<char *>.
  6409.  
  6410. =item C<shortsize>
  6411.  
  6412. From F<intsize.U>:
  6413.  
  6414. This variable contains the value of the C<SHORTSIZE> symbol which
  6415. indicates to the C program how many bytes there are in a short.
  6416.  
  6417. =item C<shrpenv>
  6418.  
  6419. From F<libperl.U>:
  6420.  
  6421. If the user builds a shared F<libperl.so>, then we need to tell the
  6422. C<perl> executable where it will be able to find the installed F<libperl.so>. 
  6423. One way to do this on some systems is to set the environment variable
  6424. C<LD_RUN_PATH> to the directory that will be the final location of the
  6425. shared F<libperl.so>.  The makefile can use this with something like
  6426. $shrpenv $(C<CC>) -o perl F<perlmain.o> $libperl $libs
  6427. Typical values are
  6428. shrpenv="env C<LD_RUN_PATH>=$F<archlibexp/C<CORE>>"
  6429. or
  6430. shrpenv=''
  6431. See the main perl F<Makefile.SH> for actual working usage.
  6432. Alternatively, we might be able to use a command line option such
  6433. as -R $F<archlibexp/C<CORE>> (Solaris, NetBSD) or -Wl,-rpath
  6434. $F<archlibexp/C<CORE>> (Linux).
  6435.  
  6436. =item C<shsharp>
  6437.  
  6438. From F<spitshell.U>:
  6439.  
  6440. This variable tells further Configure units whether your sh can
  6441. handle # comments.
  6442.  
  6443. =item C<sig_count>
  6444.  
  6445. From F<sig_name.U>:
  6446.  
  6447. This variable holds a number larger than the largest valid
  6448. signal number.  This is usually the same as the C<NSIG> macro.
  6449.  
  6450. =item C<sig_name>
  6451.  
  6452. From F<sig_name.U>:
  6453.  
  6454. This variable holds the signal names, space separated. The leading
  6455. C<SIG> in signal name is removed.  A C<ZERO> is prepended to the
  6456. list.  This is currently not used.
  6457.  
  6458. =item C<sig_name_init>
  6459.  
  6460. From F<sig_name.U>:
  6461.  
  6462. This variable holds the signal names, enclosed in double quotes and
  6463. separated by commas, suitable for use in the C<SIG_NAME> definition 
  6464. below.  A C<ZERO> is prepended to the list, and the list is 
  6465. terminated with a plain 0.  The leading C<SIG> in signal names
  6466. is removed. See sig_num.
  6467.  
  6468. =item C<sig_num>
  6469.  
  6470. From F<sig_name.U>:
  6471.  
  6472. This variable holds the signal numbers, space separated. A C<ZERO> is
  6473. prepended to the list (corresponding to the fake C<SIGZERO>), and 
  6474. the list is terminated with a 0.  Those numbers correspond to 
  6475. the value of the signal listed in the same place within the
  6476. sig_name list.
  6477.  
  6478. =item C<sig_num_init>
  6479.  
  6480. From F<sig_name.U>:
  6481.  
  6482. This variable holds the signal numbers, enclosed in double quotes and
  6483. separated by commas, suitable for use in the C<SIG_NUM> definition 
  6484. below.  A C<ZERO> is prepended to the list, and the list is 
  6485. terminated with a plain 0.
  6486.  
  6487. =item C<sig_size>
  6488.  
  6489. From F<sig_name.U>:
  6490.  
  6491. This variable contains the number of elements of the sig_name
  6492. and sig_num arrays, excluding the final C<NULL> entry.
  6493.  
  6494. =item C<signal_t>
  6495.  
  6496. From F<d_voidsig.U>:
  6497.  
  6498. This variable holds the type of the signal handler (void or int).
  6499.  
  6500. =item C<sitearch>
  6501.  
  6502. From F<sitearch.U>:
  6503.  
  6504. This variable contains the eventual value of the C<SITEARCH> symbol,
  6505. which is the name of the private library for this package.  It may
  6506. have a F<~> on the front. It is up to the makefile to eventually create
  6507. this directory while performing installation (with F<~> substitution).
  6508. The standard distribution will put nothing in this directory.
  6509. After perl has been installed, users may install their own local
  6510. architecture-dependent modules in this directory with
  6511. MakeMaker F<Makefile.PL>
  6512. or equivalent.  See C<INSTALL> for details.
  6513.  
  6514. =item C<sitearchexp>
  6515.  
  6516. From F<sitearch.U>:
  6517.  
  6518. This variable is the F<~name> expanded version of sitearch, so that you
  6519. may use it directly in Makefiles or shell scripts.
  6520.  
  6521. =item C<sitebin>
  6522.  
  6523. From F<sitebin.U>:
  6524.  
  6525. This variable holds the name of the directory in which the user wants
  6526. to put add-on publicly executable files for the package in question.  It
  6527. is most often a local directory such as F</usr/local/bin>. Programs using
  6528. this variable must be prepared to deal with F<~name> substitution.
  6529. The standard distribution will put nothing in this directory.
  6530. After perl has been installed, users may install their own local
  6531. executables in this directory with
  6532. MakeMaker F<Makefile.PL>
  6533. or equivalent.  See C<INSTALL> for details.
  6534.  
  6535. =item C<sitebinexp>
  6536.  
  6537. From F<sitebin.U>:
  6538.  
  6539. This is the same as the sitebin variable, but is filename expanded at
  6540. configuration time, for use in your makefiles.
  6541.  
  6542. =item C<sitelib>
  6543.  
  6544. From F<sitelib.U>:
  6545.  
  6546. This variable contains the eventual value of the C<SITELIB> symbol,
  6547. which is the name of the private library for this package.  It may
  6548. have a F<~> on the front. It is up to the makefile to eventually create
  6549. this directory while performing installation (with F<~> substitution).
  6550. The standard distribution will put nothing in this directory.
  6551. After perl has been installed, users may install their own local
  6552. architecture-independent modules in this directory with
  6553. MakeMaker F<Makefile.PL>
  6554. or equivalent.  See C<INSTALL> for details.
  6555.  
  6556. =item C<sitelib_stem>
  6557.  
  6558. From F<sitelib.U>:
  6559.  
  6560. This variable is $sitelibexp with any trailing version-specific component
  6561. removed.  The elements in inc_version_list (F<inc_version_list.U>) can
  6562. be tacked onto this variable to generate a list of directories to search.
  6563.  
  6564. =item C<sitelibexp>
  6565.  
  6566. From F<sitelib.U>:
  6567.  
  6568. This variable is the F<~name> expanded version of sitelib, so that you
  6569. may use it directly in Makefiles or shell scripts.
  6570.  
  6571. =item C<siteprefix>
  6572.  
  6573. From F<siteprefix.U>:
  6574.  
  6575. This variable holds the full absolute path of the directory below
  6576. which the user will install add-on packages.
  6577. See C<INSTALL> for usage and examples.
  6578.  
  6579. =item C<siteprefixexp>
  6580.  
  6581. From F<siteprefix.U>:
  6582.  
  6583. This variable holds the full absolute path of the directory below
  6584. which the user will install add-on packages.  Derived from siteprefix.
  6585.  
  6586. =item C<sizesize>
  6587.  
  6588. From F<sizesize.U>:
  6589.  
  6590. This variable contains the size of a sizetype in bytes.
  6591.  
  6592. =item C<sizetype>
  6593.  
  6594. From F<sizetype.U>:
  6595.  
  6596. This variable defines sizetype to be something like size_t, 
  6597. unsigned long, or whatever type is used to declare length 
  6598. parameters for string functions.
  6599.  
  6600. =item C<sleep>
  6601.  
  6602. From F<Loc.U>:
  6603.  
  6604. This variable is defined but not used by Configure.
  6605. The value is a plain '' and is not useful.
  6606.  
  6607. =item C<smail>
  6608.  
  6609. From F<Loc.U>:
  6610.  
  6611. This variable is defined but not used by Configure.
  6612. The value is a plain '' and is not useful.
  6613.  
  6614. =item C<so>
  6615.  
  6616. From F<so.U>:
  6617.  
  6618. This variable holds the extension used to identify shared libraries
  6619. (also known as shared objects) on the system. Usually set to C<so>.
  6620.  
  6621. =item C<sockethdr>
  6622.  
  6623. From F<d_socket.U>:
  6624.  
  6625. This variable has any cpp C<-I> flags needed for socket support.
  6626.  
  6627. =item C<socketlib>
  6628.  
  6629. From F<d_socket.U>:
  6630.  
  6631. This variable has the names of any libraries needed for socket support.
  6632.  
  6633. =item C<socksizetype>
  6634.  
  6635. From F<socksizetype.U>:
  6636.  
  6637. This variable holds the type used for the size argument
  6638. for various socket calls like accept.  Usual values include
  6639. socklen_t, size_t, and int.
  6640.  
  6641. =item C<sort>
  6642.  
  6643. From F<Loc.U>:
  6644.  
  6645. This variable is used internally by Configure to determine the
  6646. full pathname (if any) of the sort program.  After Configure runs,
  6647. the value is reset to a plain C<sort> and is not useful.
  6648.  
  6649. =item C<spackage>
  6650.  
  6651. From F<package.U>:
  6652.  
  6653. This variable contains the name of the package being constructed,
  6654. with the first letter uppercased, F<i.e>. suitable for starting
  6655. sentences.
  6656.  
  6657. =item C<spitshell>
  6658.  
  6659. From F<spitshell.U>:
  6660.  
  6661. This variable contains the command necessary to spit out a runnable
  6662. shell on this system.  It is either cat or a grep C<-v> for # comments.
  6663.  
  6664. =item C<sPRId64>
  6665.  
  6666. From F<quadfio.U>:
  6667.  
  6668. This variable, if defined, contains the string used by stdio to
  6669. format 64-bit decimal numbers (format C<d>) for output.
  6670.  
  6671. =item C<sPRIeldbl>
  6672.  
  6673. From F<longdblfio.U>:
  6674.  
  6675. This variable, if defined, contains the string used by stdio to
  6676. format long doubles (format C<e>) for output.
  6677.  
  6678. =item C<sPRIEUldbl>
  6679.  
  6680. From F<longdblfio.U>:
  6681.  
  6682. This variable, if defined, contains the string used by stdio to
  6683. format long doubles (format C<E>) for output.
  6684. The C<U> in the name is to separate this from sPRIeldbl so that even
  6685. case-blind systems can see the difference.
  6686.  
  6687. =item C<sPRIfldbl>
  6688.  
  6689. From F<longdblfio.U>:
  6690.  
  6691. This variable, if defined, contains the string used by stdio to
  6692. format long doubles (format C<f>) for output.
  6693.  
  6694. =item C<sPRIFUldbl>
  6695.  
  6696. From F<longdblfio.U>:
  6697.  
  6698. This variable, if defined, contains the string used by stdio to
  6699. format long doubles (format C<F>) for output.
  6700. The C<U> in the name is to separate this from sPRIfldbl so that even
  6701. case-blind systems can see the difference.
  6702.  
  6703. =item C<sPRIgldbl>
  6704.  
  6705. From F<longdblfio.U>:
  6706.  
  6707. This variable, if defined, contains the string used by stdio to
  6708. format long doubles (format C<g>) for output.
  6709.  
  6710. =item C<sPRIGUldbl>
  6711.  
  6712. From F<longdblfio.U>:
  6713.  
  6714. This variable, if defined, contains the string used by stdio to
  6715. format long doubles (format C<G>) for output.
  6716. The C<U> in the name is to separate this from sPRIgldbl so that even
  6717. case-blind systems can see the difference.
  6718.  
  6719. =item C<sPRIi64>
  6720.  
  6721. From F<quadfio.U>:
  6722.  
  6723. This variable, if defined, contains the string used by stdio to
  6724. format 64-bit decimal numbers (format C<i>) for output.
  6725.  
  6726. =item C<sPRIo64>
  6727.  
  6728. From F<quadfio.U>:
  6729.  
  6730. This variable, if defined, contains the string used by stdio to
  6731. format 64-bit octal numbers (format C<o>) for output.
  6732.  
  6733. =item C<sPRIu64>
  6734.  
  6735. From F<quadfio.U>:
  6736.  
  6737. This variable, if defined, contains the string used by stdio to
  6738. format 64-bit unsigned decimal numbers (format C<u>) for output.
  6739.  
  6740. =item C<sPRIx64>
  6741.  
  6742. From F<quadfio.U>:
  6743.  
  6744. This variable, if defined, contains the string used by stdio to
  6745. format 64-bit hexadecimal numbers (format C<x>) for output.
  6746.  
  6747. =item C<sPRIXU64>
  6748.  
  6749. From F<quadfio.U>:
  6750.  
  6751. This variable, if defined, contains the string used by stdio to
  6752. format 64-bit hExADECimAl numbers (format C<X>) for output.
  6753. The C<U> in the name is to separate this from sPRIx64 so that even
  6754. case-blind systems can see the difference.
  6755.  
  6756. =item C<src>
  6757.  
  6758. From F<src.U>:
  6759.  
  6760. This variable holds the path to the package source. It is up to
  6761. the Makefile to use this variable and set C<VPATH> accordingly to
  6762. find the sources remotely.
  6763.  
  6764. =item C<sSCNfldbl>
  6765.  
  6766. From F<longdblfio.U>:
  6767.  
  6768. This variable, if defined, contains the string used by stdio to
  6769. format long doubles (format C<f>) for input.
  6770.  
  6771. =item C<ssizetype>
  6772.  
  6773. From F<ssizetype.U>:
  6774.  
  6775. This variable defines ssizetype to be something like ssize_t, 
  6776. long or int.  It is used by functions that return a count 
  6777. of bytes or an error condition.  It must be a signed type.
  6778. We will pick a type such that sizeof(SSize_t) == sizeof(Size_t).
  6779.  
  6780. =item C<startperl>
  6781.  
  6782. From F<startperl.U>:
  6783.  
  6784. This variable contains the string to put on the front of a perl
  6785. script to make sure (hopefully) that it runs with perl and not some
  6786. shell. Of course, that leading line must be followed by the classical
  6787. perl idiom:
  6788. eval 'exec perl -S $0 ${1+C<$@>}'
  6789. if $running_under_some_shell;
  6790. to guarantee perl startup should the shell execute the script. Note
  6791. that this magic incatation is not understood by csh.
  6792.  
  6793. =item C<startsh>
  6794.  
  6795. From F<startsh.U>:
  6796.  
  6797. This variable contains the string to put on the front of a shell
  6798. script to make sure (hopefully) that it runs with sh and not some
  6799. other shell.
  6800.  
  6801. =item C<static_ext>
  6802.  
  6803. From F<Extensions.U>:
  6804.  
  6805. This variable holds a list of C<XS> extension files we want to
  6806. link statically into the package.  It is used by Makefile.
  6807.  
  6808. =item C<stdchar>
  6809.  
  6810. From F<stdchar.U>:
  6811.  
  6812. This variable conditionally defines C<STDCHAR> to be the type of char
  6813. used in F<stdio.h>.  It has the values "unsigned char" or C<char>.
  6814.  
  6815. =item C<stdio_base>
  6816.  
  6817. From F<d_stdstdio.U>:
  6818.  
  6819. This variable defines how, given a C<FILE> pointer, fp, to access the
  6820. _base field (or equivalent) of F<stdio.h>'s C<FILE> structure.  This will
  6821. be used to define the macro FILE_base(fp).
  6822.  
  6823. =item C<stdio_bufsiz>
  6824.  
  6825. From F<d_stdstdio.U>:
  6826.  
  6827. This variable defines how, given a C<FILE> pointer, fp, to determine
  6828. the number of bytes store in the F<I/O> buffer pointer to by the
  6829. _base field (or equivalent) of F<stdio.h>'s C<FILE> structure.  This will
  6830. be used to define the macro FILE_bufsiz(fp).
  6831.  
  6832. =item C<stdio_cnt>
  6833.  
  6834. From F<d_stdstdio.U>:
  6835.  
  6836. This variable defines how, given a C<FILE> pointer, fp, to access the
  6837. _cnt field (or equivalent) of F<stdio.h>'s C<FILE> structure.  This will
  6838. be used to define the macro FILE_cnt(fp).
  6839.  
  6840. =item C<stdio_filbuf>
  6841.  
  6842. From F<d_stdstdio.U>:
  6843.  
  6844. This variable defines how, given a C<FILE> pointer, fp, to tell
  6845. stdio to refill it's internal buffers (?).  This will
  6846. be used to define the macro FILE_filbuf(fp).
  6847.  
  6848. =item C<stdio_ptr>
  6849.  
  6850. From F<d_stdstdio.U>:
  6851.  
  6852. This variable defines how, given a C<FILE> pointer, fp, to access the
  6853. _ptr field (or equivalent) of F<stdio.h>'s C<FILE> structure.  This will
  6854. be used to define the macro FILE_ptr(fp).
  6855.  
  6856. =item C<stdio_stream_array>
  6857.  
  6858. From F<stdio_streams.U>:
  6859.  
  6860. This variable tells the name of the array holding the stdio streams.
  6861. Usual values include _iob, __iob, and __sF.
  6862.  
  6863. =item C<strings>
  6864.  
  6865. From F<i_string.U>:
  6866.  
  6867. This variable holds the full path of the string header that will be
  6868. used. Typically F</usr/include/string.h> or F</usr/include/strings.h>.
  6869.  
  6870. =item C<submit>
  6871.  
  6872. From F<Loc.U>:
  6873.  
  6874. This variable is defined but not used by Configure.
  6875. The value is a plain '' and is not useful.
  6876.  
  6877. =item C<subversion>
  6878.  
  6879. From F<patchlevel.U>:
  6880.  
  6881. The subversion level of this package.
  6882. The value of subversion comes from the F<patchlevel.h> file.
  6883. In a version number such as 5.6.1, this is the C<1>.
  6884. In F<patchlevel.h>, this is referred to as C<PERL_SUBVERSION>.
  6885. This is unique to perl.
  6886.  
  6887. =item C<sysman>
  6888.  
  6889. From F<sysman.U>:
  6890.  
  6891. This variable holds the place where the manual is located on this
  6892. system. It is not the place where the user wants to put his manual
  6893. pages. Rather it is the place where Configure may look to find manual
  6894. for unix commands (section 1 of the manual usually). See mansrc.
  6895.  
  6896. =back
  6897.  
  6898. =head2 t
  6899.  
  6900. =over
  6901.  
  6902. =item C<tail>
  6903.  
  6904. From F<Loc.U>:
  6905.  
  6906. This variable is defined but not used by Configure.
  6907. The value is a plain '' and is not useful.
  6908.  
  6909. =item C<tar>
  6910.  
  6911. From F<Loc.U>:
  6912.  
  6913. This variable is defined but not used by Configure.
  6914. The value is a plain '' and is not useful.
  6915.  
  6916. =item C<tbl>
  6917.  
  6918. From F<Loc.U>:
  6919.  
  6920. This variable is defined but not used by Configure.
  6921. The value is a plain '' and is not useful.
  6922.  
  6923. =item C<tee>
  6924.  
  6925. From F<Loc.U>:
  6926.  
  6927. This variable is defined but not used by Configure.
  6928. The value is a plain '' and is not useful.
  6929.  
  6930. =item C<test>
  6931.  
  6932. From F<Loc.U>:
  6933.  
  6934. This variable is used internally by Configure to determine the
  6935. full pathname (if any) of the test program.  After Configure runs,
  6936. the value is reset to a plain C<test> and is not useful.
  6937.  
  6938. =item C<timeincl>
  6939.  
  6940. From F<i_time.U>:
  6941.  
  6942. This variable holds the full path of the included time header(s).
  6943.  
  6944. =item C<timetype>
  6945.  
  6946. From F<d_time.U>:
  6947.  
  6948. This variable holds the type returned by time(). It can be long,
  6949. or time_t on C<BSD> sites (in which case <sys/types.h> should be
  6950. included). Anyway, the type Time_t should be used.
  6951.  
  6952. =item C<touch>
  6953.  
  6954. From F<Loc.U>:
  6955.  
  6956. This variable is used internally by Configure to determine the
  6957. full pathname (if any) of the touch program.  After Configure runs,
  6958. the value is reset to a plain C<touch> and is not useful.
  6959.  
  6960. =item C<tr>
  6961.  
  6962. From F<Loc.U>:
  6963.  
  6964. This variable is used internally by Configure to determine the
  6965. full pathname (if any) of the tr program.  After Configure runs,
  6966. the value is reset to a plain C<tr> and is not useful.
  6967.  
  6968. =item C<trnl>
  6969.  
  6970. From F<trnl.U>:
  6971.  
  6972. This variable contains the value to be passed to the tr(1)
  6973. command to transliterate a newline.  Typical values are
  6974. C<\012> and C<\n>.  This is needed for C<EBCDIC> systems where
  6975. newline is not necessarily C<\012>.
  6976.  
  6977. =item C<troff>
  6978.  
  6979. From F<Loc.U>:
  6980.  
  6981. This variable is defined but not used by Configure.
  6982. The value is a plain '' and is not useful.
  6983.  
  6984. =back
  6985.  
  6986. =head2 u
  6987.  
  6988. =over
  6989.  
  6990. =item C<u16size>
  6991.  
  6992. From F<perlxv.U>:
  6993.  
  6994. This variable is the size of an U16 in bytes.
  6995.  
  6996. =item C<u16type>
  6997.  
  6998. From F<perlxv.U>:
  6999.  
  7000. This variable contains the C type used for Perl's U16.
  7001.  
  7002. =item C<u32size>
  7003.  
  7004. From F<perlxv.U>:
  7005.  
  7006. This variable is the size of an U32 in bytes.
  7007.  
  7008. =item C<u32type>
  7009.  
  7010. From F<perlxv.U>:
  7011.  
  7012. This variable contains the C type used for Perl's U32.
  7013.  
  7014. =item C<u64size>
  7015.  
  7016. From F<perlxv.U>:
  7017.  
  7018. This variable is the size of an U64 in bytes.
  7019.  
  7020. =item C<u64type>
  7021.  
  7022. From F<perlxv.U>:
  7023.  
  7024. This variable contains the C type used for Perl's U64.
  7025.  
  7026. =item C<u8size>
  7027.  
  7028. From F<perlxv.U>:
  7029.  
  7030. This variable is the size of an U8 in bytes.
  7031.  
  7032. =item C<u8type>
  7033.  
  7034. From F<perlxv.U>:
  7035.  
  7036. This variable contains the C type used for Perl's U8.
  7037.  
  7038. =item C<uidformat>
  7039.  
  7040. From F<uidf.U>:
  7041.  
  7042. This variable contains the format string used for printing a Uid_t.
  7043.  
  7044. =item C<uidsign>
  7045.  
  7046. From F<uidsign.U>:
  7047.  
  7048. This variable contains the signedness of a uidtype.
  7049. 1 for unsigned, -1 for signed.
  7050.  
  7051. =item C<uidsize>
  7052.  
  7053. From F<uidsize.U>:
  7054.  
  7055. This variable contains the size of a uidtype in bytes.
  7056.  
  7057. =item C<uidtype>
  7058.  
  7059. From F<uidtype.U>:
  7060.  
  7061. This variable defines Uid_t to be something like uid_t, int, 
  7062. ushort, or whatever type is used to declare user ids in the kernel.
  7063.  
  7064. =item C<uname>
  7065.  
  7066. From F<Loc.U>:
  7067.  
  7068. This variable is used internally by Configure to determine the
  7069. full pathname (if any) of the uname program.  After Configure runs,
  7070. the value is reset to a plain C<uname> and is not useful.
  7071.  
  7072. =item C<uniq>
  7073.  
  7074. From F<Loc.U>:
  7075.  
  7076. This variable is used internally by Configure to determine the
  7077. full pathname (if any) of the uniq program.  After Configure runs,
  7078. the value is reset to a plain C<uniq> and is not useful.
  7079.  
  7080. =item C<uquadtype>
  7081.  
  7082. From F<quadtype.U>:
  7083.  
  7084. This variable defines Uquad_t to be something like unsigned long,
  7085. unsigned int, unsigned long long, uint64_t, or whatever type is
  7086. used for 64-bit integers.
  7087.  
  7088. =item C<use5005threads>
  7089.  
  7090. From F<usethreads.U>:
  7091.  
  7092. This variable conditionally defines the USE_5005THREADS symbol,
  7093. and indicates that Perl should be built to use the 5.005-based
  7094. threading implementation.
  7095.  
  7096. =item C<use64bitall>
  7097.  
  7098. From F<use64bits.U>:
  7099.  
  7100. This variable conditionally defines the USE_64_BIT_ALL symbol,
  7101. and indicates that 64-bit integer types should be used
  7102. when available.  The maximal possible
  7103. 64-bitness is employed: LP64 or ILP64, meaning that you will
  7104. be able to use more than 2 gigabytes of memory.  This mode is
  7105. even more binary incompatible than USE_64_BIT_INT. You may not
  7106. be able to run the resulting executable in a 32-bit C<CPU> at all or
  7107. you may need at least to reboot your C<OS> to 64-bit mode.
  7108.  
  7109. =item C<use64bitint>
  7110.  
  7111. From F<use64bits.U>:
  7112.  
  7113. This variable conditionally defines the USE_64_BIT_INT symbol,
  7114. and indicates that 64-bit integer types should be used
  7115. when available.  The minimal possible 64-bitness
  7116. is employed, just enough to get 64-bit integers into Perl.
  7117. This may mean using for example "long longs", while your memory
  7118. may still be limited to 2 gigabytes.
  7119.  
  7120. =item C<usedl>
  7121.  
  7122. From F<dlsrc.U>:
  7123.  
  7124. This variable indicates if the system supports dynamic
  7125. loading of some sort.  See also dlsrc and dlobj.
  7126.  
  7127. =item C<useithreads>
  7128.  
  7129. From F<usethreads.U>:
  7130.  
  7131. This variable conditionally defines the C<USE_ITHREADS> symbol,
  7132. and indicates that Perl should be built to use the interpreter-based
  7133. threading implementation.
  7134.  
  7135. =item C<uselargefiles>
  7136.  
  7137. From F<uselfs.U>:
  7138.  
  7139. This variable conditionally defines the C<USE_LARGE_FILES> symbol,
  7140. and indicates that large file interfaces should be used when
  7141. available.
  7142.  
  7143. =item C<uselongdouble>
  7144.  
  7145. From F<uselongdbl.U>:
  7146.  
  7147. This variable conditionally defines the C<USE_LONG_DOUBLE> symbol,
  7148. and indicates that long doubles should be used when available.
  7149.  
  7150. =item C<usemorebits>
  7151.  
  7152. From F<usemorebits.U>:
  7153.  
  7154. This variable conditionally defines the C<USE_MORE_BITS> symbol,
  7155. and indicates that explicit 64-bit interfaces and long doubles
  7156. should be used when available.
  7157.  
  7158. =item C<usemultiplicity>
  7159.  
  7160. From F<usemultiplicity.U>:
  7161.  
  7162. This variable conditionally defines the C<MULTIPLICITY> symbol,
  7163. and indicates that Perl should be built to use multiplicity.
  7164.  
  7165. =item C<usemymalloc>
  7166.  
  7167. From F<mallocsrc.U>:
  7168.  
  7169. This variable contains y if the malloc that comes with this package
  7170. is desired over the system's version of malloc.  People often include
  7171. special versions of malloc for effiency, but such versions are often
  7172. less portable.  See also mallocsrc and mallocobj.
  7173. If this is C<y>, then -lmalloc is removed from $libs.
  7174.  
  7175. =item C<usenm>
  7176.  
  7177. From F<usenm.U>:
  7178.  
  7179. This variable contains C<true> or C<false> depending whether the
  7180. nm extraction is wanted or not.
  7181.  
  7182. =item C<useopcode>
  7183.  
  7184. From F<Extensions.U>:
  7185.  
  7186. This variable holds either C<true> or C<false> to indicate
  7187. whether the Opcode extension should be used.  The sole
  7188. use for this currently is to allow an easy mechanism
  7189. for users to skip the Opcode extension from the Configure
  7190. command line.
  7191.  
  7192. =item C<useperlio>
  7193.  
  7194. From F<useperlio.U>:
  7195.  
  7196. This variable conditionally defines the C<USE_PERLIO> symbol,
  7197. and indicates that the PerlIO abstraction should be
  7198. used throughout.
  7199.  
  7200. =item C<useposix>
  7201.  
  7202. From F<Extensions.U>:
  7203.  
  7204. This variable holds either C<true> or C<false> to indicate
  7205. whether the C<POSIX> extension should be used.  The sole
  7206. use for this currently is to allow an easy mechanism
  7207. for hints files to indicate that C<POSIX> will not compile
  7208. on a particular system.
  7209.  
  7210. =item C<usesfio>
  7211.  
  7212. From F<d_sfio.U>:
  7213.  
  7214. This variable is set to true when the user agrees to use sfio.
  7215. It is set to false when sfio is not available or when the user
  7216. explicitely requests not to use sfio.  It is here primarily so
  7217. that command-line settings can override the auto-detection of
  7218. d_sfio without running into a "WHOA THERE".
  7219.  
  7220. =item C<useshrplib>
  7221.  
  7222. From F<libperl.U>:
  7223.  
  7224. This variable is set to C<yes> if the user wishes
  7225. to build a shared libperl, and C<no> otherwise.
  7226.  
  7227. =item C<usesocks>
  7228.  
  7229. From F<usesocks.U>:
  7230.  
  7231. This variable conditionally defines the C<USE_SOCKS> symbol,
  7232. and indicates that Perl should be built to use C<SOCKS>.
  7233.  
  7234. =item C<usethreads>
  7235.  
  7236. From F<usethreads.U>:
  7237.  
  7238. This variable conditionally defines the C<USE_THREADS> symbol,
  7239. and indicates that Perl should be built to use threads.
  7240.  
  7241. =item C<usevendorprefix>
  7242.  
  7243. From F<vendorprefix.U>:
  7244.  
  7245. This variable tells whether the vendorprefix
  7246. and consequently other vendor* paths are in use.
  7247.  
  7248. =item C<usevfork>
  7249.  
  7250. From F<d_vfork.U>:
  7251.  
  7252. This variable is set to true when the user accepts to use vfork.
  7253. It is set to false when no vfork is available or when the user
  7254. explicitely requests not to use vfork.
  7255.  
  7256. =item C<usrinc>
  7257.  
  7258. From F<usrinc.U>:
  7259.  
  7260. This variable holds the path of the include files, which is
  7261. usually F</usr/include>. It is mainly used by other Configure units.
  7262.  
  7263. =item C<uuname>
  7264.  
  7265. From F<Loc.U>:
  7266.  
  7267. This variable is defined but not used by Configure.
  7268. The value is a plain '' and is not useful.
  7269.  
  7270. =item C<uvoformat>
  7271.  
  7272. From F<perlxvf.U>:
  7273.  
  7274. This variable contains the format string used for printing
  7275. a Perl C<UV> as an unsigned octal integer. 
  7276.  
  7277. =item C<uvsize>
  7278.  
  7279. From F<perlxv.U>:
  7280.  
  7281. This variable is the size of a C<UV> in bytes.
  7282.  
  7283. =item C<uvtype>
  7284.  
  7285. From F<perlxv.U>:
  7286.  
  7287. This variable contains the C type used for Perl's C<UV>.
  7288.  
  7289. =item C<uvuformat>
  7290.  
  7291. From F<perlxvf.U>:
  7292.  
  7293. This variable contains the format string used for printing
  7294. a Perl C<UV> as an unsigned decimal integer. 
  7295.  
  7296. =item C<uvxformat>
  7297.  
  7298. From F<perlxvf.U>:
  7299.  
  7300. This variable contains the format string used for printing
  7301. a Perl C<UV> as an unsigned hexadecimal integer in lowercase abcdef.
  7302.  
  7303. =item C<uvXUformat>
  7304.  
  7305. From F<perlxvf.U>:
  7306.  
  7307. This variable contains the format string used for printing
  7308. a Perl C<UV> as an unsigned hexadecimal integer in uppercase C<ABCDEF>.
  7309.  
  7310. =back
  7311.  
  7312. =head2 v
  7313.  
  7314. =over
  7315.  
  7316. =item C<vendorarch>
  7317.  
  7318. From F<vendorarch.U>:
  7319.  
  7320. This variable contains the value of the C<PERL_VENDORARCH> symbol.
  7321. It may have a F<~> on the front. 
  7322. The standard distribution will put nothing in this directory.
  7323. Vendors who distribute perl may wish to place their own
  7324. architecture-dependent modules and extensions in this directory with
  7325. MakeMaker F<Makefile.PL> C<INSTALLDIRS>=vendor 
  7326. or equivalent.  See C<INSTALL> for details.
  7327.  
  7328. =item C<vendorarchexp>
  7329.  
  7330. From F<vendorarch.U>:
  7331.  
  7332. This variable is the F<~name> expanded version of vendorarch, so that you
  7333. may use it directly in Makefiles or shell scripts.
  7334.  
  7335. =item C<vendorbin>
  7336.  
  7337. From F<vendorbin.U>:
  7338.  
  7339. This variable contains the eventual value of the C<VENDORBIN> symbol.
  7340. It may have a F<~> on the front.
  7341. The standard distribution will put nothing in this directory.
  7342. Vendors who distribute perl may wish to place additional
  7343. binaries in this directory with
  7344. MakeMaker F<Makefile.PL> C<INSTALLDIRS>=vendor 
  7345. or equivalent.  See C<INSTALL> for details.
  7346.  
  7347. =item C<vendorbinexp>
  7348.  
  7349. From F<vendorbin.U>:
  7350.  
  7351. This variable is the F<~name> expanded version of vendorbin, so that you
  7352. may use it directly in Makefiles or shell scripts.
  7353.  
  7354. =item C<vendorlib>
  7355.  
  7356. From F<vendorlib.U>:
  7357.  
  7358. This variable contains the eventual value of the C<VENDORLIB> symbol,
  7359. which is the name of the private library for this package.
  7360. The standard distribution will put nothing in this directory.
  7361. Vendors who distribute perl may wish to place their own
  7362. modules in this directory with
  7363. MakeMaker F<Makefile.PL> C<INSTALLDIRS>=vendor 
  7364. or equivalent.  See C<INSTALL> for details.
  7365.  
  7366. =item C<vendorlib_stem>
  7367.  
  7368. From F<vendorlib.U>:
  7369.  
  7370. This variable is $vendorlibexp with any trailing version-specific component
  7371. removed.  The elements in inc_version_list (F<inc_version_list.U>) can
  7372. be tacked onto this variable to generate a list of directories to search.
  7373.  
  7374. =item C<vendorlibexp>
  7375.  
  7376. From F<vendorlib.U>:
  7377.  
  7378. This variable is the F<~name> expanded version of vendorlib, so that you
  7379. may use it directly in Makefiles or shell scripts.
  7380.  
  7381. =item C<vendorprefix>
  7382.  
  7383. From F<vendorprefix.U>:
  7384.  
  7385. This variable holds the full absolute path of the directory below
  7386. which the vendor will install add-on packages.
  7387. See C<INSTALL> for usage and examples.
  7388.  
  7389. =item C<vendorprefixexp>
  7390.  
  7391. From F<vendorprefix.U>:
  7392.  
  7393. This variable holds the full absolute path of the directory below
  7394. which the vendor will install add-on packages.  Derived from vendorprefix.
  7395.  
  7396. =item C<version>
  7397.  
  7398. From F<patchlevel.U>:
  7399.  
  7400. The full version number of this package, such as 5.6.1 (or 5_6_1).
  7401. This combines revision, patchlevel, and subversion to get the
  7402. full version number, including any possible subversions.
  7403. This is suitable for use as a directory name, and hence is
  7404. filesystem dependent.
  7405.  
  7406. =item C<versiononly>
  7407.  
  7408. From F<versiononly.U>:
  7409.  
  7410. If set, this symbol indicates that only the version-specific
  7411. components of a perl installation should be installed.
  7412. This may be useful for making a test installation of a new
  7413. version without disturbing the existing installation.
  7414. Setting versiononly is equivalent to setting installperl's -v option.
  7415. In particular, the non-versioned scripts and programs such as
  7416. a2p, c2ph, h2xs, pod2*, and perldoc are not installed
  7417. (see C<INSTALL> for a more complete list).  Nor are the man
  7418. pages installed.
  7419. Usually, this is undef.
  7420.  
  7421. =item C<vi>
  7422.  
  7423. From F<Loc.U>:
  7424.  
  7425. This variable is defined but not used by Configure.
  7426. The value is a plain '' and is not useful.
  7427.  
  7428. =item C<voidflags>
  7429.  
  7430. From F<voidflags.U>:
  7431.  
  7432. This variable contains the eventual value of the C<VOIDFLAGS> symbol,
  7433. which indicates how much support of the void type is given by this
  7434. compiler.  See C<VOIDFLAGS> for more info.
  7435.  
  7436. =back
  7437.  
  7438. =head2 x
  7439.  
  7440. =over
  7441.  
  7442. =item C<xlibpth>
  7443.  
  7444. From F<libpth.U>:
  7445.  
  7446. This variable holds extra path (space-separated) used to find
  7447. libraries on this platform, for example C<CPU>-specific libraries
  7448. (on multi-C<CPU> platforms) may be listed here.
  7449.  
  7450. =item C<xs_apiversion>
  7451.  
  7452. From F<xs_apiversion.U>:
  7453.  
  7454. This variable contains the version of the oldest perl binary
  7455. compatible with the present perl.  F<perl.c>:incpush() and
  7456. F<lib/lib.pm> will automatically search in $sitearch for older
  7457. directories across major versions back to xs_apiversion.
  7458. This is only useful if you have a perl library directory tree
  7459. structured like the default one.
  7460. See C<INSTALL> for how this works.
  7461. The versioned site_perl directory was introduced in 5.005,
  7462. so that is the lowest possible value.
  7463. Since this can depend on compile time options (such as
  7464. bincompat) it is set by Configure.  Other non-default sources
  7465. of potential incompatibility, such as multiplicity, threads,
  7466. debugging, 64bits, sfio, F<etc.>, are not checked for currently,
  7467. though in principle we could go snooping around in old
  7468. F<Config.pm> files.
  7469.  
  7470. =back
  7471.  
  7472. =head2 z
  7473.  
  7474. =over
  7475.  
  7476. =item C<zcat>
  7477.  
  7478. From F<Loc.U>:
  7479.  
  7480. This variable is defined but not used by Configure.
  7481. The value is a plain '' and is not useful.
  7482.  
  7483. =item C<zip>
  7484.  
  7485. From F<Loc.U>:
  7486.  
  7487. This variable is used internally by Configure to determine the
  7488. full pathname (if any) of the zip program.  After Configure runs,
  7489. the value is reset to a plain C<zip> and is not useful.
  7490.  
  7491.  
  7492. =back
  7493.  
  7494. =head1 NOTE
  7495.  
  7496. This module contains a good example of how to use tie to implement a
  7497. cache and an example of how to make a tied variable readonly to those
  7498. outside of it.
  7499.  
  7500. =cut
  7501.  
  7502.