Thomas Dickey's color xterm - porting notes.
Andrew Sumner
asumner@hare.net.au
Sun May 3 18:31:00 GMT 1998
Hi all,
Porting of the color xterm to B19.1 requires:-
* ncurses - download latest version from Thomas Dickey's site,
* the xterm source itself (same location - i ported patchlevel 74)
* the X11R6.3 distribution, binaries available from Sergey
Okhapkin's site.
I ported using the coolview dll to NT 4.0.
The procedure is somewhat involved - given time it could be made easier.
1. Build and install ncurses - it compiles smoothly. Install the
X11R6.3 distribution.
2. Unpack the xterm source, and apply the patch at the end of this
message.
3. Use the ncurses 'tic' command to install the terminfo file that
comes
with the xterm distribution into the terminfo database.
4. Edit /etc/termcap, and append the termcap file from the xterm
distribution.
5. Back in the xterm directory, run configure.
6. Build the libXext2.a library. This is an interface to a function in
the libXext.dll that libXmu.a needed to call - for some reason the
function was not present in libXext.a in the X11R6.3 release.
create Xext2.def containing:-
EXPORTS
XShapeCombineMask
To build the library, type the following command:-
dlltool --def Xext2.def --output-exp Xext2.exp --output-lib
libXext2.a --dllname libXext.dll
Add this library to the end of the LIBS variable list, and add -L.
to
the X_LIBS variable. I _know_ this should be done properly in the
Imakefile, but nevertheless...
7. Run make. You may experience a cryptic error compiling button.c - I
found that turning optimisation back from -O2 to -O fixed this. The
xterm _should_ then build and run with no problems. Install
xterm.exe
and resize.exe in place of the existing X11R6.3 executables.
Good Luck - please let me know if any problems.
Btw, I have created a page to which I will be adding ports (binaries &
patches)
Only formative at this stage, it is at
http://www.netmap.com.au/freeStuff/cygwin32
Ciao
Andrew
-----------PATCH BEGINS - CUT HERE------------------
Only in new: confdefs.h
diff -U 3 old/configure new/configure
--- old/configure Mon May 04 10:25:03 1998
+++ new/configure Mon May 04 10:41:30 1998
@@ -1,4 +1,4 @@
-#! /bin/sh
+#! /Cygnus/B19/H-i386-cygwin32/bin/bash
# Guess values for system-dependent variables and create Makefiles.
# Generated automatically using autoconf version 2.12.971230
@@ -3481,6 +3481,45 @@
ac_save_LIBS="$LIBS"
LIBS="-l${cf_x_athena}_s $X_PRE_LIBS $LIBS $X_EXTRA_LIBS $LIBS"
cat > conftest.$ac_ext <<EOF
+#line 3331 "configure"
+#include "confdefs.h"
+/* Override any gcc2 internal prototype to avoid an error. */
+/* We use char because int might match the return type of a gcc2
+ builtin and then its argument prototype would still apply. */
+char XawSimpleMenuAddGlobalActions();
+
+int main() {
+XawSimpleMenuAddGlobalActions()
+; return 0; }
+EOF
+if { (eval echo configure:3342: \"$ac_link\") 1>&5; (eval $ac_link)
2>&5; } && test -s conftest; then
+ rm -rf conftest*
+ eval "ac_cv_lib_$ac_lib_var=yes"
+else
+ echo "configure: failed program was:" >&5
+ cat conftest.$ac_ext >&5
+ rm -rf conftest*
+ eval "ac_cv_lib_$ac_lib_var=no"
+fi
+rm -f conftest*
+LIBS="$ac_save_LIBS"
+
+fi
+if eval "test \"`echo '$ac_cv_lib_'$ac_lib_var`\" = yes"; then
+ echo "$ac_t""yes" 1>&6
+ LIBS="-l$cf_x_athena $LIBS"
+else
+ echo "$ac_t""no" 1>&6
+
+echo $ac_n "checking for XawSimpleMenuAddGlobalActions in
-l${cf_x_athena}3d""... $ac_c" 1>&6
+echo "configure:3323: checking for XawSimpleMenuAddGlobalActions in
-l${cf_x_athena}3d" >&5
+ac_lib_var=`echo ${cf_x_athena}3d'_'XawSimpleMenuAddGlobalActions | sed
'y%./+-%__p_%'`
+if eval "test \"`echo '$''{'ac_cv_lib_$ac_lib_var'+set}'`\" = set";
then
+ echo $ac_n "(cached) $ac_c" 1>&6
+else
+ ac_save_LIBS="$LIBS"
+LIBS="-l${cf_x_athena}3d $X_PRE_LIBS $LIBS $X_EXTRA_LIBS $LIBS"
+cat > conftest.$ac_ext <<EOF
#line 3485 "configure"
#include "confdefs.h"
/* Override any gcc2 internal prototype to avoid an error. */
@@ -3507,10 +3546,11 @@
fi
if eval "test \"`echo '$ac_cv_lib_'$ac_lib_var`\" = yes"; then
echo "$ac_t""yes" 1>&6
- LIBS="-l${cf_x_athena}_s $LIBS"
+ LIBS="-l${cf_x_athena}3d $LIBS"
else
echo "$ac_t""no" 1>&6
{ echo "configure: error: Unable to successfully link Athena library
(-l$cf_x_athena) with test program" 1>&2; exit 1; }
+fi
fi
fi
diff -U 3 old/main.c new/main.c
--- old/main.c Mon May 04 10:25:15 1998
+++ new/main.c Mon May 04 10:35:57 1998
@@ -179,6 +179,14 @@
#define WTMP
#endif
+#ifdef __CYGWIN32__
+#define SYSV
+#define SVR4
+#define LASTLOG
+#define WTMP
+#define ATT
+#endif
+
#ifdef Lynx
#define USE_SYSV_TERMIO
#undef TIOCSLTC
@@ -193,7 +201,17 @@
#define _SVID3
#endif
+#ifdef __CYGWIN32__
+#define SYSV
+#define SVR4
+#define LASTLOG
+#define WTMP
+#define ATT
+#endif
+
+#ifndef __CYGWIN32__
#include <sys/ioctl.h>
+#endif
#include <sys/stat.h>
#ifdef Lynx
@@ -367,7 +385,7 @@
#include <sys/filio.h>
#endif
-#if defined(SVR4) || defined(SCO325)
+#if (defined(SVR4) || defined(SCO325)) && !defined(__CYGWIN32__)
#include <utmpx.h>
#define setutent setutxent
#define getutent getutxent
@@ -1221,7 +1239,9 @@
d_tio.c_cc[VEOF] = CEOF;
d_tio.c_cc[VEOL] = CNUL;
d_tio.c_cc[VEOL2] = CNUL;
+#ifdef VSWTCH
d_tio.c_cc[VSWTCH] = CNUL;
+#endif
#if defined(USE_TERMIOS) || defined(USE_POSIX_TERMIOS) /* { */
d_tio.c_cc[VSUSP] = CSUSP;
@@ -2169,7 +2189,7 @@
#endif /* sun */
struct passwd *pw = NULL;
#ifdef UTMP
-#if defined(SVR4) || defined(SCO325)
+#if (defined(SVR4) || defined(SCO325)) && !defined(__CYGWIN32__)
struct utmpx utmp;
#else
struct utmp utmp;
@@ -3426,7 +3446,7 @@
/* hung sh problem? */
signal (SIGHUP, SIG_DFL);
#else
- signal (SIGHUP,SIG_IGN);
+ signal (SIGHUP, SIG_IGN);
#endif
/*
@@ -4168,6 +4188,16 @@
long arg;
ioctl (fd, FIONREAD, (char *) &arg);
return (int) arg;
+#elif defined(__CYGWIN32__)
+ fd_set set;
+ struct timeval timeout = {0, 0};
+
+ FD_ZERO (&set);
+ FD_SET (fd, &set);
+ if (select (fd+1, &set, NULL, NULL, &timeout) > 0)
+ return 1;+ else
+ return 0;
#else
#ifdef MINIX
/* The answer doesn't have to correct. Calling nbio_isinprogress is
diff -U 3 old/resize.c new/resize.c
--- old/resize.c Mon May 04 10:25:15 1998
+++ new/resize.c Mon May 04 10:50:31 1998
@@ -81,7 +81,7 @@
#define USE_SYSV_UTMP
#endif
-#if defined(SYSV) || defined(Lynx)
+#if defined(SYSV) || defined(Lynx) || defined(__CYGWIN32__)
#define USE_SYSV_TERMIO
#ifndef Lynx
#define USE_SYSV_UTMP
@@ -104,7 +104,9 @@
#define USE_TERMIOS
#endif
+#ifndef __CYGWIN32__
#include <sys/ioctl.h>
+#endif
#ifdef USE_SYSV_TERMIO
# ifndef Lynx
# include <sys/termio.h>
@@ -112,11 +114,14 @@
# include <termio.h>
# endif
#else /* else not USE_SYSV_TERMIO */
+#include <termios.h>
+/*
# ifdef USE_TERMIOS
# include <termios.h>
-# else /* not USE_TERMIOS */
+# else /* not USE_TERMIOS *
# include <sgtty.h>
-# endif /* USE_TERMIOS */
+# endif /* USE_TERMIOS *
+*/
#endif /* USE_SYSV_TERMIO */
#ifdef USE_USG_PTYS
@@ -259,10 +264,10 @@ * Instead, just use terminfo.
*/
#undef USE_TERMCAP
-#include <curses.h>
+#include </usr/local/include/curses.h>
#endif
#else
-#include <curses.h>
+#include </usr/local/include/curses.h>
#endif /* HAVE_TERMCAP_H */
#endif
diff -U 3 old/screen.c new/screen.c
--- old/screen.c Mon May 04 10:25:15 1998
+++ new/screen.c Mon May 04 10:40:27 1998
@@ -44,8 +44,15 @@
#define SYSV
#include <termios.h>
#else
+#ifndef __CYGWIN32__
#include <sys/ioctl.h>
#endif
+#endif
+
+#if defined(__CYGWIN32__) && !defined(TIOCSPGRP)
+#include <termios.h>
+# define TIOCSPGRP (_IOW('t', 118, pid_t))
+#endif
#ifdef __hpux
#include <sys/termio.h>
@@ -94,6 +101,9 @@
static int Reallocate PROTO((ScrnBuf *sbuf, Char **sbufaddr, int nrow,
int ncol, int oldrow, int oldcol));
static void ScrnClearLines PROTO((TScreen *screen, ScrnBuf sb, int
where, int n, int size));
+#ifdef __CYGWIN32__
+extern XtermWidget term;
+#endif
ScrnBuf Allocate (nrow, ncol, addr)
/*
@@ -119,6 +129,7 @@
register int i, j, k;
size_t entries = MAX_PTRS * nrow;
size_t length = BUF_PTRS * nrow * ncol;+ static char
first_time = 1;
if ((base = (ScrnBuf) calloc (entries, sizeof (char *))) == 0)
SysError (ERROR_SCALLOC);
@@ -517,6 +528,9 @@
int scrollamt = screen->scroll_amt;
int max = screen->max_row;
int gc_changes = 0;
+#ifdef __CYGWIN32__
+ static char first_time = 1;
+#endif
TRACE(("ScrnRefresh (%d,%d) - (%d,%d)%s\n",
toprow, leftcol,
@@ -720,6 +734,19 @@
if (gc_changes & BG_COLOR)
SGR_Background(term->cur_background);
})
+
+#if defined(__CYGWIN32__) && defined(TIOCSWINSZ)
+ if (first_time == 1)
+ {
+ struct winsize ws;
+ first_time = 0;
+ ws.ws_row = nrows;
+ ws.ws_col = ncols;
+ ws.ws_xpixel = term->core.width;
+ ws.ws_ypixel = term->core.height;
+ ioctl (screen->respond, TIOCSWINSZ, (char *)&ws);
+ }
+#endif
}
void
----------PATCH ENDS - CUT HERE---------------
--
"char ((*(*())[])()) is a cast to a function returning a pointer
to an array of pointers to functions returning a char."
-
For help on using this list (especially unsubscribing), send a message to
"gnu-win32-request@cygnus.com" with one line of text: "help".
More information about the Cygwin
mailing list