aboutsummaryrefslogtreecommitdiffstats
path: root/ports-mgmt
diff options
context:
space:
mode:
authormnag <mnag@FreeBSD.org>2005-11-26 04:14:23 +0800
committermnag <mnag@FreeBSD.org>2005-11-26 04:14:23 +0800
commitb9e3accf082aef19d672e864df2341a6524906ad (patch)
tree6e62990b35fe2299317ef25cbd2ca2084ceac9f6 /ports-mgmt
parent9b885d3314516b74e54d12a10d1b034d743ed568 (diff)
downloadfreebsd-ports-graphics-b9e3accf082aef19d672e864df2341a6524906ad.tar.gz
freebsd-ports-graphics-b9e3accf082aef19d672e864df2341a6524906ad.tar.zst
freebsd-ports-graphics-b9e3accf082aef19d672e864df2341a6524906ad.zip
Update to 0.3.9_1
- Using ruby script provided by Jan Grant <Jan.Grant@bristol.ac.uk> if portupgrade is installed portmanager also uses settings from pkgtools.conf in addition to those from its own conf file. - Wild cards "*" may now be used in pm-020.conf, see man portmanager for details - Automatic timeouts are re-enabled, stdin problem is solved. - Fix build on 4.x (0.3.9) PR: 89533 Submitted by: Michael C. Shultz <ringworm01@gmail.com> (maintainer)
Diffstat (limited to 'ports-mgmt')
-rw-r--r--ports-mgmt/portmanager/Makefile6
-rw-r--r--ports-mgmt/portmanager/distinfo6
-rw-r--r--ports-mgmt/portmanager/files/patch-0.3.8_1428
-rw-r--r--ports-mgmt/portmanager/files/patch-0.3.8_297
-rw-r--r--ports-mgmt/portmanager/files/patch-0.3.9_1222
-rw-r--r--ports-mgmt/portmanager/pkg-plist3
6 files changed, 231 insertions, 531 deletions
diff --git a/ports-mgmt/portmanager/Makefile b/ports-mgmt/portmanager/Makefile
index 91df00db6ac..f97e4b06b3f 100644
--- a/ports-mgmt/portmanager/Makefile
+++ b/ports-mgmt/portmanager/Makefile
@@ -6,8 +6,8 @@
#
PORTNAME= portmanager
-PORTVERSION= 0.3.8
-PORTREVISION= 2
+PORTVERSION= 0.3.9
+PORTREVISION= 1
CATEGORIES= sysutils
MASTER_SITES= http://portmanager.sunsite.dk/distfiles/ \
${MASTER_SITE_SOURCEFORGE}
@@ -34,7 +34,7 @@ INSTALL_TARGET= install info
# time.
#
CONFIGURE_ARGS= --with-prefix=${PREFIX} --with-bindir=/bin \
- --with-etcdir=/etc/portmanager --with-pkgdbdir=/var/db/pkg \
+ --with-etcdir=/etc --with-pkgdbdir=/var/db/pkg \
--with-portsdir=${PORTSDIR} --with-sharedir=/share/portmanager \
--with-tempdir=/tmp
diff --git a/ports-mgmt/portmanager/distinfo b/ports-mgmt/portmanager/distinfo
index 69e2524633e..c8b52274cb4 100644
--- a/ports-mgmt/portmanager/distinfo
+++ b/ports-mgmt/portmanager/distinfo
@@ -1,3 +1,3 @@
-MD5 (portmanager-0.3.8.tar.gz) = bb129c42b45dab64da6d35cd7aff94f0
-SHA256 (portmanager-0.3.8.tar.gz) = 78e1b871394c0337dcde5b2a467dc3644b381010870f7f34e6cb120e5ef93203
-SIZE (portmanager-0.3.8.tar.gz) = 487559
+MD5 (portmanager-0.3.9.tar.gz) = ced2fed7ba75a664f030f8d4bd72b976
+SHA256 (portmanager-0.3.9.tar.gz) = 34063846fbf86d16cf42a8f3aa4a37c522e6e234b314721f22dab391ca8aca69
+SIZE (portmanager-0.3.9.tar.gz) = 490606
diff --git a/ports-mgmt/portmanager/files/patch-0.3.8_1 b/ports-mgmt/portmanager/files/patch-0.3.8_1
deleted file mode 100644
index f2677191cd2..00000000000
--- a/ports-mgmt/portmanager/files/patch-0.3.8_1
+++ /dev/null
@@ -1,428 +0,0 @@
-diff -ruN ../0.3.8/libMGPM/src/MGPMlogCreate.c ./libMGPM/src/MGPMlogCreate.c
---- ../0.3.8/libMGPM/src/MGPMlogCreate.c Fri Nov 18 07:49:06 2005
-+++ ./libMGPM/src/MGPMlogCreate.c Sun Nov 20 12:50:55 2005
-@@ -106,7 +106,7 @@
- fprintf( logFileStream, "%-25s %d %-25s %d\n", "backUp", property->backUp, "buildDependsAreLeaves", property->buildDependsAreLeaves );
- fprintf( logFileStream, "%-25s %d %-25s %d\n", "forced", property->forced, "interactive", property->interactive );
- fprintf( logFileStream, "%-25s %d %-25s %d\n", "log", property->log, "pmMode", property->pmMode );
-- fprintf( logFileStream, "%-25s %d %-25s %d\n", "resume", property->resume, " ", 0 );
-+ fprintf( logFileStream, "%-25s %d %-25s %d\n", "pristine", property->pristine, "resume", property->resume );
- fprintf( logFileStream, "%s\n", SINGLE_LINES );
-
- fclose( logFileStream );
-diff -ruN ../0.3.8/libMGPM/src/MGPMrCommandLine.c ./libMGPM/src/MGPMrCommandLine.c
---- ../0.3.8/libMGPM/src/MGPMrCommandLine.c Sat Nov 19 17:18:08 2005
-+++ ./libMGPM/src/MGPMrCommandLine.c Sun Nov 20 17:08:58 2005
-@@ -50,6 +50,7 @@
-
- void MGPMrTimer( int signalId )
- {
-+ int idx = 0;
- /*
- * re-set the signal handler again to MGPMrCatchSignal, for next time
- */
-@@ -59,7 +60,14 @@
- */
- while( fflush( stdout ) );
-
-+ while( close( 0 ) && idx < 100 )
-+ {
-+ printf( "close(0) retry %d of 100\n", idx );
-+ idx++;
-+ }
-+/*
- fclose( stdin );
-+*/
- globalProperty->timeOut = 1;
- }
-
-@@ -88,14 +96,15 @@
- property.autoConflicts = 0; /* 1 = yes to all */
- property.autoMoved = 0; /* if 1 then remove moved ports is Y */
- property.backUp = 0; /* 0 = no packages 1 = build backup packages */
-+ property.bsdPortMkPatched = 0; /* 1 = bsd.port.mk is in patched state */
-+ property.bsdPortMkPatchedBlock = 0; /* 1 = bsd.port.mk can't be patch so quit trying */
- property.forced = 0; /* set by -f on command line */
- property.interactive = 0; /* set by -ui on command line */
- property.log = 0; /* set by -l --LOG on command line */
- property.optionsChanged = 0; /* set by MGPMrUpdate for example to indicate a ports's options just changed */
- property.pmMode = 0; /* 0 = multiple port updates/1 = single */
-+ property.pristine = 0; /* 1 = run in pristine mode */
- property.resume = 0; /* 1 = portmanager updated itself, don't rebuild databases in -u -f mode */
-- property.bsdPortMkPatched = 0; /* 1 = bsd.port.mk is in patched state */
-- property.bsdPortMkPatchedBlock = 0; /* 1 = bsd.port.mk can't be patch so quit trying */
-
- /*
- * set by Makefile options in ports
-diff -ruN ../0.3.8/libMGPM/src/MGPMrController.c ./libMGPM/src/MGPMrController.c
---- ../0.3.8/libMGPM/src/MGPMrController.c Sat Nov 19 11:25:43 2005
-+++ ./libMGPM/src/MGPMrController.c Sun Nov 20 12:33:50 2005
-@@ -47,8 +47,10 @@
- char fix[] = "--fix";
- char id[] = "MGPMrController";
- char ignore[] = "/IGNORE";
-+ char p[] = "-p";
- char package_version[] = PACKAGE_VERSION;
- char portmanager[] = "portmanager";
-+ char pristine[] = "--pristine";
- char resume[] = "--resume";
- char space[] = " ";
- char ui[] = "-ui";
-@@ -131,16 +133,33 @@
- {
- property->resume = 1;
- }
-+
- MGdbGoTop( property->commandLineDb );
- if( MGdbSeek( property->commandLineDb, property->fieldCommandLineDbKey, ui, property->fieldCommandLineDbKey, exact ) )
- {
- property->interactive = 1;
- }
-+
- MGdbGoTop( property->commandLineDb );
- if( MGdbSeek( property->commandLineDb, property->fieldCommandLineDbKey, upgradeInteractive, property->fieldCommandLineDbKey, exact ) )
- {
- property->interactive = 1;
- }
-+
-+ MGdbGoTop( property->commandLineDb );
-+ if( MGdbSeek( property->commandLineDb, property->fieldCommandLineDbKey, p, property->fieldCommandLineDbKey, exact ) )
-+ {
-+ property->pristine = 1;
-+ }
-+
-+ MGdbGoTop( property->commandLineDb );
-+ if( MGdbSeek( property->commandLineDb, property->fieldCommandLineDbKey, pristine, property->fieldCommandLineDbKey, exact ) )
-+ {
-+ property->pristine = 1;
-+ }
-+
-+
-+
- property->logFile = MGPMlogCreate( property );
-
- /*
-diff -ruN ../0.3.8/libMGPM/src/MGPMrCreateInstalledDb.c ./libMGPM/src/MGPMrCreateInstalledDb.c
---- ../0.3.8/libMGPM/src/MGPMrCreateInstalledDb.c Fri Nov 18 07:49:06 2005
-+++ ./libMGPM/src/MGPMrCreateInstalledDb.c Mon Nov 21 10:27:28 2005
-@@ -175,7 +175,12 @@
-
- buffPtr = portDependencyName + stringSize + 1;
-
-- portDependencyDir = strstr( buffPtr, "@comment DEPORIGIN:" );
-+ if( ( portDependencyDir = strstr( buffPtr, "@comment DEPORIGIN:" ) ) == NULL )
-+ {
-+ /* if here +CONTENTS record is screwed up */
-+ break;
-+ }
-+
- portDependencyDir += strlen( "@comment DEPORIGIN:" );
- stringSize = strstr( portDependencyDir, "\n" ) - portDependencyDir;
- portDependencyDir[stringSize] = 0;
-diff -ruN ../0.3.8/libMGPM/src/MGPMrGetPortName.c ./libMGPM/src/MGPMrGetPortName.c
---- ../0.3.8/libMGPM/src/MGPMrGetPortName.c Sat Nov 19 17:45:28 2005
-+++ ./libMGPM/src/MGPMrGetPortName.c Mon Nov 21 11:55:45 2005
-@@ -42,6 +42,7 @@
- int answer = 0;
- int bufferSize = 0xffff;
- int stdinFileDescriptor = 0;
-+ int stdinFileDescriptorIdx = 0;
-
- command = (char*)calloc( bufferSize, 1 );
-
-@@ -156,8 +157,16 @@
- * reset alarm, reopen stdin after timeout
- */
- alarm(0);
-- stdinFileDescriptor = open( "/dev/tty", O_RDWR );
-+/*
-+ stdinFileDescriptorIdx = 0;
-+ while( ( stdinFileDescriptor = open( "/dev/tty", O_RDWR ) ) != -1 && stdinFileDescriptorIdx < 10000 )
-+ {
-+ printf( "open( /dev/tty ) retry %d of 100\n", stdinFileDescriptorIdx );
-+ stdinFileDescriptorIdx++;
-+ }
- stdin = fdopen( stdinFileDescriptor, "r" );
-+*/
-+ stdin = fdopen( 0, "r" );
- property->timeOut = 0;
- MGPMlogAdd( property, "installed ", portName,
- " removed from system after 5 minute timeout: no longer in ports tree: see /usr/ports/MOVED", " ", " " );
-diff -ruN ../0.3.8/libMGPM/src/MGPMrReadConfigure.c ./libMGPM/src/MGPMrReadConfigure.c
---- ../0.3.8/libMGPM/src/MGPMrReadConfigure.c Fri Nov 18 07:49:06 2005
-+++ ./libMGPM/src/MGPMrReadConfigure.c Sun Nov 20 17:21:54 2005
-@@ -54,7 +54,7 @@
- {
- FILE* configDbStream = NULL;
- char* configFileNameOld = NULL;
--/* char id[] = "MGPMrReadConfigure"; */
-+ char id[] = "MGPMrReadConfigure";
- char* buffer = NULL;
- char* command = NULL;
- char* nullBase = NULL;
-@@ -107,7 +107,12 @@
- strcat( command, property->configConfFileName );
- strcat( command, " >> " );
- strcat( command, property->configDbFileName );
-- system( command );
-+ if( system( command ) )
-+ {
-+ fprintf( stdout, "%s %s: error: command %s reurned an error\n", id, PACKAGE_VERSION );
-+ while( fflush( stdout ) );
-+ assert( 0 );
-+ }
- configDbFileSize = MGrFileSize( property->configDbFileName );
- buffer = malloc( configDbFileSize + 1 );
- configDbStream = fopen( property->configDbFileName, "r" );
-diff -ruN ../0.3.8/libMGPM/src/MGPMrSinglePortStatus.c ./libMGPM/src/MGPMrSinglePortStatus.c
---- ../0.3.8/libMGPM/src/MGPMrSinglePortStatus.c Fri Nov 18 14:40:55 2005
-+++ ./libMGPM/src/MGPMrSinglePortStatus.c Sun Nov 20 15:16:01 2005
-@@ -57,6 +57,7 @@
- int counter = 0;
- int installedPortsDbIDX = 0;
- int old = 0;
-+ int returnCode = 0;
- int* counterPtr = NULL;
-
- counterPtr = &counter;
-@@ -147,22 +148,47 @@
- installedPortsDbIDX,
- property->fieldInstalledPortsDbPortDir ) );
-
-- if( rCheckForOldDependencies( property, installedPortsDbPortDir, oldDependencyName, oldDependencyDir, counterPtr ) )
-+ if( ( returnCode = rCheckForOldDependencies( property,
-+ installedPortsDbPortDir,
-+ oldDependencyName,
-+ oldDependencyDir,
-+ counterPtr ) ) )
- {
-- fprintf( stdout, "%05d have:%-35s %-35s built with OLD dependency: %s\n",
-- counter,
-- installedPortsDbPortName,
-- installedPortsDbPortDir,
-- oldDependencyName );
-- while( fflush( stdout ) );
-+ if( returnCode == 2 )
-+ {
-+ fprintf( stdout, "%05d PRISTINE MODE: %-35s %-35s has incorrect %s entry in +CONTENTS file\n",
-+ counter,
-+ installedPortsDbPortName,
-+ installedPortsDbPortDir,
-+ oldDependencyName );
-+ while( fflush( stdout ) );
-+
-+ MGdbAdd( property->oldPortsDb,
-+ installedPortsDbPortDir,
-+ installedPortsDbPortName,
-+ "PRISTINE MODE: incorrect +CONTENTS file entry",
-+ oldDependencyName,
-+ oldDependencyDir,
-+ NULL );
-+ }
-+ else
-+ {
-+ fprintf( stdout, "%05d have:%-35s %-35s built with OLD dependency: %s\n",
-+ counter,
-+ installedPortsDbPortName,
-+ installedPortsDbPortDir,
-+ oldDependencyName );
-+ while( fflush( stdout ) );
-+
-+ MGdbAdd( property->oldPortsDb,
-+ installedPortsDbPortDir,
-+ installedPortsDbPortName,
-+ "built with OLD dependency",
-+ oldDependencyName,
-+ oldDependencyDir,
-+ NULL );
-+ }
-
-- MGdbAdd( property->oldPortsDb,
-- installedPortsDbPortDir,
-- installedPortsDbPortName,
-- "built with OLD dependency",
-- oldDependencyName,
-- oldDependencyDir,
-- NULL );
- }
- else
- {
-@@ -353,11 +379,11 @@
- char exact[] = "exact";
- char* availableDependenciesDbDependencyNamePtr = NULL;
- char* installedPortsDbPortNamePtr = NULL;
--
-+
- counterPtr[0]++;
-
- /*
-- * Are all dpendencies belonging to installedPortsDbPortName in installedPortsDb?
-+ * Are all availableDependencies belonging to installedPortsDbPortName in installedPortsDb?
- */
- MGdbGoTop( property->availableDependenciesDb );
-
-@@ -385,7 +411,7 @@
- }
-
- /*
-- * installedPortsDbPortName has no dependencies, were done here
-+ * installedPortsDbPortName has no available Dependencies, we are done here
- */
- if( availableDependenciesDbDependencyNamePtr == NULL )
- {
-@@ -406,7 +432,7 @@
- property->fieldInstalledPortsDbPortName,
- exact );
- /*
-- * dependency is not in installedPortsDb
-+ * availableDependency is not in installedPortsDb
- */
- if( installedPortsDbPortNamePtr == NULL )
- {
-@@ -421,6 +447,38 @@
- installedPortsDbPortDir,
- property->fieldAvailableDependenciesDbDependencyName,
- exact );
-+ }
-+
-+ if( property->pristine || property->forced )
-+ {
-+ /*
-+ * One last test is to check that each of installedPortsDbPortDir's dependencies found in dependencyDb are indeed in
-+ * installedDB, this verifies that +CONTENTS file is correct
-+ */
-+ MGdbGoTop( property->dependencyPortsDb );
-+ while( MGdbSeek( property->dependencyPortsDb,
-+ property->fieldDependencyDbPortDir,
-+ installedPortsDbPortDir,
-+ property->fieldDependencyDbPortDir,
-+ exact ) )
-+ {
-+ strcpy( oldDependencyName, MGdbGet( property->dependencyPortsDb,
-+ MGdbGetRecno( property->dependencyPortsDb ) - 1,
-+ property->fieldDependencyDbDependencyPortName ) );
-+
-+ MGdbGoTop( property->installedPortsDb );
-+ if( MGdbSeek( property->installedPortsDb,
-+ property->fieldInstalledPortsDbPortName,
-+ oldDependencyName,
-+ property->fieldInstalledPortsDbPortName,
-+ exact ) == NULL )
-+ {
-+ strcpy( oldDependencyDir, MGdbGet( property->dependencyPortsDb,
-+ MGdbGetRecno( property->dependencyPortsDb ) - 1,
-+ property->fieldDependencyDbDependencyPortDir ) );
-+ return( 2 );
-+ }
-+ }
- }
- oldDependencyDir[0] = 0;
- oldDependencyName[0] = 0;
-diff -ruN ../0.3.8/libMGPM/src/MGPMrUpdate.c ./libMGPM/src/MGPMrUpdate.c
---- ../0.3.8/libMGPM/src/MGPMrUpdate.c Sat Nov 19 18:01:27 2005
-+++ ./libMGPM/src/MGPMrUpdate.c Mon Nov 21 11:55:19 2005
-@@ -76,6 +76,7 @@
- int installedPortsDbIDX = 0;
- int installedPortsDbQTY = 0;
- int stdinFileDescriptor = 0;
-+ int stdinFileDescriptorIdx = 0;
- int answer = 1;
-
- structLocalProperty localProperty;
-@@ -610,7 +611,8 @@
- stinker = strstr( bufferBase, localProperty.installedPortName );
- if( stinker )
- {
-- fprintf( stdout, "OK to remove conflicting port %s Yy/Nn/Aa [Y]\? ", localProperty.installedPortName );
-+ fprintf( stdout, "OK to remove conflicting port %s Yy/Nn/Aa [Y]\?\n", localProperty.installedPortName );
-+ fprintf( stdout, "Will timeout after 5 minutes and default to [Y] if no selection is made\n" );
- while( fflush( stdout ) );
- if( property->autoConflicts == 0 )
- {
-@@ -693,8 +695,16 @@
- * reset alarm, reopen stdin after timeout
- */
- alarm(0);
-- stdinFileDescriptor = open( "/dev/tty", O_RDWR );
-+/*
-+ stdinFileDescriptorIdx = 0;
-+ while( ( stdinFileDescriptor = open( "/dev/tty", O_RDWR ) ) != -1 && stdinFileDescriptorIdx < 10000 )
-+ {
-+ printf( "open( /dev/tty ) retry %d of 100\n", stdinFileDescriptorIdx );
-+ stdinFileDescriptorIdx++;
-+ }
- stdin = fdopen( stdinFileDescriptor, "r" );
-+*/
-+ stdin = fdopen( 0, "r" );
- property->timeOut = 0;
- MGPMlogAdd( property, "conflicting installed ", localProperty.installedPortName,
- " removed from system after 5 minute timeout: conflicted with ", oldPortName, " " );
-diff -ruN ../0.3.8/libMGPM/src/libMGPM.h ./libMGPM/src/libMGPM.h
---- ../0.3.8/libMGPM/src/libMGPM.h Sat Nov 19 17:08:06 2005
-+++ ./libMGPM/src/libMGPM.h Sun Nov 20 16:54:55 2005
-@@ -119,6 +119,8 @@
- int autoConflicts; /* if 1 then conflicts Y/N default is Y */
- int autoMoved; /* if 1 then remove moved ports is Y */
- int backUp; /* if 1 then make packages for updatyed ports */
-+ int bsdPortMkPatched; /* 1 = bsd.port.mk is in patched state */
-+ int bsdPortMkPatchedBlock; /* 1 = bsd.port.mk can't be patch so quit trying */
- int buildDependsAreLeaves; /* 1 = treat build depends as if they don't exist in availableDependencies.db */
- int forced; /* 1 = forced updates 0 = normal */
- int interactive; /* 0 = non, 1 = interactive */
-@@ -126,10 +128,9 @@
- int objIdx;
- int optionsChanged; /* set by MGPMrUpdate for example to indicate a ports's options just changed */
- int pmMode; /* singlePort Upgrade = 1 multiple upgrade = 0 */
-+ int pristine; /* 1 = run in pristine mode */
- int resume; /* 0=normal 1=don't create databases*/
- int verbose;
-- int bsdPortMkPatched; /* 1 = bsd.port.mk is in patched state */
-- int bsdPortMkPatchedBlock; /* 1 = bsd.port.mk can't be patch so quit trying */
-
- /*
- * misc
-@@ -236,7 +237,7 @@
- int MGPMrStatus( structProperty* property );
- int MGPMrUpdate(structProperty* property, char* oldPortDir, char* oldPortName );
- int MGPMrBsdPortMkRevertPatch( structProperty* property );
--void MGPMrCatchSignal(int signalId ); /* located in MGPMrController.c */
--void MGPMrTimer( int signalId );
-+void MGPMrCatchSignal(int signalId ); /* located in MGPMrCommandLine.c */
-+void MGPMrTimer( int signalId ); /* located in MGPMrCommandLine.c */
-
- #endif
-diff -ruN ../0.3.8/portmanager/help.txt ./portmanager/help.txt
---- ../0.3.8/portmanager/help.txt Fri Nov 18 07:49:06 2005
-+++ ./portmanager/help.txt Sun Nov 20 11:44:28 2005
-@@ -33,6 +33,14 @@
- instead of starting from the beggining by
- trying this option
-
-+ -p or --pristine Updates a port if any dependency in it's
-+ /var/db/pkg/{port name}/+CONTENTS does not
-+ match what is installed. The effect is when a
-+ port is updated, any port who uses the updated
-+ port in it's dependency chain, no matter how
-+ deep, are rebuilt. Normally only ports one
-+ level up are rebuilt.
-+
- examples:
-
- to add or update a single port with logging:
-diff -ruN ../0.3.8/portmanager/portmanager.1 ./portmanager/portmanager.1
---- ../0.3.8/portmanager/portmanager.1 Fri Nov 18 07:49:06 2005
-+++ ./portmanager/portmanager.1 Sun Nov 20 12:37:51 2005
-@@ -88,6 +88,13 @@
- from the ports tree (see /usr/ports/MOVED for a list of these)
- .sp
- .It
-+\fB\&-p\fR or \fB\&--pristine\fR
-+ Updates a port if any dependency in it's /var/db/pkg/{port name}/+CONTENTS
-+does not match what is installed. The effect is when a port is updated, any
-+port who uses the updated port in it's dependency chain, no matter how deep,
-+are rebuilt. Normally only ports one level up are rebuilt.
-+.sp
-+.It
- \fB\&--resume\fR
- bypass installed port dependency data collection: if you quit in the middle of a forced update for example,
- you may be able to resume instead of starting from the beginning with this option. After you have updated
diff --git a/ports-mgmt/portmanager/files/patch-0.3.8_2 b/ports-mgmt/portmanager/files/patch-0.3.8_2
deleted file mode 100644
index 6349c849bf9..00000000000
--- a/ports-mgmt/portmanager/files/patch-0.3.8_2
+++ /dev/null
@@ -1,97 +0,0 @@
-diff -ruN ../0.3.8_1/libMGPM/src/MGPMrGetPortName.c ./libMGPM/src/MGPMrGetPortName.c
---- ../0.3.8_1/libMGPM/src/MGPMrGetPortName.c Mon Nov 21 15:18:23 2005
-+++ ./libMGPM/src/MGPMrGetPortName.c Tue Nov 22 08:18:39 2005
-@@ -78,7 +78,9 @@
- "%s %s is no longer in the ports collection, see /usr/ports/MOVED\nthis port must be removed for portmanager to continue\nis it OK to remove %s from your system? (yes/no/auto yes to all) [y/n/a] [y]\n",
- portName, portDir, portName );
- fprintf( stdout, "%s\n", SINGLE_LINES );
-+/*
- fprintf( stdout, "Will timeout after 5 minutes and default to [Y] if no selection is made\n" );
-+*/
- while( fflush( stdout ) );
-
- if( property->autoMoved == 0 )
-@@ -86,9 +88,11 @@
- /*
- * set timeout default to Y
- */
-+/*
- property->timeOut = 0;
- signal( SIGALRM, MGPMrTimer );
-- alarm( 300 ); /* time out in 5 minutes */
-+ alarm( 300 );
-+*/
- answer = getc(stdin);
-
- switch(answer)
-@@ -156,18 +160,11 @@
- /*
- * reset alarm, reopen stdin after timeout
- */
-- alarm(0);
- /*
-- stdinFileDescriptorIdx = 0;
-- while( ( stdinFileDescriptor = open( "/dev/tty", O_RDWR ) ) != -1 && stdinFileDescriptorIdx < 10000 )
-- {
-- printf( "open( /dev/tty ) retry %d of 100\n", stdinFileDescriptorIdx );
-- stdinFileDescriptorIdx++;
-- }
-- stdin = fdopen( stdinFileDescriptor, "r" );
--*/
-- stdin = fdopen( 0, "r" );
-+ alarm(0);
-+ stdin = fdopen( fileno(stdin), "r" );
- property->timeOut = 0;
-+*/
- MGPMlogAdd( property, "installed ", portName,
- " removed from system after 5 minute timeout: no longer in ports tree: see /usr/ports/MOVED", " ", " " );
- }
-diff -ruN ../0.3.8_1/libMGPM/src/MGPMrUpdate.c ./libMGPM/src/MGPMrUpdate.c
---- ../0.3.8_1/libMGPM/src/MGPMrUpdate.c Mon Nov 21 15:18:23 2005
-+++ ./libMGPM/src/MGPMrUpdate.c Tue Nov 22 08:17:51 2005
-@@ -612,18 +612,21 @@
- if( stinker )
- {
- fprintf( stdout, "OK to remove conflicting port %s Yy/Nn/Aa [Y]\?\n", localProperty.installedPortName );
-+/*
- fprintf( stdout, "Will timeout after 5 minutes and default to [Y] if no selection is made\n" );
-+*/
- while( fflush( stdout ) );
- if( property->autoConflicts == 0 )
- {
- /*
- * set timeout default to Y
- */
-+/*
- property->timeOut = 0;
- signal( SIGALRM, MGPMrTimer );
-- alarm( 300 ); /* time out in 5 minutes */
-+ alarm( 300 );
-+*/
- answer = getc(stdin);
--
- switch(answer)
- {
- case KEY_ENTER:
-@@ -694,18 +697,11 @@
- /*
- * reset alarm, reopen stdin after timeout
- */
-- alarm(0);
- /*
-- stdinFileDescriptorIdx = 0;
-- while( ( stdinFileDescriptor = open( "/dev/tty", O_RDWR ) ) != -1 && stdinFileDescriptorIdx < 10000 )
-- {
-- printf( "open( /dev/tty ) retry %d of 100\n", stdinFileDescriptorIdx );
-- stdinFileDescriptorIdx++;
-- }
-- stdin = fdopen( stdinFileDescriptor, "r" );
--*/
-- stdin = fdopen( 0, "r" );
-+ alarm(0);
-+ stdin = fdopen( fileno(stdin), "r" );
- property->timeOut = 0;
-+*/
- MGPMlogAdd( property, "conflicting installed ", localProperty.installedPortName,
- " removed from system after 5 minute timeout: conflicted with ", oldPortName, " " );
- }
diff --git a/ports-mgmt/portmanager/files/patch-0.3.9_1 b/ports-mgmt/portmanager/files/patch-0.3.9_1
new file mode 100644
index 00000000000..ef2a7095e75
--- /dev/null
+++ b/ports-mgmt/portmanager/files/patch-0.3.9_1
@@ -0,0 +1,222 @@
+diff -ruN ../0.3.9/libMGPM/src/MGPMrCommandLine.c ./libMGPM/src/MGPMrCommandLine.c
+--- ../0.3.9/libMGPM/src/MGPMrCommandLine.c Wed Nov 23 19:35:36 2005
++++ ./libMGPM/src/MGPMrCommandLine.c Fri Nov 25 10:38:28 2005
+@@ -57,7 +57,7 @@
+ /*
+ fprintf( stdout, "MGPMrTimer received signal -=>%d\n", signalId );
+ */
+- fclose( globalProperty->stdin );
++ fclose( globalProperty->STDIN );
+ globalProperty->timeOut = 1;
+ }
+
+diff -ruN ../0.3.9/libMGPM/src/MGPMrGetPortName.c ./libMGPM/src/MGPMrGetPortName.c
+--- ../0.3.9/libMGPM/src/MGPMrGetPortName.c Thu Nov 24 09:28:49 2005
++++ ./libMGPM/src/MGPMrGetPortName.c Fri Nov 25 11:22:07 2005
+@@ -84,11 +84,11 @@
+ /*
+ * set timeout default to Y
+ */
+- property->stdin = fopen( "/dev/stdin", "r" );
+- property->timeOut = 0;
+- signal( SIGALRM, MGPMrTimer );
+ alarm( property->timeout );
+- answer = getc( property->stdin );
++ signal( SIGALRM, MGPMrTimer );
++ property->STDIN = fopen( "/dev/stdin", "r" );
++ property->timeOut = 0;
++ answer = getc( property->STDIN );
+
+ switch(answer)
+ {
+@@ -98,36 +98,36 @@
+ }
+ case KEY_A:
+ {
+- answer = getc( property->stdin );
++ answer = getc( property->STDIN );
+ property->autoMoved = 1;
+ break;
+ }
+ case KEY_a:
+ {
+ property->autoMoved = 1;
+- answer = getc( property->stdin );
++ answer = getc( property->STDIN );
+ break;
+ }
+ case KEY_Y:
+ {
+- answer = getc( property->stdin );
++ answer = getc( property->STDIN );
+ break;
+ }
+ case KEY_y:
+ {
+- answer = getc( property->stdin );
++ answer = getc( property->STDIN );
+ break;
+ }
+ case KEY_N:
+ {
+- answer = getc( property->stdin );
++ answer = getc( property->STDIN );
+ fprintf( stdout, "you will have to deal with this manually then, portmanager shutting down\n" );
+ while( fflush( stdout ) );
+ exit(0);
+ }
+ case KEY_n:
+ {
+- answer = getc( property->stdin );
++ answer = getc( property->STDIN );
+ fprintf( stdout, "you will have to deal with this manually then, portmanager shutting down\n" );
+ while( fflush( stdout ) );
+ exit(0);
+@@ -143,7 +143,7 @@
+ {
+ fprintf( stdout, "Invalid option. Please enter either Y to upgrade or N\n");
+ while( fflush( stdout ) );
+- answer = getc( property->stdin );
++ answer = getc( property->STDIN );
+ }
+ }
+ }
+@@ -156,7 +156,7 @@
+ if( property->timeOut == 1 )
+ {
+ /*
+- * reset alarm, reopen stdin after timeout
++ * reset alarm, reopen STDIN after timeout
+ */
+ alarm(0);
+ property->timeOut = 0;
+@@ -165,7 +165,7 @@
+ }
+ else
+ {
+- fclose( property->stdin );
++ fclose( property->STDIN );
+ MGPMlogAdd( property, "installed ", portName,
+ " removed from system: no longer in ports tree: see /usr/ports/MOVED", " ", " " );
+ }
+diff -ruN ../0.3.9/libMGPM/src/MGPMrUpdate.c ./libMGPM/src/MGPMrUpdate.c
+--- ../0.3.9/libMGPM/src/MGPMrUpdate.c Thu Nov 24 10:01:19 2005
++++ ./libMGPM/src/MGPMrUpdate.c Fri Nov 25 11:21:55 2005
+@@ -617,11 +617,11 @@
+ /*
+ * set timeout default to Y
+ */
+- property->stdin = fopen( "/dev/stdin", "r" );
+- property->timeOut = 0;
+- signal( SIGALRM, MGPMrTimer );
+ alarm( property->timeout );
+- answer = getc( property->stdin );
++ signal( SIGALRM, MGPMrTimer );
++ property->STDIN = fopen( "/dev/stdin", "r" );
++ property->timeOut = 0;
++ answer = getc( property->STDIN );
+
+ switch(answer)
+ {
+@@ -631,24 +631,24 @@
+ }
+ case KEY_A:
+ {
+- answer = getc( property->stdin );
++ answer = getc( property->STDIN );
+ property->autoConflicts = 1;
+ break;
+ }
+ case KEY_a:
+ {
+ property->autoConflicts = 1;
+- answer = getc( property->stdin );
++ answer = getc( property->STDIN );
+ break;
+ }
+ case KEY_Y:
+ {
+- answer = getc( property->stdin );
++ answer = getc( property->STDIN );
+ break;
+ }
+ case KEY_y:
+ {
+- answer = getc( property->stdin );
++ answer = getc( property->STDIN );
+ break;
+ }
+ case KEY_N:
+@@ -656,7 +656,7 @@
+ fprintf( stdout, "\nAdding %s %s to ignore list\n", oldPortName, oldPortDir );
+ while( fflush( stdout ) );
+ MGdbAdd( property->ignoreDb, oldPortDir, "conflicts with another port", NULL );
+- answer = getc( property->stdin );
++ answer = getc( property->STDIN );
+ rCleanUp( property, &localProperty );
+ return(0);
+ }
+@@ -665,7 +665,7 @@
+ fprintf( stdout, "\nAdding %s %s to ignore list\n", oldPortName, oldPortDir );
+ while( fflush( stdout ) );
+ MGdbAdd( property->ignoreDb, oldPortDir, "conflicts with another port", NULL );
+- answer = getc( property->stdin );
++ answer = getc( property->STDIN );
+ rCleanUp( property, &localProperty );
+ return(0);
+ }
+@@ -680,7 +680,7 @@
+ {
+ fprintf( stdout, "Invalid option. Please enter either Y to upgrade or N\n");
+ while( fflush( stdout ) );
+- answer = getc( property->stdin );
++ answer = getc( property->STDIN );
+ }
+ }
+ }
+@@ -691,7 +691,7 @@
+ if( property->timeOut == 1 )
+ {
+ /*
+- * reset alarm, reopen stdin after timeout
++ * reset alarm, reopen STDIN after timeout
+ */
+ alarm(0);
+ property->timeOut = 0;
+@@ -701,7 +701,7 @@
+ }
+ else
+ {
+- fclose( property->stdin );
++ fclose( property->STDIN );
+ MGPMlogAdd( property, "conflicting installed ", localProperty.installedPortName,
+ " removed from system: conflicted with ", oldPortName, " " );
+ }
+@@ -1249,12 +1249,12 @@
+ * 5 second time delay
+ */
+ /*
+- property->stdin = fopen( "/dev/stdin", "r" );
++ property->STDIN = fopen( "/dev/STDIN", "r" );
+ signal( SIGALRM, MGPMrTimer );
+ alarm( 5 );
+- answer = getc( property->stdin );
++ answer = getc( property->STDIN );
+ alarm(0);
+- fclose( property->stdin );
++ fclose( property->STDIN );
+ */
+
+ strcpy( localProperty.command, "cp /tmp/*.db " );
+diff -ruN ../0.3.9/libMGPM/src/libMGPM.h ./libMGPM/src/libMGPM.h
+--- ../0.3.9/libMGPM/src/libMGPM.h Fri Nov 25 05:50:16 2005
++++ ./libMGPM/src/libMGPM.h Fri Nov 25 10:38:39 2005
+@@ -139,7 +139,7 @@
+ int timeout; /* default timeout in seconds */
+ int verbose;
+
+- FILE* stdin;
++ FILE* STDIN;
+ /*
+ * misc
+ */
diff --git a/ports-mgmt/portmanager/pkg-plist b/ports-mgmt/portmanager/pkg-plist
index 918e486f772..a59e6356992 100644
--- a/ports-mgmt/portmanager/pkg-plist
+++ b/ports-mgmt/portmanager/pkg-plist
@@ -1,3 +1,5 @@
+@unexec rm -f %D/etc/portmanager/pm-039-pkg-tools.conf 2>/dev/null || true
+@unexec rm -f %D/share/portmanager/pkgtools.db 2>/dev/null || true
@unexec rm -f %D/share/portmanager/3strikes.db 2>/dev/null || true
@unexec rm -f %D/share/portmanager/commandLine.db 2>/dev/null || true
@unexec rm -f %D/share/portmanager/configure.db 2>/dev/null || true
@@ -13,6 +15,7 @@
@unexec rm -f %D/share/portmanager/ports_old.db 2>/dev/null || true
%%DATADIR%%/help.txt
%%DATADIR%%/patch-bsd.port.mk-0.3.6
+%%DATADIR%%/pkgtools-to-portmanager.rb
%%DATADIR%%/bsd.port.mk-BACKUP
bin/portmanager
etc/portmanager/pm-020.conf.SAMPLE