ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/rxvt-unicode/autoconf/configure.in
(Generate patch)

Comparing rxvt-unicode/autoconf/configure.in (file contents):
Revision 1.31 by root, Tue Aug 10 22:36:30 2004 UTC vs.
Revision 1.66 by root, Wed Jan 11 00:59:58 2006 UTC

1dnl# -*- sh -*- 1dnl# -*- sh -*-
2dnl# 2dnl#
3dnl# Process this file with autoconf to produce a configure script. 3dnl# Process this file with autoconf to produce a configure script.
4dnl# 4dnl#
5orig_CXXFLAGS="$CXXFLAGS"
6
5AC_INIT 7AC_INIT
6AC_CONFIG_SRCDIR([src/feature.h]) 8AC_CONFIG_SRCDIR([src/feature.h])
7AC_CONFIG_AUX_DIR(autoconf) 9AC_CONFIG_AUX_DIR(autoconf)
8AC_CONFIG_HEADER(config.h:autoconf/config.h.in) 10AC_CONFIG_HEADER(config.h:autoconf/config.h.in)
9 11
12AC_CANONICAL_HOST
13
10dnl RXVT version 14dnl RXVT version
11changequote(, )dnl 15changequote(, )dnl
12VERSION=`sed -n -e 's/^.*[ \t]VERSION.*"\(.*\)"$/\1/p' ${srcdir}/src/version.h` 16VERSION=`sed -n -e 's/^.*[ \t]VERSION.*"\(.*\)"$/\1/p' ${srcdir}/src/version.h`
13DATE=`sed -n -e 's/^.*[ \t]DATE.*"\(.*\)"$/\1/p' ${srcdir}/src/version.h` 17DATE=`sed -n -e 's/^.*[ \t]DATE.*"\(.*\)"$/\1/p' ${srcdir}/src/version.h`
14LSMDATE=`sed -n -e 's/^.*[ \t]LSMDATE.*"\(.*\)"$/\1/p' ${srcdir}/src/version.h`
15LIBVERSION=`sed -n -e 's/^.*[ \t]LIBVERSION.*"\(.*\)"$/\1/p' ${srcdir}/src/version.h` 18dnl LIBVERSION=`sed -n -e 's/^.*[ \t]LIBVERSION.*"\(.*\)"$/\1/p' ${srcdir}/src/version.h`
16changequote([, ])dnl 19changequote([, ])dnl
17AC_SUBST(VERSION)dnl 20AC_SUBST(VERSION)dnl
18AC_SUBST(DATE)dnl 21AC_SUBST(DATE)dnl
19AC_SUBST(LSMDATE)dnl 22AC_SUBST(LSMDATE)dnl
20AC_SUBST(LIBVERSION)dnl 23AC_SUBST(LIBVERSION)dnl
31AC_PROG_INSTALL 34AC_PROG_INSTALL
32AC_PROG_AWK 35AC_PROG_AWK
33 36
34AC_LANG(C) 37AC_LANG(C)
35 38
39dnl# --------------------------------------------------------------------------
40dnl# Supply default CFLAGS, if not specified by `CFLAGS=flags ./configure'
41dnl#
42if test -z "$orig_CXXFLAGS"; then
43 CXXFLAGS='-O'
44 if test x$GCC = xyes && test "x$GXX" = xyes; then
45 CXXFLAGS="-g -O3"
46 fi
47 CFLAGS="$CXXFLAGS"
48fi
49
36LINKER="$CXX" 50LINKER="$CXX"
37if test x$GCC = xyes && test x$GXX = xyes; then 51if test x$GCC = xyes && test x$GXX = xyes; then
38 AC_CHECK_LIB(supc++, main, [ 52 AC_CHECK_LIB(supc++, main, [
39 LINKER="$CC" 53 LINKER="$CC"
40 LIBS="$LIBS -lsupc++" 54 LIBS="$LIBS -lsupc++"
41 ]) 55 ])
42fi 56fi
43AC_SUBST(LINKER,[$LINKER]) 57AC_SUBST(LINKER,[$LINKER])
44 58
45CPPFLAGS="-D_GNU_SOURCE -D_XOPEN_SOURCE" 59AC_DEFINE(_GNU_SOURCE, 1, Use all glibc features.)
60
61case $host in
62 *-*-solaris* )
63 AC_DEFINE(_XOPEN_SOURCE_EXTENDED, 1, Needed to get declarations for msg_control and msg_controllen on Solaris)
64 AC_DEFINE(_XOPEN_SOURCE, 2, Needed to get declarations for msg_control and msg_controllen on Solaris)
65 AC_DEFINE(__EXTENSIONS__, 1, Needed to get declarations for msg_control and msg_controllen on Solaris)
66 ;;
67esac
46 68
47dnl if test x$GXX = xyes; then 69dnl if test x$GXX = xyes; then
48dnl CXXFLAGS="$CXXFLAGS" dnl I once had -fno-exceptions, but I am using them now... 70dnl CXXFLAGS="$CXXFLAGS" dnl I once had -fno-exceptions, but I am using them now...
49dnl fi 71dnl fi
50 72
53dnl# system hacks 75dnl# system hacks
54AC_AIX 76AC_AIX
55AC_ISC_POSIX 77AC_ISC_POSIX
56 78
57dnl# FreeBSD needs to link libxpg4 79dnl# FreeBSD needs to link libxpg4
58AC_CHECK_LIB(xpg4, setlocale, [LIBS="$LIBS -lxpg4"]) 80AC_CHECK_FUNC(setlocale, [], [AC_CHECK_LIB(xpg4, setlocale, [LIBS="$LIBS -lxpg4"])])
59 81
60dnl solaris needs to link libnsl and socket 82dnl# solaris needs to link libnsl and socket
61AC_CHECK_LIB(nsl, gethostbyname, [LIBS="$LIBS -lnsl"]) 83AC_CHECK_FUNC(gethostbyname, [], [AC_CHECK_LIB(nsl, gethostbyname, [LIBS="$LIBS -lnsl"])])
62AC_CHECK_LIB(socket, socket, [LIBS="$LIBS -lsocket"]) 84AC_CHECK_FUNC(socket, [], [AC_CHECK_LIB(socket, socket, [LIBS="$LIBS -lsocket"])])
63 85
86dnl# more solaris
87AC_CHECK_FUNC(sched_yield, [], [AC_CHECK_LIB(rt, sched_yield, [LIBS="$LIBS -lrt"])])
88
89dnl# sched_yield to improve terminal efficiency
90AC_MSG_CHECKING(for sched_yield support)
91AC_TRY_LINK([#include <sched.h>],[sched_yield ()],
92 [AC_MSG_RESULT(yes)
93 AC_DEFINE(HAVE_SCHED_YIELD, 1, Define if you have sched-h and sched_yield)],
94 [AC_MSG_RESULT(no)])
95
64AC_ENABLE_SHARED(no)dnl# libtool 96dnl AC_ENABLE_SHARED(no)dnl# libtool
65AC_ENABLE_STATIC(yes)dnl# libtool 97dnl AC_ENABLE_STATIC(yes)dnl# libtool
66AC_PROG_LIBTOOL()dnl# libtool 98dnl AC_PROG_LIBTOOL()dnl# libtool
67 99
68MALLOC_TYPE=S 100MALLOC_TYPE=S
101
69support_addstrings=no 102support_addstrings=no
70support_frills=no 103support_frills=yes
71support_linespace=no
72support_inheritpixmap=no 104support_inheritpixmap=yes
73support_tinting=no 105support_tinting=yes
74support_fading=no 106support_fading=yes
75support_keepscrolling=no 107support_keepscrolling=yes
76support_selectionscrolling=no 108support_selectionscrolling=yes
77support_menubar=no 109support_menubar=no
78support_mousewheel=no 110support_mousewheel=yes
79support_mouseslipwheel=no 111support_mouseslipwheel=yes
80support_utmp=no 112support_utmp=yes
81support_wtmp=no 113support_wtmp=yes
82support_lastlog=no 114support_lastlog=yes
83support_cursor_blink=no
84support_text_blink=no 115support_text_blink=yes
85support_pointer_blank=no 116support_pointer_blank=yes
86support_scroll_rxvt=no 117support_scroll_rxvt=yes
87support_scroll_next=no 118support_scroll_next=yes
88support_scroll_xterm=no 119support_scroll_xterm=yes
89support_scroll_plain=no 120support_scroll_plain=yes
90support_xim=no 121support_xim=yes
91support_xpm=no 122support_xpm=yes
92support_xft=no 123support_xft=yes
93support_unicode3=no 124support_unicode3=no
94support_combining=no 125support_combining=yes
95support_8bitctrls=no 126support_8bitctrls=no
127support_iso14755=yes
128support_styles=yes
129support_perl=yes
96codesets= 130codesets=all
97 131
98dnl# -------------------------------------------------------------------------- 132dnl# --------------------------------------------------------------------------
99dnl# CHECKING COMMAND LINE OPTIONS 133dnl# CHECKING COMMAND LINE OPTIONS
100dnl# -------------------------------------------------------------------------- 134dnl# --------------------------------------------------------------------------
101 135
107 141
108AC_ARG_ENABLE(everything, 142AC_ARG_ENABLE(everything,
109 [ --enable-everything enable standard non-multichoice features 143 [ --enable-everything enable standard non-multichoice features
110 NOTE: this option is order dependent 144 NOTE: this option is order dependent
111 NOTE: automatically enabled with --enable-shared], 145 NOTE: automatically enabled with --enable-shared],
146 [
147 if test x$enableval = xno; then
148 support_24bit=no
149 support_frills=no
150 support_inheritpixmap=no
151 support_tinting=no
152 support_fading=no
153 support_keepscrolling=no
154 support_selectionscrolling=no
155 support_lastlog=no
156 support_menubar=no
157 support_mousewheel=no
158 support_mouseslipwheel=no
159 support_text_blink=no
160 support_pointer_blank=no
161 support_scroll_rxvt=no
162 support_scroll_next=no
163 support_scroll_xterm=no
164 support_scroll_plain=no
165 support_utmp=no
166 support_wtmp=no
167 support_xim=no
168 support_xpm=no
169 support_xft=no
170 support_unicode3=no
171 support_combining=no
172 support_8bitctrls=no
173 support_iso14755=no
174 support_styles=no
175 support_perl=no
176 codesets=
177 fi
112 [if test x$enableval = xyes; then 178 if test x$enableval = xyes; then
113 support_24bit=yes 179 support_24bit=yes
114 support_frills=yes 180 support_frills=yes
115 support_linespace=yes
116 support_inheritpixmap=yes 181 support_inheritpixmap=yes
117 support_tinting=yes 182 support_tinting=yes
118 support_fading=yes 183 support_fading=yes
119 support_keepscrolling=yes 184 support_keepscrolling=yes
120 support_selectionscrolling=yes 185 support_selectionscrolling=yes
121 support_lastlog=yes 186 support_lastlog=yes
122 support_menubar=yes 187 support_menubar=yes
123 support_mousewheel=yes 188 support_mousewheel=yes
124 support_mouseslipwheel=yes 189 support_mouseslipwheel=yes
125 support_cursor_blink=yes
126 support_text_blink=yes 190 support_text_blink=yes
127 support_pointer_blank=yes 191 support_pointer_blank=yes
128 support_scroll_rxvt=yes 192 support_scroll_rxvt=yes
129 support_scroll_next=yes 193 support_scroll_next=yes
130 support_scroll_xterm=yes 194 support_scroll_xterm=yes
131 support_scroll_plain=yes 195 support_scroll_plain=yes
132 support_utmp=yes 196 support_utmp=yes
133 support_wtmp=yes 197 support_wtmp=yes
134 support_xim=yes 198 support_xim=yes
135 support_xpm=yes 199 support_xpm=yes
136 support_xft=yes 200 support_xft=yes
137 support_unicode3=yes 201 support_unicode3=yes
138 support_combining=yes 202 support_combining=yes
139 #support_8bitctrls=yes 203 #support_8bitctrls=yes
204 support_iso14755=yes
205 support_styles=yes
206 support_perl=yes
140 codesets=all 207 codesets=all
208 fi
141 fi]) 209 ])
142 210
143AC_ARG_ENABLE(unicode3, 211AC_ARG_ENABLE(unicode3,
144 [ --enable-unicode3 use 21 instead of 16 bits to represent unicode characters], 212 [ --enable-unicode3 use 21 instead of 16 bits to represent unicode characters],
145 [if test x$enableval = xyes -o x$enableval = xno; then 213 [if test x$enableval = xyes -o x$enableval = xno; then
146 support_unicode3=yes 214 support_unicode3=$enableval
147 fi]) 215 fi])
148 216
149AC_ARG_ENABLE(combining, 217AC_ARG_ENABLE(combining,
150 [ --enable-combining enable composition of base and combining characters], 218 [ --enable-combining enable composition of base and combining characters],
151 [if test x$enableval = xyes -o x$enableval = xno; then 219 [if test x$enableval = xyes -o x$enableval = xno; then
152 support_combining=yes 220 support_combining=$enableval
153 fi]) 221 fi])
154 222
155AC_ARG_ENABLE(xft, 223AC_ARG_ENABLE(xft,
156 [ --enable-xft enable xft support on systems that have it], 224 [ --enable-xft enable xft support on systems that have it],
157 [if test x$enableval = xyes -o x$enableval = xno; then 225 [if test x$enableval = xyes -o x$enableval = xno; then
158 support_xft=yes 226 support_xft=$enableval
227 fi])
228
229AC_ARG_ENABLE(font-styles,
230 [ --enable-font-styles enable bold and italic support],
231 [if test x$enableval = xyes -o x$enableval = xno; then
232 support_styles=$enableval
159 fi]) 233 fi])
160 234
161AC_ARG_ENABLE(utmp, 235AC_ARG_ENABLE(utmp,
162 [ --enable-utmp enable utmp (utmpx) support], 236 [ --enable-utmp enable utmp (utmpx) support],
163 [if test x$enableval = xyes -o x$enableval = xno; then 237 [if test x$enableval = xyes -o x$enableval = xno; then
220 294
221AC_ARG_ENABLE(xterm-scroll, 295AC_ARG_ENABLE(xterm-scroll,
222 [ --enable-xterm-scroll enable Xterm style scrollbar], 296 [ --enable-xterm-scroll enable Xterm style scrollbar],
223 [if test x$enableval = xyes -o x$enableval = xno; then 297 [if test x$enableval = xyes -o x$enableval = xno; then
224 support_scroll_xterm=$enableval 298 support_scroll_xterm=$enableval
299 fi])
300
301AC_ARG_ENABLE(perl,
302 [ --enable-perl enable embedded perl interpreter],
303 [if test x$enableval = xyes -o x$enableval = xno; then
304 support_perl=$enableval
225 fi]) 305 fi])
226 306
227AC_ARG_ENABLE(plain-scroll, 307AC_ARG_ENABLE(plain-scroll,
228 [ --enable-plain-scroll enable plain style scrollbar], 308 [ --enable-plain-scroll enable plain style scrollbar],
229 [if test x$enableval = xyes -o x$enableval = xno; then 309 [if test x$enableval = xyes -o x$enableval = xno; then
235 [if test x$enableval = xyes; then 315 [if test x$enableval = xyes; then
236 AC_DEFINE(HALFSHADOW, 1, Define if you want the depth of scrollbars and menus to be less) 316 AC_DEFINE(HALFSHADOW, 1, Define if you want the depth of scrollbars and menus to be less)
237 fi]) 317 fi])
238 318
239AC_ARG_WITH(codesets, 319AC_ARG_WITH(codesets,
240 [ --with-codesets=NAME,.. compile in additional codesets (jp,jp_ext,kr,cn,cn_ext,all)], 320 [ --with-codesets=NAME,.. compile in additional codesets (jp,jp_ext,kr,zh,zh_ext,all)],
241 [codesets="$withval"]) 321 [codesets="$withval"])
242 322
243AC_ARG_ENABLE(xim, 323AC_ARG_ENABLE(xim,
244 [ --enable-xim XIM (X Input Method) protocol support], 324 [ --enable-xim XIM (X Input Method) protocol support],
245 [if test x$enableval = xyes -o x$enableval = xno; then 325 [if test x$enableval = xyes -o x$enableval = xno; then
268 [ --disable-resources disable all resource checking], 348 [ --disable-resources disable all resource checking],
269 [if test x$enableval = xno; then 349 [if test x$enableval = xno; then
270 AC_DEFINE(NO_RESOURCES, 1, Define if you don't want any resources read) 350 AC_DEFINE(NO_RESOURCES, 1, Define if you don't want any resources read)
271 fi]) 351 fi])
272 352
273AC_ARG_ENABLE(xgetdefault,
274 [ --enable-xgetdefault enable resources via X instead of our small version],
275 [if test x$enableval = xyes; then
276 AC_DEFINE(USE_XGETDEFAULT, 1, Define if you want to use XGetDefault instead of our internal version)
277 fi])
278
279AC_ARG_ENABLE(8bitctrls, 353AC_ARG_ENABLE(8bitctrls,
280 [ --enable-8bitctrls enable 8 bit control sequences (not recommended)], 354 [ --enable-8bitctrls enable 8 bit control sequences (not recommended)],
281 [if test x$enableval = xyes -o x$enableval = xno; then 355 [if test x$enableval = xyes -o x$enableval = xno; then
282 support_8bitctrls=yes 356 support_8bitctrls=$enableval
283 fi]) 357 fi])
284 358
285RESFALLBACK=Rxvt 359RESFALLBACK=Rxvt
286AC_ARG_ENABLE(fallback, 360AC_ARG_ENABLE(fallback,
287 [ --enable-fallback(=CLASS) fall back on CLASS resources in addition to URxvt ones (default: Rxvt)], 361 [ --enable-fallback(=CLASS) fall back on CLASS resources in addition to URxvt ones (default: Rxvt)],
309 383
310RXVTNAME=urxvt 384RXVTNAME=urxvt
311AC_ARG_WITH(name, 385AC_ARG_WITH(name,
312 [ --with-name=NAME set the basename for the installed binaries (default: urxvt)], 386 [ --with-name=NAME set the basename for the installed binaries (default: urxvt)],
313 [RXVTNAME="$withval"]) 387 [RXVTNAME="$withval"])
388AC_DEFINE_UNQUOTED(RXVTNAME,"$RXVTNAME", [Binary base name])
314 389
315RXVTNAME=`echo "$RXVTNAME"|sed "$program_transform_name"` 390RXVTNAME=`echo "$RXVTNAME"|sed "$program_transform_name"`
316AC_SUBST(RXVTNAME) 391AC_SUBST(RXVTNAME)
317 392
318AC_ARG_ENABLE(strings, 393AC_ARG_ENABLE(strings,
325 [ --disable-swapscreen disable swap screen support], 400 [ --disable-swapscreen disable swap screen support],
326 [if test x$enableval = xno; then 401 [if test x$enableval = xno; then
327 AC_DEFINE(NO_SECONDARY_SCREEN, 1, Disable the secondary screen. Many programs use the secondary screen as their workplace) 402 AC_DEFINE(NO_SECONDARY_SCREEN, 1, Disable the secondary screen. Many programs use the secondary screen as their workplace)
328 fi]) 403 fi])
329 404
405AC_ARG_ENABLE(iso14755,
406 [ --enable-iso14755 enable support for extended ISO 14755 modes],
407 [if test x$enableval = xyes -o x$enableval = xno; then
408 support_iso14755=$enableval
409 fi])
410
330AC_ARG_ENABLE(frills, 411AC_ARG_ENABLE(frills,
331 [ --enable-frills enable support for rarely used features], 412 [ --enable-frills enable support for rarely used features],
332 [if test x$enableval = xyes -o x$enableval = xno; then 413 [if test x$enableval = xyes -o x$enableval = xno; then
333 support_frills=$enableval 414 support_frills=$enableval
334 fi])
335
336AC_ARG_ENABLE(linespace,
337 [ --enable-linespace enable support for linespace],
338 [if test x$enableval = xyes -o x$enableval = xno; then
339 support_linespace=$enableval
340 fi]) 415 fi])
341 416
342AC_ARG_ENABLE(24bit, 417AC_ARG_ENABLE(24bit,
343 [ --enable-24bit enable support for using 24bit visuals if available], 418 [ --enable-24bit enable support for using 24bit visuals if available],
344 [if test x$enableval = xyes -o x$enableval = xno; then 419 [if test x$enableval = xyes -o x$enableval = xno; then
392 [ --enable-smart-resize enable smart growth/shrink behaviour], 467 [ --enable-smart-resize enable smart growth/shrink behaviour],
393 [if test x$enableval = xyes; then 468 [if test x$enableval = xyes; then
394 AC_DEFINE(SMART_RESIZE, 1, Define to use "smart" resize behavior) 469 AC_DEFINE(SMART_RESIZE, 1, Define to use "smart" resize behavior)
395 fi]) 470 fi])
396 471
397AC_ARG_ENABLE(256-color,
398 [ --enable-256-color enable 256-color support],
399 [if test x$enableval = xyes; then
400 AC_DEFINE(TTY_256COLOR, 1, Define if you want 256 colour support)
401 fi])
402
403AC_ARG_ENABLE(cursor-blink,
404 [ --enable-cursor-blink enable blinking cursor],
405 [if test x$enableval = xyes -o x$enableval = xno; then
406 support_cursor_blink=$enableval
407 fi])
408
409AC_ARG_ENABLE(text-blink, 472AC_ARG_ENABLE(text-blink,
410 [ --enable-text-blink enable blinking text], 473 [ --enable-text-blink enable blinking text],
411 [if test x$enableval = xyes -o x$enableval = xno; then 474 [if test x$enableval = xyes -o x$enableval = xno; then
412 support_text_blink=$enableval 475 support_text_blink=$enableval
413 fi]) 476 fi])
431 fi]) 494 fi])
432 495
433dnl# -------------------------------------------------------------------------- 496dnl# --------------------------------------------------------------------------
434 497
435AC_DEFINE(PROTOTYPES, 1, Define if you need function prototypes) 498AC_DEFINE(PROTOTYPES, 1, Define if you need function prototypes)
436
437dnl# --------------------------------------------------------------------------
438dnl# Supply default CFLAGS, if not specified by `CFLAGS=flags ./configure'
439dnl#
440if test -z "$CFLAGS"; then
441 if test -z "$CCOPTS"; then
442 CCOPTS='-O'
443dnl> if test "x$GCC" = xyes; then
444dnl> if test x$system = xLinux; then
445dnl> CCOPTS="$CCOPTS "'-O2 -fno-strength-reduce'
446dnl> fi
447dnl> fi
448 fi
449 CFLAGS="$CCOPTS"
450fi
451 499
452AC_PATH_PROG(MV, mv, mv) 500AC_PATH_PROG(MV, mv, mv)
453AC_PATH_PROG(RM, rm, rm) 501AC_PATH_PROG(RM, rm, rm)
454AC_PATH_PROG(CP, cp, cp) 502AC_PATH_PROG(CP, cp, cp)
455AC_PATH_PROG(LN, ln, ln) 503AC_PATH_PROG(LN, ln, ln)
456AC_PATH_PROG(SED, sed, sed) 504AC_PATH_PROG(SED, sed, sed)
457AC_PATH_PROG(ECHO, echo, echo) 505AC_PATH_PROG(ECHO, echo, echo)
458AC_PATH_PROG(CMP, cmp, cmp) 506AC_PATH_PROG(CMP, cmp, cmp)
459AC_PATH_PROG(TBL, tbl) 507AC_PATH_PROG(TBL, tbl)
508AC_PATH_PROG(TIC, tic)
460 509
461dnl# need a neat way to detect SVR4 or its features 510dnl# need a neat way to detect SVR4 or its features
462dnl# in src/command.c we use these functions: 511dnl# in src/command.c we use these functions:
463dnl# grantpt(), unlockpt(), ptsname(), which are defined in <sys/ptms.h> 512dnl# grantpt(), unlockpt(), ptsname(), which are defined in <sys/ptms.h>
464dnl# - but are these also defined for other systems? 513dnl# - but are these also defined for other systems?
501 sys/byteorder.h \ 550 sys/byteorder.h \
502 sys/ioctl.h \ 551 sys/ioctl.h \
503 sys/select.h \ 552 sys/select.h \
504 sys/sockio.h \ 553 sys/sockio.h \
505 sys/strredir.h \ 554 sys/strredir.h \
555 sys/stropts.h \
506 sys/time.h \ 556 sys/time.h \
507 utmp.h \ 557 utmp.h \
508 utmpx.h \ 558 utmpx.h \
509 stdint.h \ 559 stdint.h \
560 pty.h \
561 util.h \
562 libutil.h \
563 wchar.h \
564 cwchar \
565 clocale \
510) 566)
511 567
512AC_HEADER_TIME 568AC_HEADER_TIME
513 569
514dnl# check to allow both <termios.h> and <sys/ioctl.h> 570dnl# check to allow both <termios.h> and <sys/ioctl.h>
582dnl> AC_CHECK_TYPE(umode_t, int) 638dnl> AC_CHECK_TYPE(umode_t, int)
583dnl> AC_CHECK_TYPE(off_t, long) 639dnl> AC_CHECK_TYPE(off_t, long)
584AC_TYPE_PID_T 640AC_TYPE_PID_T
585AC_TYPE_UID_T 641AC_TYPE_UID_T
586 642
587
588AC_CHECK_SIZEOF(char, 1)
589AC_CHECK_SIZEOF(short, 2) 643AC_CHECK_SIZEOF(short, 2)
590AC_CHECK_SIZEOF(int, 4) 644AC_CHECK_SIZEOF(int, 4)
591AC_CHECK_SIZEOF(long, 4) 645dnl AC_CHECK_SIZEOF(long, 4)
592AC_CHECK_SIZEOF(long long, 8) 646AC_CHECK_SIZEOF(long long, 8)
593AC_CHECK_SIZEOF(int *, 4) 647AC_CHECK_SIZEOF(int *, 4)
594 648
595dnl# see usage below 649dnl# see usage below
596AC_DEFUN(RXVT_CHECK_SIZE, 650AC_DEFUN(RXVT_CHECK_SIZE,
597 [AC_CACHE_CHECK([for $2], $1, 651 [AC_CACHE_CHECK([for $2], $1,
598 [AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[#include <stdint.h>]], [[$2 dummy;]])],[$1=yes],[dnl 652 [AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[#include <stdint.h>]], [[$2 dummy;]])],[$1=yes],[dnl
599if test $ac_cv_sizeof_char -ge $3; then 653if test "$ac_cv_sizeof_char" -ge $3; then
600 $1="$4 char" 654 $1="$4 char"
601else 655else
602 if test $ac_cv_sizeof_short -ge $3; then 656 if test "$ac_cv_sizeof_short" -ge $3; then
603 $1="$4 short" 657 $1="$4 short"
604 else 658 else
605 if test $ac_cv_sizeof_int -ge $3; then 659 if test "$ac_cv_sizeof_int" -ge $3; then
606 $1="$4 int" 660 $1="$4 int"
607 else 661 else
608 if test $ac_cv_sizeof_long -ge $3; then 662 if test "$ac_cv_sizeof_long" -ge $3; then
609 $1="$4 long" 663 $1="$4 long"
610 else 664 else
611 if test $ac_cv_sizeof_long_long -ge $3; then 665 if test "$ac_cv_sizeof_long_long" -ge $3; then
612 $1="$4 long long" 666 $1="$4 long long"
613 else 667 else
614 $1="$4 $5" # we _must_ have a (possibly wrong) default 668 $1="$4 $5" # we _must_ have a (possibly wrong) default
615 fi 669 fi
616 fi 670 fi
643dnl RXVT_CHECK_SIZE(rxvt_cv_uint64_t, uint64_t, 8, unsigned, long long, rxvt_uint64_typedef) 697dnl RXVT_CHECK_SIZE(rxvt_cv_uint64_t, uint64_t, 8, unsigned, long long, rxvt_uint64_typedef)
644dnl AC_SUBST(rxvt_uint64_typedef) 698dnl AC_SUBST(rxvt_uint64_typedef)
645dnl# 699dnl#
646dnl# Now look for another we use 700dnl# Now look for another we use
647dnl# 701dnl#
648if test $ac_cv_sizeof_int_p -eq 8; then 702if test "$ac_cv_sizeof_int_p" -eq 8; then
649 rxvt_intp_define="#define intp_t int64_t" 703 rxvt_intp_define="#define intp_t int64_t"
650 rxvt_u_intp_define="#define u_intp_t u_int64_t" 704 rxvt_u_intp_define="#define u_intp_t u_int64_t"
651else 705else
652 if test $ac_cv_sizeof_int_p -eq 4; then 706 if test "$ac_cv_sizeof_int_p" -eq 4; then
653 rxvt_intp_define="#define intp_t int32_t" 707 rxvt_intp_define="#define intp_t int32_t"
654 rxvt_u_intp_define="#define u_intp_t u_int32_t" 708 rxvt_u_intp_define="#define u_intp_t u_int32_t"
655 else 709 else
656 if test $ac_cv_sizeof_int_p -eq 2; then 710 if test "$ac_cv_sizeof_int_p" -eq 2; then
657 rxvt_intp_define="#define intp_t int16_t" 711 rxvt_intp_define="#define intp_t int16_t"
658 rxvt_u_intp_define="#define u_intp_t u_int16_t" 712 rxvt_u_intp_define="#define u_intp_t u_int16_t"
659 else 713 else
660 rxvt_intp_define="#error set intp_t" 714 rxvt_intp_define="#error set intp_t"
661 rxvt_u_intp_define="#error set u_intp_t" 715 rxvt_u_intp_define="#error set u_intp_t"
693 unlockpt \ 747 unlockpt \
694 isastream \ 748 isastream \
695 on_exit \ 749 on_exit \
696 nanosleep \ 750 nanosleep \
697 updwtmp \ 751 updwtmp \
752 updwtmpx \
698 ttyslot \ 753 ttyslot \
699) 754)
700dnl# Note: On NetBSD, openpty() exists in libutil. Don't pull it in 755dnl# Note: On NetBSD, openpty() exists in libutil. Don't pull it in
701 756
702dnl# -------------------------------------------------------------------------- 757dnl# --------------------------------------------------------------------------
745[AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[#include <sys/types.h> 800[AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[#include <sys/types.h>
746#include <utmpx.h>]], [[struct utmpx utx; utx.ut_host;]])],[rxvt_cv_struct_utmpx_host=yes],[rxvt_cv_struct_utmpx_host=no])]) 801#include <utmpx.h>]], [[struct utmpx utx; utx.ut_host;]])],[rxvt_cv_struct_utmpx_host=yes],[rxvt_cv_struct_utmpx_host=no])])
747if test x$rxvt_cv_struct_utmpx_host = xyes; then 802if test x$rxvt_cv_struct_utmpx_host = xyes; then
748 AC_DEFINE(HAVE_UTMPX_HOST, 1, Define if struct utmpx contains ut_host) 803 AC_DEFINE(HAVE_UTMPX_HOST, 1, Define if struct utmpx contains ut_host)
749fi 804fi
805
806AC_CACHE_CHECK(for session in utmpx struct, rxvt_cv_struct_utmpx_session,
807[AC_TRY_COMPILE([#include <sys/types.h>
808#include <utmpx.h>],
809[struct utmpx utx; utx.ut_session;],
810rxvt_cv_struct_utmpx_session=yes, rxvt_cv_struct_utmpx_session=no)])
811if test x$rxvt_cv_struct_utmpx_session = xyes; then
812 AC_DEFINE(HAVE_UTMPX_SESSION, 1, Define if struct utmpx contains ut_session)
813fi
750) dnl# AC_CHECK_HEADER(utmpx.h 814) dnl# AC_CHECK_HEADER(utmpx.h
751
752 815
753dnl# -------------------------------------------------------------------------- 816dnl# --------------------------------------------------------------------------
754dnl# check for struct lastlog 817dnl# check for struct lastlog
755AC_CACHE_CHECK(for struct lastlog, rxvt_cv_struct_lastlog, 818AC_CACHE_CHECK(for struct lastlog, rxvt_cv_struct_lastlog,
756[AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[#include <sys/types.h> 819[AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[#include <sys/types.h>
1066 1129
1067AC_CACHE_CHECK(for working nl_langinfo, rxvt_cv_func_nl_langinfo, 1130AC_CACHE_CHECK(for working nl_langinfo, rxvt_cv_func_nl_langinfo,
1068[AC_LINK_IFELSE([AC_LANG_PROGRAM([[#include <langinfo.h>]], [[nl_langinfo(CODESET);]])],[rxvt_cv_func_nl_langinfo=yes],[rxvt_cv_func_nl_langinfo=no])]) 1131[AC_LINK_IFELSE([AC_LANG_PROGRAM([[#include <langinfo.h>]], [[nl_langinfo(CODESET);]])],[rxvt_cv_func_nl_langinfo=yes],[rxvt_cv_func_nl_langinfo=no])])
1069if test x$rxvt_cv_func_nl_langinfo = xyes; then 1132if test x$rxvt_cv_func_nl_langinfo = xyes; then
1070 AC_DEFINE(HAVE_NL_LANGINFO, 1, Define if nl_langinfo(CODESET) works) 1133 AC_DEFINE(HAVE_NL_LANGINFO, 1, Define if nl_langinfo(CODESET) works)
1134fi
1135
1136AC_CACHE_CHECK(for unix-compliant filehandle passing ability, rxvt_can_pass_fds,
1137[AC_TRY_LINK([
1138#include <sys/types.h>
1139#include <sys/socket.h>
1140],[
1141{
1142 msghdr msg;
1143 iovec iov;
1144 char buf [100];
1145 char data = 0;
1146
1147 iov.iov_base = &data;
1148 iov.iov_len = 1;
1149
1150 msg.msg_iov = &iov;
1151 msg.msg_iovlen = 1;
1152 msg.msg_control = buf;
1153 msg.msg_controllen = sizeof buf;
1154
1155 cmsghdr *cmsg = CMSG_FIRSTHDR (&msg);
1156 cmsg->cmsg_level = SOL_SOCKET;
1157 cmsg->cmsg_type = SCM_RIGHTS;
1158 cmsg->cmsg_len = 100;
1159
1160 *(int *)CMSG_DATA (cmsg) = 5;
1161
1162 return sendmsg (3, &msg, 0);
1163}
1164],[rxvt_can_pass_fds=yes],[rxvt_can_pass_fds=no])])
1165if test x$rxvt_can_pass_fds = xyes; then
1166 AC_DEFINE(HAVE_UNIX_FDPASS, 1, Define if sys/socket.h defines the necessary macros/functions for file handle passing)
1071fi 1167fi
1072 1168
1073AC_CACHE_CHECK(for broken XIM callback, rxvt_broken_ximcb, 1169AC_CACHE_CHECK(for broken XIM callback, rxvt_broken_ximcb,
1074[AC_COMPILE_IFELSE([ 1170[AC_COMPILE_IFELSE([
1075#include <X11/Xlib.h> 1171#include <X11/Xlib.h>
1170fi 1266fi
1171 1267
1172dnl# -------------------------------------------------------------------------- 1268dnl# --------------------------------------------------------------------------
1173dnl# now add and remove other stuff 1269dnl# now add and remove other stuff
1174dnl# -------------------------------------------------------------------------- 1270dnl# --------------------------------------------------------------------------
1271if test x$support_xft = xyes; then
1272 LIBS="$LIBS `pkg-config xft --libs`"
1273 CPPFLAGS="$CPPFLAGS `pkg-config xft --cflags`"
1274
1275 AC_CHECK_HEADERS(X11/Xft/Xft.h,,[support_xft=no])
1276 AC_CHECK_LIB(Xft,XftDrawString32,,[support_xft=no])
1277
1278 if test x$support_xft = xyes; then
1279 AC_DEFINE(XFT, 1, Define to enable xft support)
1280 fi
1281fi
1282if test x$support_styles = xyes; then
1283 AC_DEFINE(ENABLE_STYLES, 1, Define if you want bold and italic support)
1284fi
1285if test x$support_iso14755 = xyes; then
1286 AC_DEFINE(ISO_14755, 1, Define if you want ISO 14755 extended support)
1287fi
1175if test x$support_8bitctrls = xyes; then 1288if test x$support_8bitctrls = xyes; then
1176 AC_DEFINE(EIGHT_BIT_CONTROLS, 1, Define if you want 8 bit control sequences) 1289 AC_DEFINE(EIGHT_BIT_CONTROLS, 1, Define if you want 8 bit control sequences)
1177fi 1290fi
1178if test x$support_fading = xyes; then 1291if test x$support_fading = xyes; then
1179 AC_DEFINE(OFF_FOCUS_FADING, 1, Define if you want faded colors when focus is lost) 1292 AC_DEFINE(OFF_FOCUS_FADING, 1, Define if you want faded colors when focus is lost)
1191 AC_DEFINE(SELECTION_SCROLLING, 1, Define to allow scrolling when the selection moves to the top or bottom of the screen) 1304 AC_DEFINE(SELECTION_SCROLLING, 1, Define to allow scrolling when the selection moves to the top or bottom of the screen)
1192fi 1305fi
1193if test x$support_menubar = xyes; then 1306if test x$support_menubar = xyes; then
1194 AC_DEFINE(MENUBAR, 1, Define if you want Menubar support) 1307 AC_DEFINE(MENUBAR, 1, Define if you want Menubar support)
1195fi 1308fi
1196if test x$support_frills = xno; then 1309if test x$support_frills = xyes; then
1197 AC_DEFINE(NO_FRILLS, 1, Define if you don't want handling for rarely used features) 1310 AC_DEFINE(ENABLE_FRILLS, 1, Define if you want handling for rarely used but handy features)
1198fi
1199if test x$support_linespace = xno; then
1200 AC_DEFINE(NO_LINESPACE, 1, Define if you don't want support linespace)
1201fi 1311fi
1202if test x$support_24bit = xyes; then 1312if test x$support_24bit = xyes; then
1203 AC_DEFINE(PREFER_24BIT, 1, Define to use a 24 bit visual if the screen has 24 bit mode, even if the default is 8 bit) 1313 AC_DEFINE(PREFER_24BIT, 1, Define to use a 24 bit visual if the screen has 24 bit mode, even if the default is 8 bit)
1204fi 1314fi
1205if test x$support_mousewheel = xyes; then 1315if test x$support_mousewheel = xyes; then
1242 scrolltypes="$scrolltypes plain" 1352 scrolltypes="$scrolltypes plain"
1243fi 1353fi
1244if test x$support_pointer_blank = xyes; then 1354if test x$support_pointer_blank = xyes; then
1245 AC_DEFINE(POINTER_BLANK, 1, Define if you want hide the pointer while typing) 1355 AC_DEFINE(POINTER_BLANK, 1, Define if you want hide the pointer while typing)
1246fi 1356fi
1247if test x$support_cursor_blink = xyes; then
1248 AC_DEFINE(CURSOR_BLINK, 1, Define if you want blinking cursor support)
1249fi
1250if test x$support_text_blink = xyes; then 1357if test x$support_text_blink = xyes; then
1251 AC_DEFINE(TEXT_BLINK, 1, Define if you want blinking text support) 1358 AC_DEFINE(TEXT_BLINK, 1, Define if you want blinking text support)
1252fi 1359fi
1253if test x$support_unicode3 = xyes; then 1360if test x$support_unicode3 = xyes; then
1254 AC_DEFINE(UNICODE_3, 1, Define if you want to represent unicode characters outside plane 0) 1361 AC_DEFINE(UNICODE_3, 1, Define if you want to represent unicode characters outside plane 0)
1255fi 1362fi
1256if test x$support_combining = xyes; then 1363if test x$support_combining = xyes; then
1257 AC_DEFINE(ENABLE_COMBINING, 1, Define if you want to automatically compose combining characters) 1364 AC_DEFINE(ENABLE_COMBINING, 1, Define if you want to automatically compose combining characters)
1258fi 1365fi
1259if test x$codesets = xall; then 1366if test x$codesets = xall; then
1260 codesets=jp,jp-ext,kr,cn,cn-ext 1367 codesets=jp,jp-ext,kr,zh,zh-ext
1261fi 1368fi
1369AC_DEFINE(ENCODING_EU, 1, Define if you want european extended codesets)
1370AC_DEFINE(ENCODING_VN, 1, Define if you want vietnamese codesets)
1262for codeset in `echo $codesets | tr "[a-z,\\-]" "[A-Z _]"`; do 1371for codeset in `echo $codesets | tr "[a-z,\\-]" "[A-Z _]"`; do
1263 AC_DEFINE(ENCODING_EU, 1, Define if you want european extended codesets)
1264 AC_DEFINE(ENCODING_VN, 1, Define if you want vietnamese codesets)
1265 case "$codeset" in 1372 case "$codeset" in
1266 JP ) AC_DEFINE(ENCODING_JP, 1, Define if you want japanese codesets) ;; 1373 JP ) AC_DEFINE(ENCODING_JP, 1, Define if you want japanese codesets) ;;
1267 JP_EXT ) AC_DEFINE(ENCODING_JP_EXT, 1, Define if you want extended japanese codesets) ;; 1374 JP_EXT ) AC_DEFINE(ENCODING_JP_EXT, 1, Define if you want extended japanese codesets) ;;
1268 KR ) AC_DEFINE(ENCODING_KR, 1, Define if you want korean codesets) ;; 1375 KR ) AC_DEFINE(ENCODING_KR, 1, Define if you want korean codesets) ;;
1269 CN ) AC_DEFINE(ENCODING_CN, 1, Define if you want chinese codesets) ;; 1376 ZH ) AC_DEFINE(ENCODING_ZH, 1, Define if you want chinese codesets) ;;
1270 CN_EXT ) AC_DEFINE(ENCODING_CN_EXT, 1, Define if you want extended chinese codesets) ;; 1377 ZH_EXT ) AC_DEFINE(ENCODING_ZH_EXT, 1, Define if you want extended chinese codesets) ;;
1271 esac 1378 esac
1272done 1379done
1380
1381IF_PERL=\#
1382if test x$support_perl = xyes; then
1383 AC_PATH_PROG(PERL, perl5)
1384 AC_PATH_PROG(PERL, perl)
1385
1386 AC_MSG_CHECKING(for $PERL suitability)
1387 if $PERL -MExtUtils::Embed -e "use v5.8" >/dev/null 2>/dev/null; then
1388
1389 save_CXXFLAGS="$CXXFLAGS"
1390 save_LIBS="$LIBS"
1391 CXXFLAGS="$CXXFLAGS `$PERL -MExtUtils::Embed -e ccopts`"
1392 LIBS="$LIBS `$PERL -MExtUtils::Embed -e ldopts`"
1393 AC_TRY_LINK([
1394#include <EXTERN.h>
1395#include <perl.h>
1396#include <XSUB.h>
1397],[
1398 PerlInterpreter *perl = perl_alloc ();
1399],[rxvt_perl_link=yes],[rxvt_perl_link=no])
1400 CXXFLAGS="$save_CXXFLAGS"
1401 LIBS="$save_LIBS"
1402
1403 if test x$rxvt_perl_link = xyes; then
1404 AC_MSG_RESULT(ok)
1405 AC_DEFINE(ENABLE_PERL, 1, Define if you can embed a perl interpreter)
1406 IF_PERL=
1407 PERL_O=rxvtperl.o
1408 PERLFLAGS="`$PERL -MExtUtils::Embed -e ccopts`"
1409 PERLLIB="`$PERL -MExtUtils::Embed -e ldopts`"
1410 PERLPRIVLIBEXP="`$PERL -MConfig -e 'print $Config{privlibexp}'`"
1411 else
1412 support_perl=no
1413 AC_MSG_RESULT([no, unable to link])
1414 fi
1415 else
1416 AC_MSG_ERROR(no working perl found, or perl not version >= 5.8)
1417 support_perl=no
1418 fi
1419fi
1420AC_SUBST(PERLLIB)
1421AC_SUBST(PERLFLAGS)
1422AC_SUBST(PERLPRIVLIBEXP)
1423AC_SUBST(PERL)
1424AC_SUBST(IF_PERL)
1425AC_SUBST(PERL_O)
1426
1427if text x$support_perl = xyes; then
1428 support_frills=yes
1429fi
1273 1430
1274dnl> AC_CHECK_FUNCS(gettimeofday putenv select socket) 1431dnl> AC_CHECK_FUNCS(gettimeofday putenv select socket)
1275 1432
1276CFLAGS=${CFLAGS--O} 1433CFLAGS=${CFLAGS--O}
1277LDFLAGS=${LDFLAGS--O} 1434LDFLAGS=${LDFLAGS--O}
1330RXVT_DEFINE_TO_INCLUDE(include_sys_select_h, sys/select.h, ac_cv_header_sys_select_h, yes, notset, dontmatch) 1487RXVT_DEFINE_TO_INCLUDE(include_sys_select_h, sys/select.h, ac_cv_header_sys_select_h, yes, notset, dontmatch)
1331RXVT_DEFINE_TO_INCLUDE(include_sys_strredir_h, sys/strredir.h, ac_cv_header_sys_strredir_h, yes, notset, dontmatch) 1488RXVT_DEFINE_TO_INCLUDE(include_sys_strredir_h, sys/strredir.h, ac_cv_header_sys_strredir_h, yes, notset, dontmatch)
1332RXVT_DEFINE_TO_INCLUDE(include_sys_time_h, sys/time.h, ac_cv_header_sys_time_h, yes, notset, dontmatch) 1489RXVT_DEFINE_TO_INCLUDE(include_sys_time_h, sys/time.h, ac_cv_header_sys_time_h, yes, notset, dontmatch)
1333RXVT_DEFINE_TO_INCLUDE(include_time_h, time.h, ac_cv_header_sys_time_h, no, ac_cv_header_time, yes) 1490RXVT_DEFINE_TO_INCLUDE(include_time_h, time.h, ac_cv_header_sys_time_h, no, ac_cv_header_time, yes)
1334 1491
1335if test x$support_xft = xyes; then
1336 LIBS="$LIBS `pkg-config xft --libs`"
1337 CFLAGS="$CFLAGS `pkg-config xft --cflags`"
1338 CPPFLAGS="$CPPFLAGS `pkg-config xft --cflags`"
1339
1340 AC_CHECK_HEADERS(X11/Xft/Xft.h,,[support_xft=no])
1341 AC_CHECK_LIB(Xft,XftDrawString32,,[support_xft=no])
1342
1343 if test x$support_xft = xyes; then
1344 AC_DEFINE(XFT, 1, Define to enable xft support)
1345 fi
1346fi
1347
1348AC_CONFIG_FILES([autoconf/Make.common \ 1492AC_CONFIG_FILES([autoconf/Make.common \
1349Makefile \ 1493Makefile \
1350doc/Makefile \ 1494doc/Makefile \
1351src/Makefile \ 1495src/Makefile \
1352src/test/Makefile \
1353src/rxvtlib.h \ 1496src/rxvtlib.h \
1354W11/Makefile \
1355]) 1497])
1356AC_OUTPUT 1498AC_OUTPUT
1357 1499
1358echo "Configuration: 1500echo "Configuration:
1359 1501
1390 utmp file: $rxvt_cv_path_utmp 1532 utmp file: $rxvt_cv_path_utmp
1391 utmpx file: $rxvt_cv_path_utmpx 1533 utmpx file: $rxvt_cv_path_utmpx
1392 wtmp file: $rxvt_cv_path_wtmp 1534 wtmp file: $rxvt_cv_path_wtmp
1393 wtmpx file: $rxvt_cv_path_wtmpx 1535 wtmpx file: $rxvt_cv_path_wtmpx
1394 lastlog file: $rxvt_cv_path_lastlog 1536 lastlog file: $rxvt_cv_path_lastlog
1395 ttys/ttytab file: $rxvt_cv_path_ttytab" 1537 ttys/ttytab file: $rxvt_cv_path_ttytab
1538 embedded perl: $support_perl"
1396 echo 1539 echo
1397fi 1540fi
1398if test x$term != x; then 1541if test x$term != x; then
1399 echo " set TERM to: $term" 1542 echo " set TERM to: $term"
1400fi 1543fi
1429 echo ". functions could not be found. ." 1572 echo ". functions could not be found. ."
1430 echo ". XIM is now being DISABLED! ." 1573 echo ". XIM is now being DISABLED! ."
1431 echo ".----------------------------------------------------------------." 1574 echo ".----------------------------------------------------------------."
1432fi 1575fi
1433 1576
1434echo " *** Please check src/feature.h for further options ***" 1577echo " *** Optionally check src/feature.h for further options ***"
1435echo 1578echo
1436 1579
1437echo ".----------------------------------------------------------------." 1580echo ".----------------------------------------------------------------."
1438echo ". NOTE: most features are disabled by default, try ." 1581echo ". NOTE: some features are disabled by default, try ."
1439echo ". configure --help to get an idea of the optional features ." 1582echo ". configure --help to get an idea of the optional features, ."
1583echo ". or read ./README.configure ."
1584echo ". ."
1585echo ". The script ./reconf gives a reasonable baseline, try it if ."
1586echo ". you do not want to read documentation and still want some ."
1587echo ". useful features. ."
1440echo ".----------------------------------------------------------------." 1588echo ".----------------------------------------------------------------."
1441echo 1589echo
1442 1590

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines