Motif Multi-Document Interface Version 1.0 ------------------------------------------ INTRODUCTION ============ The Motif Multi-Document Interface (MDI) is a collection of C++ classes that emulates the behavior of the Multi-Document Interface in Microsoft Windows. The MDI framework allows a user to view multiple documents (windows) constrained to a single parent window. REQUIREMENTS ============ The following are required to build MDI: C++ compiler X11R5/X11R6 Motif1.2 PLATFORMS ========= The MDI package is known to compile on the following platforms: SGI IRIX 5.2 SunOS 4.1.3 Sun Solaris 5.4 HP-UX 9.05 AIX 4.1 Alpha/OSF1 v3.2 Linux 1.1.90 (gcc version 2.5.8) INSTALLATION ============ MDI is written in C++. It does not use any language extensions like exceptions or templates, so it should compile with most C++ compilers. To build MDI, you need to set the name of your C++ compiler in the file "config/MDI.tmpl". An attempt is made to pick a logical default for your machine, but if it fails, you will need to edit this file. After setting your compiler, just type: xmkmf make Makefiles make If successful, the MDI library (libXsw.a) will be created in the "lib" directory. Additionally, a short test program (MDItest) will be created in the "test" directory. If you are not successful, see the "Possible Problems" section below. I have had no luck with imake as it seems to only work on about 1/2 of the platforms I have tried. If imake does not work, don't despair. The MDI library is really simple to build by hand. Just follow the following steps and it will work just fine. I have given detailed instructions in the "Possible Problems" section below where I had problems using imake. If anyone sees a problem with my Imakefile (I assume there are many), please let me know. In order to build the MDI package by hand, do the following: 1. "cd" into the "lib" directory (cd lib) 2. Compile all of the source code (CC -g -c *.C). Your compiler name may vary. Some common compilers are: CC: SGI, Sun, Solaris, HP-UX xlC: AIX RS/6000 cxx: Alpha/OSF1 g++: Linux gcc: Most other platforms 3. Create the library "libXsw.a" (ar rlv libXsw.a *.o) 4. Run "ranlib" (not necessary on all machines) 5. "cd" into the "test" directory (cd ../test) 6. Compile the source code (see step #2 above) 7. Link the test program (CC *.o -o MDItest ../lib/libXsw.a \ -lXm -lXt -lX11). Again, the compiler/linker name may vary If you still can't get it to work after all of that, email me and I'll give you a hand. POSSIBLE PROBLEMS ================= SunOS 4.1.3 Kept getting this message when trying to make: make: Fatal error: Don't know how to make target `XsComponent.o' I ended up building the library and test case with the following: cd lib CC -g -c *.C ar rlv libXsw.a *.o ranlib libXsw.a cd ../test CC -g -c *.C -I../lib CC -g *.o -o MDItest ../lib/libXsw.a -L/usr/lib -lXm -lXt -lX11 Solaris 5.4 The generated Makefile had some unsupported options being passed to the linker. I don't know what they were for, so I just removed them. All worked fine after that. HP-UX 9.05 I did not have "xmkmf" on this platform. To build the library and test case, I did the following (paths may vary): cd lib CC -g -c *.C -I/usr/include/Motif1.2 -I/usr/include/X11R5 ar rlv libXsw.a *.o cd ../test CC -g -c *.C -I../lib -I/usr/include/Motif1.2 -I/usr/include/X11R5 CC -g *.o -o MDItest ../lib/libXsw.a -L/usr/lib/Motif1.2 \ -L/usr/lib/X11R5 -lXm -lXt -lX11 AIX 4.1 Running xmkmf on the top Makefile did not work. Got the following: "./Imakefile", line 8.1: 1506-215 (E) Too many arguments specified for macro NamedTargetSubdirs. In order to build the library, I cd'd into both the "lib" and "test" directory and did the following there: xmkmf make Alpha/OSF1 v3.2 Kept getting this message when trying to make: Make: Don't know how to make XsComponent.o. Stop. I ended up building the library and test case with the following: cd lib cxx -g -c *.C ar rlv libXsw.a *.o cd ../test cxx -g -c *.C -I../lib cxx -g *.o -o MDItest ../lib/libXsw.a -lXm -lXt -lX11 Linux "make Makefiles" did not work correctly. Just cd'd into both the "lib" and "test" directories and type: xmkmf make Also, if you don't have the C++ library (libC.a), you will get some undefined symbols like when linking: ../lib/libXsw.a(XsComponent.o): Undefined symbol _cout referenced from text segment ../lib/libXsw.a(XsComponent.o): Undefined symbol ostream::operator<<(char const *) referenced from text segment To get rid of these errors, you will need to recompile the library (specifically XsComponent.C) with -DNDEBUG. This will remove the calls to the <iostream> library and will eliminate the need to link with the C++ library DOCUMENTATION ============= All documentation is written in HTML and can be found in the "doc" directory. The top-most documentation file is "mdi.html" AVAILABILITY =============== The latest version of MDI is available at: ftp://ftp.x.org/contrib/widgets/motif/MDI-<version>.tar.gz COPYRIGHT ========= Copyright (c) 1996, 1998 Scott W. Sadler All rights reserved. See license conditions in the COPYRIGHT file of the MDI distribution BUG REPORTS =========== Please report any bugs, suggestions or criticisms directly to me at the address below. I want to make this as quality a software package as possible: stable, efficient and portable. It is the feedback from the X community that makes writing the software worthwhile. Scott W. Sadler ssadler@cisco.com HISTORY ======= 03-Mar-96 Version 1.0 Released 29-Jun-98 Version 1.0.1 No code changes; New email address