summaryrefslogtreecommitdiff
path: root/ports-mgmt/pkg_cleanup
diff options
context:
space:
mode:
authorPav Lucistnik <pav@FreeBSD.org>2011-03-25 20:58:07 +0000
committerPav Lucistnik <pav@FreeBSD.org>2011-03-25 20:58:07 +0000
commitdf339ef28af1a631d29fd8e352d1cb7c796c9908 (patch)
tree75ed56c79fd9678a8bc1824befdec410734add9f /ports-mgmt/pkg_cleanup
parentccceb519697416e5b7ea5b05a0ab41084442752f (diff)
downloadfreebsd-ports-df339ef28af1a631d29fd8e352d1cb7c796c9908.zip
- Fix build on -CURRENT
PR: ports/155771 Submitted by: Stephen Hurd <shurd@sasktel.net> (maintainer)
Diffstat (limited to 'ports-mgmt/pkg_cleanup')
-rw-r--r--ports-mgmt/pkg_cleanup/Makefile3
-rw-r--r--ports-mgmt/pkg_cleanup/files/Makefile1
-rw-r--r--ports-mgmt/pkg_cleanup/files/pkg_cleanup.c188
3 files changed, 158 insertions, 34 deletions
diff --git a/ports-mgmt/pkg_cleanup/Makefile b/ports-mgmt/pkg_cleanup/Makefile
index e3d75398f3b2..e73a5d47faad 100644
--- a/ports-mgmt/pkg_cleanup/Makefile
+++ b/ports-mgmt/pkg_cleanup/Makefile
@@ -6,8 +6,7 @@
#
PORTNAME= pkg_cleanup
-PORTVERSION= 1.0
-PORTREVISION= 2
+PORTVERSION= 1.1
CATEGORIES= ports-mgmt
DISTFILES=
diff --git a/ports-mgmt/pkg_cleanup/files/Makefile b/ports-mgmt/pkg_cleanup/files/Makefile
index e5271323fc1d..8f60dfa3061b 100644
--- a/ports-mgmt/pkg_cleanup/files/Makefile
+++ b/ports-mgmt/pkg_cleanup/files/Makefile
@@ -1,5 +1,6 @@
# $FreeBSD$
+LDLIBS += -lncursesw
LDLIBS += -ldialog
pkg_cleanup: pkg_cleanup.c
diff --git a/ports-mgmt/pkg_cleanup/files/pkg_cleanup.c b/ports-mgmt/pkg_cleanup/files/pkg_cleanup.c
index 675e18250f06..000045327b55 100644
--- a/ports-mgmt/pkg_cleanup/files/pkg_cleanup.c
+++ b/ports-mgmt/pkg_cleanup/files/pkg_cleanup.c
@@ -15,8 +15,27 @@
#include <sysexits.h>
#include <unistd.h>
+#if __FreeBSD_version < 900030
+#define OLD_DIALOG
+#endif
+
static glob_t gl; /* A cached list of all files in /var/db/pkg */
-dialogMenuItem *menu=NULL;
+#ifdef OLD_DIALOG
+typedef dialogMenuItem ListItem;
+#else
+typedef DIALOG_LISTITEM ListItem;
+#endif
+ListItem *menu;
+#ifdef OLD_DIALOG
+#define ITEM_DATA data
+#define ITEM_PROMPT prompt
+#define ITEM_CHECKED aux
+#else
+#define ITEM_DATA help
+#define ITEM_PROMPT name
+#define ITEM_CHECKED state
+#endif
+
int menulen=0;
void free_menu(void)
@@ -25,13 +44,13 @@ void free_menu(void)
if(menu) {
for(i=0; i<menulen; i++) {
- if(menu[i].data) {
- free(menu[i].data);
- menu[i].data=NULL;
+ if(menu[i].ITEM_DATA) {
+ free(menu[i].ITEM_DATA);
+ menu[i].ITEM_DATA=NULL;
}
- if(menu[i].prompt) {
- free(menu[i].prompt);
- menu[i].prompt=NULL;
+ if(menu[i].ITEM_PROMPT) {
+ free(menu[i].ITEM_PROMPT);
+ menu[i].ITEM_PROMPT=NULL;
}
}
free(menu);
@@ -49,6 +68,7 @@ int blacklist(char *path, int operation)
return(hsearch(item, operation)!=NULL);
}
+#ifdef OLD_DIALOG
int fire(struct _dmenu_item *item)
{
if(item->aux)
@@ -80,22 +100,23 @@ int checked(struct _dmenu_item *item)
return(TRUE);
return(FALSE);
}
+#endif
/* Read +COMMENT, add to menu and blacklist */
int add_item(char *path)
{
- char *p;
- char comment[80];
- FILE *comment_file;
- char comment_path[MAXPATHLEN+1];
- dialogMenuItem *newmenu;
+ char *p;
+ char comment[80];
+ FILE *file;
+ char newpath[MAXPATHLEN+1];
+ ListItem *newmenu;
if(blacklist(path,FIND))
return(0);
blacklist(path,ENTER);
comment[0]=0;
- newmenu=(dialogMenuItem*)realloc(menu, sizeof(dialogMenuItem)*(menulen+1));
+ newmenu=(ListItem *)realloc(menu, sizeof(ListItem)*(menulen+1));
if(newmenu==NULL)
return(-1);
menu=newmenu;
@@ -104,7 +125,9 @@ int add_item(char *path)
if(p==NULL) /* Not possible */
return(-1);
- menu[menulen].prompt=strdup(p+1);
+ menu[menulen].ITEM_PROMPT=strdup(p+1);
+ menu[menulen].ITEM_CHECKED=0;
+#ifdef OLD_DIALOG
menu[menulen].title="";
menu[menulen].checked=checked;
menu[menulen].fire=fire;
@@ -112,14 +135,16 @@ int add_item(char *path)
menu[menulen].lbra='[';
menu[menulen].mark='X';
menu[menulen].rbra=']';
- menu[menulen].aux=0;
+#else
+ menu[menulen].text="";
+#endif
/* Read +COMMENT */
- sprintf(comment_path,"%s/+COMMENT",path);
- comment_file=fopen(comment_path,"r");
- if(comment_file) {
- fgets(comment, sizeof(comment), comment_file);
- fclose(comment_file);
+ sprintf(newpath,"%s/+COMMENT",path);
+ file=fopen(newpath,"r");
+ if(file) {
+ fgets(comment, sizeof(comment), file);
+ fclose(file);
/* Remove trailing whitespace */
for(p=strchr(comment,0)-1; p>=comment; p--) {
if(isspace(*p))
@@ -128,22 +153,75 @@ int add_item(char *path)
break;
}
}
- menu[menulen].data=strdup(comment);
+ menu[menulen].ITEM_DATA=strdup(comment);
menulen++;
return(0);
}
+void do_init_dialog(void)
+{
+#ifdef OLD_DIALOG
+ init_dialog();
+ use_shadow=FALSE;
+#else
+ init_dialog(stdin, stdout);
+ dialog_state.use_shadow=FALSE;
+#endif
+}
+
int display_menu(void)
{
int ret=0;
- int maxx,maxy;
+ int maxx,maxy;
+ int curr;
- init_dialog();
- use_shadow=FALSE;
+ do_init_dialog();
getmaxyx(stdscr, maxy, maxx);
+#ifdef OLD_DIALOG
if(dialog_checklist("Welcome to pkg_cleanup.", "These are the leaf packages installed on your system\nChose the packages to deinstall. F1 will display the package description.\n\n\n", maxy, maxx, maxy-11, 0-menulen, menu, NULL))
ret=-1;
+#else
+ dialog_vars.help_button=1;
+ dialog_vars.item_help=1;
+loop:
+ switch(ret=dlg_checklist("Welcome to pkg_cleanup.", "These are the leaf packages installed on your system\nChose the packages to deinstall. Help will display the package description.", maxy-1, maxx, maxy-9, menulen, menu, " X", FLAG_CHECK, &curr)) {
+ case DLG_EXIT_HELP: {
+ char *p;
+ char newpath[MAXPATHLEN+1];
+ FILE *file;
+ struct stat sb;
+
+ /* READ +DESC */
+ sprintf(newpath,"/var/db/pkg/%s/+DESC",menu[curr].ITEM_PROMPT);
+ file=fopen(newpath, "r");
+ if(file) {
+ if(fstat(fileno(file), &sb)==0) {
+ p=(char *)malloc(sb.st_size+1);
+ if(p) {
+ if(fread(p, sb.st_size, 1, file)==1) {
+ p[sb.st_size]=0;
+ dialog_vars.help_button=0;
+ dialog_msgbox(menu[curr].ITEM_DATA, p, maxy-4, maxx-4, TRUE);
+ dialog_vars.help_button=1;
+ }
+ free(p);
+ }
+ }
+ fclose(file);
+ }
+ goto loop;
+ }
+ case 0:
+ ret=0;
+ break;
+ default:
+ ret=-1;
+ break;
+ }
+ dialog_vars.help_button=0;
+ dialog_vars.item_help=0;
+#endif
end_dialog();
return(ret);
}
@@ -157,13 +235,38 @@ int read_pkglist(int loops)
int maxx,maxy;
int lastgauge=-1;
int gauge;
+#ifndef OLD_DIALOG
+ int pipepair[2];
+ FILE *read_pipe;
+ FILE *write_pipe;
+#endif
- init_dialog();
+ do_init_dialog();
getmaxyx(stdscr, maxy, maxx);
for(p=0;p<gl.gl_pathc;p++) {
gauge=p*100/gl.gl_pathc;
if(gauge != lastgauge) {
+#ifdef OLD_DIALOG
dialog_gauge(NULL, "Searching for leaves", maxy/2-1, maxx/2-12, 7, 24, gauge);
+#else
+ if(pipe(pipepair)!=0) {
+ fputs("Cannot create pipe pair.\n", stderr);
+ return(-1);
+ }
+ if((read_pipe=fdopen(pipepair[0], "r"))==NULL) {
+ fputs("Cannot open read end of pipe pair.\n", stderr);
+ return(-1);
+ }
+ dialog_state.pipe_input=read_pipe;
+ if((write_pipe=fdopen(pipepair[1], "r"))==NULL) {
+ fputs("Cannot open read end of pipe pair.\n", stderr);
+ return(-1);
+ }
+ fprintf(write_pipe, "%d\n%c", gauge, 4);
+ fclose(write_pipe);
+ dialog_gauge(NULL, "Searching for leaves", maxy/2-1, maxx/2-12, gauge);
+ fclose(read_pipe);
+#endif
lastgauge=gauge;
}
sprintf(path,"%s/+REQUIRED_BY",gl.gl_pathv[p]);
@@ -184,8 +287,29 @@ int read_pkglist(int loops)
add_item(gl.gl_pathv[p]);
}
}
+#ifdef OLD_DIALOG
dialog_gauge(NULL, "Searching for leaves", maxy/2-1, maxx/2-12, 7, 24, 100);
dialog_clear_norefresh();
+#else
+ if(pipe(pipepair)!=0) {
+ fputs("Cannot create pipe pair.\n", stderr);
+ return(-1);
+ }
+ if((read_pipe=fdopen(pipepair[0], "r"))==NULL) {
+ fputs("Cannot open read end of pipe pair.\n", stderr);
+ return(-1);
+ }
+ dialog_state.pipe_input=read_pipe;
+ if((write_pipe=fdopen(pipepair[1], "r"))==NULL) {
+ fputs("Cannot open read end of pipe pair.\n", stderr);
+ return(-1);
+ }
+ fprintf(write_pipe, "%d\n%c", 100, 4);
+ fclose(write_pipe);
+ dialog_gauge(NULL, "Searching for leaves", maxy/2-1, maxx/2-12, 100);
+ fclose(read_pipe);
+ dlg_clear();
+#endif
if(menulen==0) {
if(loops)
dialog_msgbox(NULL, "No new leaves found", 5, 23, TRUE);
@@ -210,7 +334,7 @@ int remove_ports(void)
args=(char **)malloc((menulen+2) * sizeof(char *));
if(!args) {
- init_dialog();
+ do_init_dialog();
dialog_msgbox("ERROR", "Can not allocate memory for package list!", 5, 45, TRUE);
end_dialog();
return(-1);
@@ -218,14 +342,14 @@ int remove_ports(void)
p=args;
*(p++)="-G";
for(i=0;i<menulen;i++) {
- if(menu[i].aux) {
- *(p++)=menu[i].prompt;
+ if(menu[i].ITEM_CHECKED) {
+ *(p++)=menu[i].ITEM_PROMPT;
delete_count++;
}
}
*(p)=NULL;
if(!delete_count) {
- init_dialog();
+ do_init_dialog();
dialog_msgbox(NULL, "No packages selected", 5, 24, TRUE);
end_dialog();
free(args);
@@ -242,7 +366,7 @@ int remove_ports(void)
}
free(args);
if(child==-1) {
- init_dialog();
+ do_init_dialog();
dialog_msgbox(NULL, "Can not fork()", 5, 18, TRUE);
end_dialog();
return(-1);
@@ -261,7 +385,7 @@ int keep_going(void)
{
int ret;
- init_dialog();
+ do_init_dialog();
ret = !dialog_yesno(NULL,"Do you want to process the new leaves packages?",-1,-1);
end_dialog();
return(ret);
@@ -312,6 +436,6 @@ int main(int argc, char **argv)
free_menu();
} while(keep_going());
- fputs("Program Terminated Successfully\n",stderr);
+ fputs("\nProgram Terminated Successfully\n",stderr);
return(0);
}