import eject by Peter Willis / Tito Ragusa
diff --git a/AUTHORS b/AUTHORS
index ebf57b6..6701562 100644
--- a/AUTHORS
+++ b/AUTHORS
@@ -8,6 +8,9 @@
 
 -----------
 
+Peter Willis <psyphreak@phreaker.net>
+    eject
+
 Emanuele Aina <emanuele.aina@tiscali.it>
     run-parts
 
@@ -139,5 +142,6 @@
     tarcat (since removed), loadkmap, various fixes, Debian maintenance
 
 Tito Ragusa <farmatito@tiscali.it>
-    devfsd and size optimizations in strings, openvt, chvt, deallocvt, hdparm and fdformat.
+    devfsd and size optimizations in strings, openvt, chvt, deallocvt, hdparm,
+    fdformat, lsattr, chattr, id and eject.
 
diff --git a/include/applets.h b/include/applets.h
index 7f6f758..3f411c2 100644
--- a/include/applets.h
+++ b/include/applets.h
@@ -182,6 +182,9 @@
 #if defined(CONFIG_FEATURE_GREP_EGREP_ALIAS)
 	APPLET_NOUSAGE("egrep", grep_main, _BB_DIR_BIN, _BB_SUID_NEVER)
 #endif
+#ifdef CONFIG_EJECT
+	APPLET(eject, eject_main, _BB_DIR_USR_BIN, _BB_SUID_NEVER)
+#endif
 #ifdef CONFIG_ENV
 	APPLET(env, env_main, _BB_DIR_USR_BIN, _BB_SUID_NEVER)
 #endif
diff --git a/include/usage.h b/include/usage.h
index 1ef79df..316772e 100644
--- a/include/usage.h
+++ b/include/usage.h
@@ -556,6 +556,19 @@
 	"$ echo \"Erik\\nis\\ncool\"\n" \
 	"Erik\\nis\\ncool\n")
 
+#ifdef CONFIG_FEATURE_EJECT_LONG_OPTIONS
+# define USAGE_EJECT_TRAYCLOSE ",trayclose"
+#else
+# define USAGE_EJECT_TRAYCLOSE ""
+#endif
+
+#define eject_trivial_usage \
+	"[-t] [DEVICE]"
+#define eject_full_usage \
+	"Eject specified DEVICE (or default /dev/cdrom).\n\n" \
+	"Options:\n" \
+	"\tt" USAGE_EJECT_TRAYCLOSE "\tclose tray"
+
 #define env_trivial_usage \
 	"[-iu] [-] [name=value]... [command]"
 #define env_full_usage \
diff --git a/miscutils/Config.in b/miscutils/Config.in
index 77e13e8..710639a 100644
--- a/miscutils/Config.in
+++ b/miscutils/Config.in
@@ -83,6 +83,19 @@
 	help
 	  Increases logging to stderr or syslog.
 
+config CONFIG_EJECT
+	bool "eject"
+	default n
+	help
+	  Used to eject cdroms.  (defaults to /dev/cdrom)
+
+config CONFIG_FEATURE_EJECT_LONG_OPTIONS
+	bool "  Enable support for --trayclose long option (-t)"
+	default n
+	depends on CONFIG_EJECT
+	help
+	  Enable use of long options (like --trayclose for -t).
+
 config CONFIG_LAST
 	bool "last"
 	default n
diff --git a/miscutils/Makefile.in b/miscutils/Makefile.in
index ddddf72..d714f40 100644
--- a/miscutils/Makefile.in
+++ b/miscutils/Makefile.in
@@ -24,19 +24,20 @@
 srcdir=$(top_srcdir)/miscutils
 
 MISCUTILS-y:=
-MISCUTILS-$(CONFIG_ADJTIMEX)		+= adjtimex.o
-MISCUTILS-$(CONFIG_CROND)               += crond.o
-MISCUTILS-$(CONFIG_CRONTAB)             += crontab.o
-MISCUTILS-$(CONFIG_DC)			+= dc.o
-MISCUTILS-$(CONFIG_DEVFSD)		+= devfsd.o
-MISCUTILS-$(CONFIG_HDPARM)		+= hdparm.o
-MISCUTILS-$(CONFIG_LAST)		+= last.o
-MISCUTILS-$(CONFIG_MAKEDEVS)		+= makedevs.o
-MISCUTILS-$(CONFIG_MT)			+= mt.o
-MISCUTILS-$(CONFIG_RX)			+= rx.o
-MISCUTILS-$(CONFIG_STRINGS)		+= strings.o
-MISCUTILS-$(CONFIG_TIME)		+= time.o
-MISCUTILS-$(CONFIG_WATCHDOG)		+= watchdog.o
+MISCUTILS-$(CONFIG_ADJTIMEX)    += adjtimex.o
+MISCUTILS-$(CONFIG_CROND)       += crond.o
+MISCUTILS-$(CONFIG_CRONTAB)     += crontab.o
+MISCUTILS-$(CONFIG_DC)          += dc.o
+MISCUTILS-$(CONFIG_DEVFSD)      += devfsd.o
+MISCUTILS-$(CONFIG_EJECT)       += eject.o
+MISCUTILS-$(CONFIG_HDPARM)      += hdparm.o
+MISCUTILS-$(CONFIG_LAST)        += last.o
+MISCUTILS-$(CONFIG_MAKEDEVS)    += makedevs.o
+MISCUTILS-$(CONFIG_MT)          += mt.o
+MISCUTILS-$(CONFIG_RX)          += rx.o
+MISCUTILS-$(CONFIG_STRINGS)     += strings.o
+MISCUTILS-$(CONFIG_TIME)        += time.o
+MISCUTILS-$(CONFIG_WATCHDOG)    += watchdog.o
 
 libraries-y+=$(MISCUTILS_DIR)$(MISCUTILS_AR)
 
diff --git a/miscutils/eject.c b/miscutils/eject.c
new file mode 100644
index 0000000..cbfd115
--- /dev/null
+++ b/miscutils/eject.c
@@ -0,0 +1,64 @@
+/*
+ * eject implementation for busybox
+ *
+ * Copyright (C) 2004  Peter Willis <psyphreak@phreaker.net>
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+ *
+ */
+
+/*
+ * This is a simple hack of eject based on something Erik posted in #uclibc.
+ * Most of the dirty work blatantly ripped off from cat.c =)
+ */
+
+#include <stdio.h>
+#include <string.h>
+#include <sys/types.h>
+#include <sys/stat.h>
+#include <fcntl.h>
+#include <sys/ioctl.h>
+#include <getopt.h>
+#include "busybox.h"
+
+/* various defines swiped from linux/cdrom.h */
+#define CDROMCLOSETRAY            0x5319  /* pendant of CDROMEJECT  */
+#define CDROMEJECT                0x5309  /* Ejects the cdrom media */
+#define DEFAULT_CDROM             "/dev/cdrom"
+/*#define CLOSE_TRAY              1*/
+
+extern int eject_main(int argc, char **argv)
+{
+	unsigned long flags;
+	
+#ifdef CONFIG_FEATURE_EJECT_LONG_OPTIONS
+	static const struct option eject_long_options[] = {
+		{ "trayclose", 0, 0, 't' },
+		{ 0,           0, 0, 0 }
+	};
+	bb_applet_long_options = eject_long_options;
+#endif
+
+	flags = bb_getopt_ulflags(argc, argv, "t");
+
+	if (ioctl(bb_xopen((argv[optind] ? argv[optind] : DEFAULT_CDROM), 
+	                   (O_RDONLY | O_NONBLOCK)), 
+	          ( flags /*& CLOSE_TRAY*/ ? CDROMCLOSETRAY : CDROMEJECT)))
+	{
+		bb_perror_msg_and_die(bb_msg_unknown);
+	}
+
+	return EXIT_SUCCESS;
+}
diff --git a/patches/eject.diff b/patches/eject.diff
deleted file mode 100644
index 197b8cd..0000000
--- a/patches/eject.diff
+++ /dev/null
@@ -1,164 +0,0 @@
-Index: AUTHORS
-===================================================================
-RCS file: /var/cvs/busybox/AUTHORS,v
-retrieving revision 1.40
-diff -u -r1.40 AUTHORS
---- a/AUTHORS	9 Oct 2003 21:19:21 -0000	1.40
-+++ b/AUTHORS	5 Mar 2004 07:23:17 -0000
-@@ -8,6 +8,9 @@
-
- -----------
-
-+Peter Willis <psyphreak@phreaker.net>
-+    eject
-+
- Emanuele Aina <emanuele.aina@tiscali.it>
- 	run-parts
-
-Index: coreutils/Config.in
-===================================================================
-RCS file: /var/cvs/busybox/coreutils/Config.in,v
-retrieving revision 1.23
-diff -u -r1.23 Config.in
---- a/coreutils/Config.in	5 Mar 2004 06:47:25 -0000	1.23
-+++ b/coreutils/Config.in	5 Mar 2004 07:23:18 -0000
-@@ -164,6 +164,13 @@
- 	  a command; without options it displays the current
- 	  environment.
-
-+config CONFIG_EJECT
-+	bool "eject"
-+	default n
-+	help
-+	  ejects a cdrom drive.
-+	  defaults to /dev/cdrom
-+
- config CONFIG_EXPR
- 	bool "expr"
- 	default n
-Index: coreutils/Makefile.in
-===================================================================
-RCS file: /var/cvs/busybox/coreutils/Makefile.in,v
-retrieving revision 1.8
-diff -u -r1.8 Makefile.in
---- a/coreutils/Makefile.in	27 Jan 2004 09:22:20 -0000	1.8
-+++ b/coreutils/Makefile.in	5 Mar 2004 07:23:18 -0000
-@@ -41,6 +41,7 @@
- COREUTILS-$(CONFIG_DU)      	+= du.o
- COREUTILS-$(CONFIG_ECHO)    	+= echo.o
- COREUTILS-$(CONFIG_ENV)     	+= env.o
-+COREUTILS-$(CONFIG_EJECT)   	+= eject.o
- COREUTILS-$(CONFIG_EXPR)    	+= expr.o
- COREUTILS-$(CONFIG_FALSE)   	+= false.o
- COREUTILS-$(CONFIG_FOLD)    	+= fold.o
-Index: coreutils/eject.c
-===================================================================
-RCS file: coreutils/eject.c
-diff -N coreutils/eject.c
---- /dev/null	1 Jan 1970 00:00:00 -0000
-+++ b/coreutils/eject.c	5 Mar 2004 07:23:21 -0000
-@@ -0,0 +1,66 @@
-+/*
-+ * eject implementation for busybox
-+ *
-+ * Copyright (C) 2004  Peter Willis <psyphreak@phreaker.net>
-+ *
-+ * This program is free software; you can redistribute it and/or modify
-+ * it under the terms of the GNU General Public License as published by
-+ * the Free Software Foundation; either version 2 of the License, or
-+ * (at your option) any later version.
-+ *
-+ * This program is distributed in the hope that it will be useful,
-+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
-+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
-+ * General Public License for more details.
-+ *
-+ * You should have received a copy of the GNU General Public License
-+ * along with this program; if not, write to the Free Software
-+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
-+ *
-+ */
-+
-+/*
-+ * This is a simple hack of eject based on something Erik posted in #uclibc.
-+ * Most of the dirty work blatantly ripped off from cat.c =)
-+ */
-+
-+#include <stdio.h>
-+#include <string.h>
-+#include <sys/types.h>
-+#include <sys/stat.h>
-+#include <fcntl.h>
-+#include <sys/ioctl.h>
-+#include "busybox.h"
-+#include <linux/cdrom.h> // needs to be after busybox.h or compile problems arise
-+
-+#define DEFAULT_CDROM "/dev/cdrom"
-+
-+extern int eject_main(int argc, char **argv)
-+{
-+	int fd;
-+	int flag = CDROMEJECT;
-+	int i = 1;
-+	char *device = NULL;
-+
-+	/*
-+	 * i'm too lazy to learn bb_getopt_ulflags and this is obscenely large
-+	 * for just some argument parsing so mjn3 can clean it up later.
-+	 * sorry, but PlumpOS 7.0-pre2 needs this asap :-/
-+	 */
-+	while (++i <= argc) {
-+		if ( (! strncmp(argv[i-1],"-t",2)) || (! strncmp(argv[i-1],"--trayclose",11)) ) {
-+			flag = CDROMCLOSETRAY;
-+		} else {
-+			device = argv[i-1];
-+		}
-+	}
-+	if ( (fd = open(device == NULL ? DEFAULT_CDROM : device, O_RDONLY | O_NONBLOCK) ) < 0 ) {
-+		perror("eject: Can't open device");
-+		return(EXIT_FAILURE);
-+	}
-+	if (ioctl(fd, flag)) {
-+		perror("eject: Can't eject cdrom");
-+		return(EXIT_FAILURE);
-+	}
-+	return EXIT_SUCCESS;
-+}
-Index: include/applets.h
-===================================================================
-RCS file: /var/cvs/busybox/include/applets.h,v
-retrieving revision 1.111
-diff -u -r1.111 applets.h
---- a/include/applets.h	27 Jan 2004 09:22:20 -0000	1.111
-+++ b/include/applets.h	5 Mar 2004 07:23:21 -0000
-@@ -178,6 +178,9 @@
- #if defined(CONFIG_FEATURE_GREP_EGREP_ALIAS)
- 	APPLET_NOUSAGE("egrep", grep_main, _BB_DIR_BIN, _BB_SUID_NEVER)
- #endif
-+#ifdef CONFIG_EJECT
-+	APPLET(eject, eject_main, _BB_DIR_USR_BIN, _BB_SUID_NEVER)
-+#endif
- #ifdef CONFIG_ENV
- 	APPLET(env, env_main, _BB_DIR_USR_BIN, _BB_SUID_NEVER)
- #endif
-Index: include/usage.h
-===================================================================
-RCS file: /var/cvs/busybox/include/usage.h,v
-retrieving revision 1.191
-diff -u -r1.191 usage.h
---- a/include/usage.h	25 Feb 2004 10:35:55 -0000	1.191
-+++ b/include/usage.h	5 Mar 2004 07:23:29 -0000
-@@ -537,6 +537,13 @@
- 	"\t-, -i\tstart with an empty environment\n" \
- 	"\t-u\tremove variable from the environment\n"
-
-+#define eject_trivial_usage \
-+	"[-t] [FILE]"
-+#define eject_full_usage \
-+	"Ejects the specified FILE or /dev/cdrom if FILE is unspecified.\n\n" \
-+	"Options:\n" \
-+	"\t-t, --trayclose\tclose tray\n"
-+
- #define expr_trivial_usage \
- 	"EXPRESSION"
- #define expr_full_usage \