aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorcy <cy@FreeBSD.org>2011-09-01 13:08:54 +0800
committercy <cy@FreeBSD.org>2011-09-01 13:08:54 +0800
commit4afede8d76d1e238ec2638e1d5feb294c61904e3 (patch)
treee1b8a69e87dbd88ae26487694d1115bc871ec1fd
parentbbd79d77a1d2a18296ac56b6d06122c4f86e1134 (diff)
downloadfreebsd-ports-gnome-4afede8d76d1e238ec2638e1d5feb294c61904e3.tar.gz
freebsd-ports-gnome-4afede8d76d1e238ec2638e1d5feb294c61904e3.tar.zst
freebsd-ports-gnome-4afede8d76d1e238ec2638e1d5feb294c61904e3.zip
Fix build under 9.0-CURRENT.
-rw-r--r--security/krb5-appl/Makefile6
-rw-r--r--security/krb5-appl/files/patch-ba59
-rw-r--r--security/krb5-appl/files/patch-bsd-krlogind.c26
-rw-r--r--security/krb5-appl/files/patch-libpty-logwtmp.c16
-rw-r--r--security/krb5-appl/files/patch-libpty-update_wtmp.c65
5 files changed, 159 insertions, 13 deletions
diff --git a/security/krb5-appl/Makefile b/security/krb5-appl/Makefile
index 91bfed0a6bf3..025f1b97ddab 100644
--- a/security/krb5-appl/Makefile
+++ b/security/krb5-appl/Makefile
@@ -7,7 +7,7 @@
PORTNAME= krb5-appl
PORTVERSION= 1.0.1
-PORTREVISION= 3
+PORTREVISION= 4
CATEGORIES= security
MASTER_SITES= http://web.mit.edu/kerberos/dist/${PORTNAME}/${PORTVERSION:C/^[0-9]*\.[0-9]*/&X/:C/X\.[0-9]*$//:C/X//}/
PATCH_SITES= http://web.mit.edu/kerberos/advisories/
@@ -46,10 +46,6 @@ OPTIONS= KRB5_RENAME_FTP "Rename ftp to kftp" off \
.include <bsd.port.pre.mk>
-.if ${OSVERSION} > 900007
-BROKEN= fails to build with new utmpx
-.endif
-
.if defined(WITH_KRB5_DOC)
BUILD_DEPENDS+= texi2dvi:${PORTSDIR}/print/texinfo \
dvips:${PORTSDIR}/print/dvipsk-tetex
diff --git a/security/krb5-appl/files/patch-ba b/security/krb5-appl/files/patch-ba
index e8e44ac0cd9b..15a341cdaf59 100644
--- a/security/krb5-appl/files/patch-ba
+++ b/security/krb5-appl/files/patch-ba
@@ -1,6 +1,33 @@
---- bsd/login.c.orig Tue May 27 21:06:25 2003
-+++ bsd/login.c Tue Jul 29 20:52:25 2003
-@@ -1342,19 +1342,6 @@
+--- bsd/login.c.orig 2009-11-21 12:29:19.000000000 -0800
++++ bsd/login.c 2011-08-31 21:56:02.581035877 -0700
+@@ -86,7 +86,12 @@
+ #include <netdb.h>
+
+ #include <time.h>
++#ifdef HAVE_UTMP_H
+ #include <utmp.h>
++#endif
++#ifdef HAVE_UTMPX_H
++#include <utmpx.h>
++#endif
+ #include <signal.h>
+
+ #include <assert.h>
+@@ -225,8 +230,13 @@
+ #endif
+ #ifndef UT_NAMESIZE
+ /* linux defines it directly in <utmp.h> */
++#ifdef HAVE_UTMP_H
+ #define UT_NAMESIZE sizeof(((struct utmp *)0)->ut_name)
+ #endif
++#ifdef HAVE_UTMPX_H
++#define UT_NAMESIZE sizeof(((struct utmpx *)0)->ut_user)
++#endif
++#endif
+
+ #ifndef HAVE_SETPRIORITY
+ /* if we don't have it, punt it cleanly */
+@@ -964,19 +974,6 @@
setpriority(PRIO_PROCESS, 0, 0 + PRIO_OFFSET);
}
@@ -20,9 +47,9 @@
if (got_v5_tickets) {
retval = krb5_verify_init_creds(kcontext, &my_creds, NULL,
NULL, &xtra_creds,
-@@ -1378,6 +1365,9 @@
+@@ -993,6 +990,9 @@
+ }
}
- #endif /* KRB4_GET_TICKETS */
+ if (lpass_ok)
+ break;
@@ -30,7 +57,7 @@
bad_login:
setpriority(PRIO_PROCESS, 0, 0 + PRIO_OFFSET);
-@@ -1667,21 +1657,23 @@
+@@ -1250,21 +1250,23 @@
/* set up credential cache -- obeying KRB5_ENV_CCNAME
set earlier */
/* (KRB5_ENV_CCNAME == "KRB5CCNAME" via osconf.h) */
@@ -67,11 +94,27 @@
} else if (forwarded_v5_tickets && rewrite_ccache) {
if ((retval = krb5_cc_initialize (kcontext, ccache, me))) {
syslog(LOG_ERR,
-@@ -1762,6 +1754,7 @@
+@@ -1322,6 +1324,7 @@
if (ccname)
setenv("KRB5CCNAME", ccname, 1);
+ krb5_cc_set_default_name(kcontext, ccname);
setenv("HOME", pwd->pw_dir, 1);
- setenv("PATH", LPATH, 1);
+ setenv("PATH", LPATH, 0);
+@@ -1652,6 +1655,7 @@
+ int quiet;
+ char *tty;
+ {
++#if !(defined(__FreeBSD_version)) || (defined(__FreeBSD_version) && (__FreeBSD_version <= 900007))
+ #if defined(HAVE_LASTLOG_H) || (defined(BSD) && (BSD >= 199103))
+ struct lastlog ll;
+ time_t lltime;
+@@ -1692,6 +1696,7 @@
+ (void)close(fd);
+ }
+ #endif
++#endif
+ }
+
+ #undef UNKNOWN
diff --git a/security/krb5-appl/files/patch-bsd-krlogind.c b/security/krb5-appl/files/patch-bsd-krlogind.c
new file mode 100644
index 000000000000..a7afaf09e7c3
--- /dev/null
+++ b/security/krb5-appl/files/patch-bsd-krlogind.c
@@ -0,0 +1,26 @@
+--- bsd/krlogind.c.orig 2009-11-21 12:29:19.000000000 -0800
++++ bsd/krlogind.c 2011-08-31 21:05:10.318698837 -0700
+@@ -236,6 +236,9 @@
+ #ifdef HAVE_UTMP_H
+ #include <utmp.h>
+ #endif
++#ifdef HAVE_UTMPX_H
++#include <utmpx.h>
++#endif
+
+ int non_privileged = 0; /* set when connection is seen to be from */
+ /* a non-privileged port */
+@@ -275,8 +278,13 @@
+ #define MAX_PROG_NAME 16
+
+ #ifndef UT_NAMESIZE /* linux defines it directly in <utmp.h> */
++#ifdef HAVE_UTMP_H
+ #define UT_NAMESIZE sizeof(((struct utmp *)0)->ut_name)
+ #endif
++#ifdef HAVE_UTMPX_H
++#define UT_NAMESIZE sizeof(((struct utmpx *)0)->ut_user)
++#endif
++#endif
+
+ #if HAVE_ARPA_NAMESER_H
+ #include <arpa/nameser.h>
diff --git a/security/krb5-appl/files/patch-libpty-logwtmp.c b/security/krb5-appl/files/patch-libpty-logwtmp.c
new file mode 100644
index 000000000000..b6af12eb74c6
--- /dev/null
+++ b/security/krb5-appl/files/patch-libpty-logwtmp.c
@@ -0,0 +1,16 @@
+--- libpty/logwtmp.c.orig 2009-11-05 12:15:06.000000000 -0800
++++ libpty/logwtmp.c 2011-08-31 20:37:06.438225202 -0700
+@@ -104,8 +104,13 @@
+ ut.ut_host[sizeof(ut.ut_host) - 1] = '\0';
+ #endif
+ strncpy(ut.ut_line, tty, sizeof(ut.ut_line));
++#ifdef HAVE_UTMPX_H
++ strncpy(ut.ut_user, user, sizeof(ut.ut_user));
++ return ptyint_update_wtmpx(&utx);
++#else
+ strncpy(ut.ut_name, user, sizeof(ut.ut_name));
+ return ptyint_update_wtmp(&ut);
++#endif
+
+ #endif /* !HAVE_LOGWTMP */
+ }
diff --git a/security/krb5-appl/files/patch-libpty-update_wtmp.c b/security/krb5-appl/files/patch-libpty-update_wtmp.c
new file mode 100644
index 000000000000..8aa80234fc9e
--- /dev/null
+++ b/security/krb5-appl/files/patch-libpty-update_wtmp.c
@@ -0,0 +1,65 @@
+--- libpty/update_wtmp.c.orig 2009-11-05 12:15:06.000000000 -0800
++++ libpty/update_wtmp.c 2011-08-31 20:51:26.695908790 -0700
+@@ -50,8 +50,13 @@
+ ptyint_update_wtmpx(struct utmpx *ent)
+ {
+ #if !(defined(HAVE_UPDWTMPX) && defined(WTMPX_FILE))
++#ifdef HAVE_UTMPX_H
++ struct utmpx ut;
++#endif
++#ifdef HAVE_UTMP_H
+ struct utmp ut;
+ #endif
++#endif
+
+ #if defined(HAVE_UPDWTMPX) && defined(WTMPX_FILE)
+ updwtmpx(WTMPX_FILE, ent);
+@@ -62,9 +67,17 @@
+ getutmp(ent, &ut);
+ #else /* Emulate getutmp(). Yuck. */
+ memset(&ut, 0, sizeof(ut));
++#ifdef HAVE_UTMPX_H
++ strncpy(ut.ut_user, ent->ut_user, sizeof(ut.ut_user));
++#else
+ strncpy(ut.ut_name, ent->ut_user, sizeof(ut.ut_name));
++#endif
+ strncpy(ut.ut_line, ent->ut_line, sizeof(ut.ut_line));
++#ifdef HAVE_UTMPX_H
++ ut.ut_tv.tv_sec = ent->ut_tv.tv_sec;
++#else
+ ut.ut_time = ent->ut_tv.tv_sec;
++#endif
+ #ifdef HAVE_STRUCT_UTMP_UT_HOST
+ strncpy(ut.ut_host, ent->ut_host, sizeof(ut.ut_host));
+ ut.ut_host[sizeof(ut.ut_host) - 1] = '\0';
+@@ -88,7 +101,11 @@
+ #endif
+ #endif /* !HAVE_GETUTMP */
+
++#ifdef HAVE_UTMP_H
+ return ptyint_update_wtmp(&ut);
++#else
++ return 0;
++#endif
+ #endif /* !(defined(WTMPX_FILE) && defined(HAVE_UPDWTMPX)) */
+ }
+
+@@ -97,8 +114,13 @@
+ #if !(defined(WTMPX_FILE) && defined(HAVE_UPDWTMPX)) \
+ || !defined(HAVE_SETUTXENT)
+
++#ifdef HAVE_UTMP_H
+ long
+ ptyint_update_wtmp(struct utmp *ent)
++#ifdef HAVE_SETUTXENT
++long ptyint_update_wtmpx(struct utmpx *utx);
++#endif
++
+ {
+ #ifndef HAVE_UPDWTMP
+ int fd;
+@@ -123,3 +145,4 @@
+ }
+
+ #endif
++#endif