A
download dhcp-3.0.2-extended_option_environment.patch
Language: NonCode
LOC: 0
Project Info
Pingwinek GNU/Linux(pingwinek)
Server: Gna!
Type: cvs
...ingwinek\pingwinek\patches\
   a2ps-gcc34.patch
   acpid-build.patch
   adns-destdir.patch
   anacron-build.patch
   antlr-box.patch
   apache-ant-antd.patch
   apache-ant-home.diff
   apache-ant-javah.patch
   ardour-build.patch
   atol-paths.patch
   aurora-library-build.patch
   aurora-panel-bugs.patch
   autogen-build.patch
   avidemux-build.patch
   backstep-build.patch
   barrage-desktop.patch
   ...command-not-found.patch
   bash-paths.diff
   bash-trap.patch
   binutils-fix.patch
   blam-build.patch
   blender-build.patch
   bluefish-desktop.diff
   bmp-wma-build.patch
   bonddb-build.patch
   boost-atomicity.patch
   bsd-finger-build.patch
   bsdiff-build.patch
   bzip2-makefile.diff
   cdemu-latest-kernel.patch
   cdparanoia-gcc34.patch
   childsplay-install.patch
   ...y-plugins-install.patch
   christine-shared.patch
   clanlib-build.patch
   compiz-build.patch
   confuse-shared.patch
   control-center-xkb.patch
   criawips-desktop.patch
   cuiterm-build.patch
   cups-ppdsdat.patch
   cvs-haiku-hacks.patch
   cvs-system-zlib.diff
   db-fhs.diff
   db-pthread.patch
   ...harp-glib-install.patch
   dctc-build.patch
   ...udio-player-paths.patch
   dhcdbd-build.patch
   ...ption_environment.patch
   ...ent-script-redhat.patch
   dhcp-fhs.diff
   dhcpcd-build.patch
   docbook-to-man-build.patch
   ...ook-utils-catalog.patch
   docbook-utils-elinks.patch
   dos2unix-fixes.patch
   drapes-build.patch
   drgeo-desktop.patch
   dsniff-build.patch
   dsniff-libnet11.patch
   eagle-usb-build.patch
   efax-gtk-desktop.patch
   efltk-build.patch
   eiciel-build.patch
   ekg2-build.patch
   emotion-build.patch
   entice-build.patch
   etcnet-config.patch
   evolution-gstreamer.patch
   ...rver__mmap_summary.diff
   faad-build.patch
   fam-build.diff
   fam-dnotify.diff
   fam-gcc34.patch
   fam-rpcsvc.diff
   fcron-destdir.patch
   festival-build.patch
   fftscope-gtk2.patch
   file-haiku-hacks.patch
   findutils-locate.patch
   firefox-lib-path.patch
   freewrl-build.patch
   g-wrap-build.patch
   gai-build.patch
   gammu-build.patch
   ganyremote-install.patch
   gazpacho-build.patch
   gcc-not-found.patch
   gcstar-install.patch
   gd-fontpath.patch
   gdb-system-readline.diff
   gdm-config.diff
   gexif-deprecated.patch
   gfilemanager-install.patch
   gg2-libnotify.patch
   ggseq-build.patch
   gimp-build.patch
   gimp-gcc4.patch
   git-gnu-install.patch
   glame-build.patch
   glib-haiku-hacks.patch
   glib1-build.patch
   glibc-localedata.diff
   glibrary-desktop.patch
   glom-gettext.patch
   glut-link.patch
   gnocky-bug.patch
   ...applets-gswitchit.patch
   ...e-menus-pingwinek.patch
   gnome-panel-config.patch
   ...ne-manager-pixmap.patch
   gnome-pilot-build.patch
   gnome-session-build.patch
   gnome-session-config.patch
   ...em-tools-grub_map.patch
   ...m-tools-pingwinek.patch
   ...e-terminal-config.patch
   gnome-themes-config.patch
   ...e-translate-build.patch
   ...late-selected-tag.patch
   ...ow-custom-widgets.patch
   gnomeicu-deprecated.patch
   gnuchess-build.patch
   gnusound-ffmpeg.patch
   goldwater-build.patch
   goldwater-soname.patch
   gpaint-gnome22.diff
   gpaint-imlib.diff
   gpdf-build.patch
   gplflash-build.patch
   gproftpd-desktop.patch
   groff-colors.patch
   grub-install.patch
   gsmlib-gcc34.patch
   gsoko-desktop.patch
   gsoko-gtk2.patch
   gst-ffmpeg-build.patch
   gtetrinet-fhs.patch
   ...-2.4.0-menushadow.patch
   gtk+-menu_size.patch
   gtk+-performance.patch
   gtk-doc-haiku-hacks.patch
   gtk-sharp-destdir.patch
   gtk-sharp-gtkhtml.patch
   ...ozembedmm-firefox.patch
   gtkperf-desktop.patch
   guniqueapp-build.patch
   gweled-bug.patch
   gweled-desktop.patch
   ...de-export-symbols.patch
   gwifimeter-install.patch
   haiku-build.patch
   hawknl-libname.patch
   heimdal-build.patch
   heimdal-link.patch
   helixplayer-build.patch
   hermes-build.patch
   howl-build.patch
   httpd-config.patch
   httpd-layout.patch
   ifplugd-build.patch
   ...ck-system-libltdl.patch
   indent-build.patch
   initng-livecd.patch
   initng-no-warnings.patch
   iplog-build.patch
   iproute2-pgw.diff
   iputils-pgw.diff
   ipw3945-build.patch
   iso-codes-pkgconfig.patch
   ...-ControlPanel-fix.patch
   kazehakase-build.patch
   kdebase-build.patch
   kdelibs-config.patch
   kdemultimedia-build.patch
   kvm-build.patch
   kvm-qemu-fixes.patch
   ladspa-build.patch
   lame-link.patch
   latex2html-build.patch
   libebml-build.patch
   libexif-gtk-build.patch
   libgenerics-install.patch
   libgnome-config.patch
   libgsm-makefile.patch
   libjpeg-fhs.patch
   libjpeg-haiku-shared.patch
   libmatroska-build.patch
   libmikmod-perms.diff
   libmpeg3-build.patch
   libnet-shared.diff
   libots-build.patch
   libpcap-shared.diff
   librhtv-build.patch
   libtextcat-devel.patch
   ...rrent-change-name.patch
   ...plugins-gstreamer.patch
   libxml2-haiku-hacks.patch
   links-languages.diff
   linneighborhood-gtk2.patch
   linux-initng.patch
   linux-sanity.patch
   linux-squashfs.patch
   linuxdcpp-build.patch
   littlewizard-build.patch
   log4cxx-build.patch
   lsdvd-build.patch
   make-haiku-hacks.patch
   man-not-found.patch
   mc-bash32.patch
   mc-haiku-hacks.patch
   mc-links.diff
   mc-pingwinek.patch
   mesa-demos-build.patch
   metacity-config.patch
   minicom-build.patch
   mjpegtools-build.patch
   mlview-build.patch
   monkeystudio-install.patch
   mono-build.patch
   mono-provreq.patch
   monodoc-destdir.patch
   mozilla-config.patch
   mozilla-freetype.patch
   mozilla-gcc-bugs.patch
   mozilla-latest-gcc.patch
   mplayer-desktop.patch
   mtools-destdir.patch
   mysql-build.patch
   nas-build.patch
   nautilus-build.patch
   nautilus-config.patch
   ncpfs-build.patch
   ncurses-haiku-fix.patch
   ndiswrapper-sandbox.patch
   ...s-libraries-build.patch
   net-tools-gcc34.patch
   net-tools-linux26.diff
   networkmanager-build.patch
   neverball-install.patch
   nginx-build.patch
   ooo-build-desktop.patch
   ooo-build-pingwinek.patch
   opal-build.patch
   openal-gcc42.patch
   openexr-build.patch
   opensp-gcc34.patch
   pacman-shared.patch
   pam-ac.patch
   pam-gcc.patch
   pam-shared.patch
   pcmciautils-udev.patch
   perl-gd-paths.patch
   ...ate-toolkit-paths.patch
   phat-build.patch
   phlib-gcc34.patch
   phlib-soname.patch
   php-config.patch
   phpmyadmin-config.patch
   pingus-build.patch
   pingus-prefix.patch
   pitfdll-latest.patch
   ...onfig-haiku-hacks.patch
   pkgconfig-pingwinek.patch
   plib-build.patch
   plib-shared.patch
   portmap-linux.diff
   ppp-build.patch
   prozgui-build.patch
   pwc-build.patch
   pwlib-build.patch
   python-json-install.patch
   ...on-pylucene-build.patch
   python-soap-build.patch
   ...-0.8.0-gcc4-hacks.patch
   qemu-0.8.3-gcc4.patch
   qsvn-qt4.patch
   quark-desktop.patch
   ...nge-applet-config.patch
   ...ktime4linux-build.patch
   qwt-fhs.patch
   readline-shared.patch
   rhythmbox-link.patch
   rtl8180-build.patch
   ...orrect-libtorrent.patch
   ruby-install.patch
   rubyripper-install.patch
   ...m-classpath-build.patch
   sablotron-expat.patch
   scintilla-build.patch
   scite-build.patch
   scite-config.patch
   screem-build.patch
   scribes-build.patch
   sdl-net-haiku-net.patch
   sdl-ttf-build.patch
   ...go-0.1.2-API-adds.patch
   setedit-build.patch
   shadow-login.diff
   smpeg-upstream.patch
   speech_tools-build.patch
   speedtouch-build.patch
   ...-selector-install.patch
   stlport-cxx.patch
   stlport-gcc34.patch
   ...ort-gcc3stdexcept.patch
   stlport-nodebug.patch
   stlport-soname.patch
   strace-build.patch
   stratagus-link.patch
   streamtuner-bmp.patch
   streamtuner-build.patch
   sudo-box.patch
   sudo-install.patch
   sudoku-savant-build.patch
   supertux-beos-hack.patch
   supertux-build.patch
   suspend-install.patch
   ...n-sensor-python23.patch
   sysklogd-linux26.diff
   syslinux-nowin32.patch
   ...s-backends-config.patch
   t1lib-build.patch
   tcp_wrappers-build.patch
   tcpdump-build.patch
   tesseract-build.patch
   texinfo-haiku-hacks.patch
   texmaker-build.patch
   tightvnc-gcc34.patch
   tightvnc-prefix.patch
   tightvnc-xsession.diff
   transfig-build.patch
   trophy-build.patch
   truevision-desktop.patch
   ...tream-vera-config.patch
   tvtime-build.patch
   udev-config.patch
   udev-modprobe.patch
   usbutils-config.patch
   util-linux-managed.patch
   vim-vimrc.diff
   vlc-desktop.patch
   vnc2swf-build.patch
   vrpe-glade-path.patch
   vsftpd-build.patch
   wahcade-build.patch
   webalizer-build.patch
   wikidpad-build.patch
   wormux-desktop.patch
   wvstreams-build.patch
   wvstreams-speex.patch
   wxwidgets-gtk24.patch
   wxwidgets-unicode.patch
   xaw3d-scrollbars.patch
   xcdroast-desktop.diff
   xchm-build.patch
   xfce-fm-build.patch
   xfce-panel-config.patch
   xfig-build.patch
   xfsprogs-build.patch
   xine-ui-desktop.patch
   xinetd-zombie.diff
   xmlrpc-epi-build.patch
   xmlrpc-epi-libname.patch
   xorg-getdriver.patch
   xpaint-build.patch
   xpdf-config.diff
   xplc-build.patch
   ypbind-errno.diff
   zopeinterface-build.patch

--- dhcp-3.0.2/common/parse.c.extended_option_environment	2005-04-05 17:49:36.513062562 -0400
+++ dhcp-3.0.2/common/parse.c	2005-04-05 17:49:36.580052656 -0400
@@ -1270,6 +1270,10 @@
 	option_hash_add (option -> universe -> hash,
 			 (const char *)option -> name,
 			 0, option, MDL);
+#ifdef EXTENDED_NEW_OPTION_INFO
+	if ( new_option_info_tree != 0L )
+		add_new_option_info( option );
+#endif
 	return 1;
 }
 
--- dhcp-3.0.2/common/tables.c.extended_option_environment	2004-09-01 13:06:35.000000000 -0400
+++ dhcp-3.0.2/common/tables.c	2005-04-05 18:04:23.915838623 -0400
@@ -1238,3 +1238,40 @@
 			   fqdn_universe.name, 0,
 			   &fqdn_universe, MDL);
 }
+
+#ifdef EXTENDED_NEW_OPTION_INFO
+#include <search.h>
+
+void *new_option_info_tree = 0L;
+
+static int  new_option_info_comparator( const void* p1, const void *p2 )
+{
+	uint32_t ocode1 =  (((const struct option*)p1)->universe->index << 8)
+		          |(((const struct option*)p1)->code),
+		 ocode2 =  (((const struct option*)p2)->universe->index << 8)
+	                  |(((const struct option*)p2)->code);
+	return( (ocode1 == ocode2) 
+		? 0 
+		:( ( ocode1 > ocode2 )
+		   ?  1
+		   : -1
+	         )
+	      );
+}
+
+void *add_new_option_info( struct option *option )
+{
+	if ( option->universe->index >= fqdn_universe.index )
+		return 0L;
+	if ( new_option_info_tree == GENERATE_NEW_OPTION_INFO )
+		new_option_info_tree = (void*)0L;
+	return tsearch( option, &(new_option_info_tree), new_option_info_comparator );
+}
+
+void *lookup_new_option_info( struct option *option )
+{
+	if ( new_option_info_tree == GENERATE_NEW_OPTION_INFO )
+		return 0L;
+	return tfind( option, &(new_option_info_tree), new_option_info_comparator );
+}
+#endif
--- dhcp-3.0.2/includes/dhcpd.h.extended_option_environment	2004-11-24 12:39:16.000000000 -0500
+++ dhcp-3.0.2/includes/dhcpd.h	2005-04-05 17:49:36.613047777 -0400
@@ -1800,6 +1800,13 @@
 void initialize_common_option_spaces PROTO ((void));
 struct universe *config_universe;
 
+#ifdef EXTENDED_NEW_OPTION_INFO
+#define GENERATE_NEW_OPTION_INFO ((void*)1)
+extern void   *new_option_info_tree;
+extern void   *add_new_option_info( struct option*);
+extern void   *lookup_new_option_info( struct option *);
+#endif
+
 /* stables.c */
 #if defined (FAILOVER_PROTOCOL)
 extern failover_option_t null_failover_option;
--- dhcp-3.0.2/client/dhclient.c.extended_option_environment	2005-04-05 17:49:36.566054726 -0400
+++ dhcp-3.0.2/client/dhclient.c	2005-04-05 17:49:36.617047185 -0400
@@ -74,7 +74,9 @@
 int onetry=0;
 int quiet=0;
 int nowait=0;
-
+#ifdef EXTENDED_NEW_OPTION_INFO
+int extended_option_environment = 0;
+#endif
 static void usage PROTO ((void));
 
 void do_release(struct client_state *);
@@ -204,6 +206,11 @@
 		} else if (!strcmp (argv [i], "--version")) {
 			log_info ("isc-dhclient-%s", DHCP_VERSION);
 			exit (0);
+#ifdef EXTENDED_NEW_OPTION_INFO
+		} else if (!strcmp (argv [i], "-x")) {
+		    extended_option_environment = 1;
+		    new_option_info_tree = GENERATE_NEW_OPTION_INFO;
+#endif
  		} else if (argv [i][0] == '-') {
  		    usage ();
 		} else {
@@ -572,7 +579,11 @@
 	log_info (arr);
 	log_info (url);
 
+#ifdef EXTENDED_NEW_OPTION_INFO
+	log_error ("Usage: dhclient [-1dqr] [-nwx] [-p <port>] %s",
+#else
 	log_error ("Usage: dhclient [-1dqr] [-nw] [-p <port>] %s",
+#endif
 		   "[-s server]");
 	log_error ("                [-cf config-file] [-lf lease-file]%s",
 		   "[-pf pid-file] [-e VAR=val]");
@@ -2529,8 +2540,28 @@
 struct envadd_state {
 	struct client_state *client;
 	const char *prefix;
+        struct universe *universe;
 };
 
+#ifdef EXTENDED_NEW_OPTION_INFO			
+static 
+void build_universe_info_envvar
+(      struct option_cache *oc,
+       struct packet *p, struct lease *l,
+       struct client_state *client,
+       struct option_state *in_o,
+       struct option_state *cf_o,
+       struct binding_scope **scope,
+       struct universe *u, void *es	          
+)
+{
+    char info_name[512], info_data[512];
+    snprintf(info_name, 512, "%s._universe_.", oc->option->universe->name);
+    snprintf(info_data, 512, "%u:%s", oc->option->code,oc->option->format);
+    client_envadd( client, info_name, oc->option->name, info_data );
+}
+#endif
+
 void client_option_envadd (struct option_cache *oc,
 			   struct packet *packet, struct lease *lease,
 			   struct client_state *client_state,
@@ -2547,6 +2578,31 @@
 				   in_options, cfg_options, scope, oc, MDL)) {
 		if (data.len) {
 			char name [256];
+#ifdef EXTENDED_NEW_OPTION_INFO			
+			if (  extended_option_environment )
+			{
+				if(  ( oc->option->universe != &dhcp_universe )
+				   &&( oc->option->universe->index > fqdn_universe.index )
+				   &&( es->universe !=  oc->option->universe )
+			          )
+				{
+					es->universe = oc->option->universe;
+					(*(es->universe->foreach))
+					     (  (struct packet *)0, (struct lease *)0, 
+						client_state, 
+						in_options, cfg_options, 
+						scope, es->universe, es, 
+						build_universe_info_envvar
+					     );
+				}else
+				if ( lookup_new_option_info(oc->option) != 0L )			   
+					build_universe_info_envvar
+					      ( oc, packet, lease, client_state, 
+						in_options, cfg_options, scope,
+						oc->option->universe, es 
+					      );
+			}
+#endif
 			if (dhcp_option_ev_name (name, sizeof name,
 						 oc -> option)) {
 				client_envadd (es -> client, es -> prefix,
@@ -2575,6 +2631,7 @@
 
 	es.client = client;
 	es.prefix = prefix;
+	es.universe = 0L;
 
 	client_envadd (client,
 		       prefix, "ip_address", "%s", piaddr (lease -> address));
@@ -2788,7 +2845,14 @@
 			s = option -> name;
 			if (j + 1 == buflen)
 				return 0;
+#ifdef EXTENDED_NEW_OPTION_INFO
+			if ( ! extended_option_environment )
+			    buf [j++] = '_';
+			else
+			    buf [j++] = '.';
+#else
 			buf [j++] = '_';
+#endif
 		}
 		++i;
 	} while (i != 2);
--- dhcp-3.0.2/client/dhclient.8.extended_option_environment	2004-09-29 19:01:46.000000000 -0400
+++ dhcp-3.0.2/client/dhclient.8	2005-04-05 17:49:36.619046889 -0400
@@ -78,6 +78,9 @@
 .B -w
 ]
 [
+.B -x
+]
+[
 .I if0
 [
 .I ...ifN
@@ -252,6 +255,10 @@
 supplying the
 .B -nw
 flag.
+.PP
+The -x argument enables eXtended option information to be created in the
+-s dhclient-script environment, which would allow applications running 
+in that environment to handle options they do not know about in advance.
 .SH CONFIGURATION
 The syntax of the dhclient.conf(5) file is discussed separately.
 .SH OMAPI

About Koders | Resources | Downloads | Support | Black Duck | Terms of Service | DMCA | Privacy Policy | Contact Us