summaryrefslogtreecommitdiffstats
path: root/experimental/tqtinterface/qt4/mkspecs/solaris-cc
diff options
context:
space:
mode:
Diffstat (limited to 'experimental/tqtinterface/qt4/mkspecs/solaris-cc')
-rw-r--r--experimental/tqtinterface/qt4/mkspecs/solaris-cc/qmake.conf85
-rw-r--r--experimental/tqtinterface/qt4/mkspecs/solaris-cc/qplatformdefs.h114
2 files changed, 199 insertions, 0 deletions
diff --git a/experimental/tqtinterface/qt4/mkspecs/solaris-cc/qmake.conf b/experimental/tqtinterface/qt4/mkspecs/solaris-cc/qmake.conf
new file mode 100644
index 000000000..e4842075b
--- /dev/null
+++ b/experimental/tqtinterface/qt4/mkspecs/solaris-cc/qmake.conf
@@ -0,0 +1,85 @@
+#
+#
+# qmake configuration for solaris-cc
+#
+# Written for Sun WorkShop 5.0, Forte Developer 6, and Sun ONE Studio 7.
+#
+
+MAKEFILE_GENERATOR = UNIX
+TEMPLATE = app
+CONFIG += qt warn_on release link_prl
+
+TQMAKE_CC = cc
+TQMAKE_LEX = flex
+TQMAKE_LEXFLAGS =
+TQMAKE_YACC = yacc
+TQMAKE_YACCFLAGS = -d
+TQMAKE_CFLAGS =
+TQMAKE_CFLAGS_DEPS = -xM
+TQMAKE_CFLAGS_WARN_ON =
+TQMAKE_CFLAGS_WARN_OFF = -w
+TQMAKE_CFLAGS_RELEASE = -O
+TQMAKE_CFLAGS_DEBUG = -g
+TQMAKE_CFLAGS_SHLIB = -KPIC
+TQMAKE_CFLAGS_YACC =
+TQMAKE_CFLAGS_THREAD = -mt
+
+TQMAKE_CXX = CC
+TQMAKE_CXXFLAGS = $$TQMAKE_CFLAGS
+TQMAKE_CXXFLAGS_DEPS = $$TQMAKE_CFLAGS_DEPS
+TQMAKE_CXXFLAGS_WARN_ON = $$TQMAKE_CFLAGS_WARN_ON
+TQMAKE_CXXFLAGS_WARN_OFF = $$TQMAKE_CFLAGS_WARN_OFF
+TQMAKE_CXXFLAGS_RELEASE = -O2
+TQMAKE_CXXFLAGS_DEBUG = $$TQMAKE_CFLAGS_DEBUG
+TQMAKE_CXXFLAGS_SHLIB = $$TQMAKE_CFLAGS_SHLIB
+TQMAKE_CXXFLAGS_YACC = $$TQMAKE_CFLAGS_YACC
+TQMAKE_CXXFLAGS_THREAD = $$TQMAKE_CFLAGS_THREAD
+
+TQMAKE_INCDIR =
+TQMAKE_LIBDIR =
+TQMAKE_INCDIR_X11 = /usr/openwin/include
+TQMAKE_LIBDIR_X11 = /usr/openwin/lib
+TQMAKE_INCDIR_QT = $(TQTDIR)/include
+TQMAKE_LIBDIR_QT = $(TQTDIR)/lib
+TQMAKE_INCDIR_OPENGL = /usr/openwin/include
+TQMAKE_LIBDIR_OPENGL = /usr/openwin/lib
+
+TQMAKE_LINK = CC
+TQMAKE_LINK_SHLIB = CC
+TQMAKE_LFLAGS = -R/usr/lib -R$(TQTDIR)/lib
+TQMAKE_LFLAGS_RELEASE =
+TQMAKE_LFLAGS_DEBUG =
+TQMAKE_LFLAGS_SHLIB = -G
+TQMAKE_LFLAGS_PLUGIN = $$TQMAKE_LFLAGS_SHLIB
+TQMAKE_LFLAGS_SONAME = -h$$LITERAL_WHITESPACE
+TQMAKE_LFLAGS_THREAD = -mt
+TQMAKE_RPATH = -R
+
+TQMAKE_LIBS =
+TQMAKE_LIBS_DYNLOAD = -ldl
+TQMAKE_LIBS_X11 = -lXext -lX11 -lresolv -lsocket -lnsl
+TQMAKE_LIBS_X11SM = -lSM -lICE
+TQMAKE_LIBS_NIS =
+TQMAKE_LIBS_QT = -lqt
+TQMAKE_LIBS_TQT_THREAD = -lqt-mt
+TQMAKE_LIBS_OPENGL = -lGLU -lGL -lXmu
+TQMAKE_LIBS_OPENGL_QT = -lGL -lXmu
+TQMAKE_LIBS_THREAD = -lpthread -lrt
+
+TQMAKE_TQMOC = $(TQTDIR)/bin/tqmoc
+TQMAKE_UIC = $(TQTDIR)/bin/uic
+
+TQMAKE_AR = CC -xar -o
+TQMAKE_RANLIB =
+
+TQMAKE_CLEAN = -r $(OBJECTS_DIR)Templates.DB $(OBJECTS_DIR)SunWS_cache
+
+TQMAKE_TAR = tar -cf
+TQMAKE_GZIP = gzip -9f
+
+TQMAKE_COPY = cp -f
+TQMAKE_MOVE = mv -f
+TQMAKE_DEL_FILE = rm -f
+TQMAKE_DEL_DIR = rmdir
+TQMAKE_CHK_DIR_EXISTS = test -d
+TQMAKE_MKDIR = mkdir -p
diff --git a/experimental/tqtinterface/qt4/mkspecs/solaris-cc/qplatformdefs.h b/experimental/tqtinterface/qt4/mkspecs/solaris-cc/qplatformdefs.h
new file mode 100644
index 000000000..80662b9d6
--- /dev/null
+++ b/experimental/tqtinterface/qt4/mkspecs/solaris-cc/qplatformdefs.h
@@ -0,0 +1,114 @@
+#ifndef TQPLATFORMDEFS_H
+#define TQPLATFORMDEFS_H
+
+// Get TQt defines/settings
+
+#include "tqglobal.h"
+
+// Set any POSIX/XOPEN defines at the top of this file to turn on specific APIs
+#define _POSIX_PTHREAD_SEMANTICS
+
+#include <unistd.h>
+
+
+// We are hot - unistd.h should have turned on the specific APIs we requested
+
+
+#ifdef TQT_THREAD_SUPPORT
+#include <pthread.h>
+#endif
+
+#include <dirent.h>
+#include <fcntl.h>
+#include <grp.h>
+#include <pwd.h>
+#include <signal.h>
+#include <dlfcn.h>
+
+#include <sys/types.h>
+#include <sys/ioctl.h>
+#include <sys/filio.h>
+#include <sys/ipc.h>
+#include <sys/time.h>
+#include <sys/shm.h>
+#include <sys/socket.h>
+#include <sys/stat.h>
+#include <sys/wait.h>
+
+// DNS header files are not fully covered by X/Open specifications.
+// In particular nothing is said about res_* :/
+// On Solaris header files <netinet/in.h> and <arpa/nameser.h> are not
+// included by <resolv.h>. Note that <arpa/nameser.h> must be included
+// before <resolv.h>.
+#include <netinet/in.h>
+#include <arpa/nameser.h>
+#include <resolv.h>
+
+
+#if !defined(TQT_NO_COMPAT)
+#define TQT_STATBUF struct stat
+#define TQT_STATBUF4TSTAT struct stat
+#define TQT_STAT ::stat
+#define TQT_FSTAT ::fstat
+#define TQT_STAT_REG S_IFREG
+#define TQT_STAT_DIR S_IFDIR
+#define TQT_STAT_MASK S_IFMT
+#define TQT_STAT_LNK S_IFLNK
+#define TQT_FILENO fileno
+#define TQT_OPEN ::open
+#define TQT_CLOSE ::close
+#define TQT_LSEEK ::lseek
+#define TQT_READ ::read
+#define TQT_WRITE ::write
+#define TQT_ACCESS ::access
+#define TQT_GETCWD ::getcwd
+#define TQT_CHDIR ::chdir
+#define TQT_MKDIR ::mkdir
+#define TQT_RMDIR ::rmdir
+#define TQT_OPEN_RDONLY O_RDONLY
+#define TQT_OPEN_WRONLY O_WRONLY
+#define TQT_OPEN_RDWR O_RDWR
+#define TQT_OPEN_CREAT O_CREAT
+#define TQT_OPEN_TRUNC O_TRUNC
+#define TQT_OPEN_APPEND O_APPEND
+#endif
+
+#define TQT_SIGNAL_RETTYPE void
+#define TQT_SIGNAL_ARGS int
+#define TQT_SIGNAL_IGNORE SIG_IGN
+
+#if !defined(_XOPEN_UNIX)
+// Function usleep() is defined in C library but not declared in header files
+// on Solaris 2.5.1. Not really a surprise, usleep() is specified by XPG4v2
+// and XPG4v2 is only supported by Solaris 2.6 and better.
+// Function gethostname() is defined in C library but not declared in <unistd.h>
+// on Solaris 2.5.1.
+// So we are trying to detect Solaris 2.5.1 using macro _XOPEN_UNIX which is
+// not defined by <unistd.h> when XPG4v2 is not supported.
+typedef unsigned int useconds_t;
+extern "C" int usleep(useconds_t);
+extern "C" int gethostname(char *, int);
+#endif
+
+#if defined(_XOPEN_SOURCE) && (_XOPEN_SOURCE-0 >= 500) && (_XOPEN_VERSION-0 >= 500)
+// on Solaris 7 and better with specific feature test macros
+#define TQT_SOCKLEN_T socklen_t
+#elif defined(_XOPEN_SOURCE_EXTENDED) && (_XOPEN_VERSION-0 >= 4)
+// on Solaris 2.6 and better with specific feature test macros
+#define TQT_SOCKLEN_T size_t
+#else
+// always this case in practice
+#define TQT_SOCKLEN_T int
+#endif
+
+#if defined(_XOPEN_UNIX)
+// Supported by Solaris 2.6 and better. XPG4v2 and XPG4v2 is also supported
+// by Solaris 2.6 and better. So we are trying to detect Solaris 2.6 using
+// macro _XOPEN_UNIX which is not defined by <unistd.h> when XPG4v2 is not
+// supported.
+#define TQT_SNPRINTF ::snprintf
+#define TQT_VSNPRINTF ::vsnprintf
+#endif
+
+
+#endif // TQPLATFORMDEFS_H