Преглед изворни кода

Bug(s) fixed: 214243
Bug Description: Advanced install loops at install sample entries
Reviewed by: nhosoi (Thanks!)
Fix Description: There were a couple of problems. The first problem is that askPopulate is not
a YesNo dialog, it is just a general Input dialog. The second problem is that
askPopulateSetup sets the input buffer size greater than the static buffer used
to hold the input in the Dialog class, which is defined as char _buf[MED_BUF].
So the solution is to set the InputLen to be MED_BUF-1, which allows for the
trailing null as well.
Platforms tested: FC5
Flag Day: no
Doc impact: no

Rich Megginson пре 19 година
родитељ
комит
379091dfc0
2 измењених фајлова са 5 додато и 3 уклоњено
  1. 4 2
      ldap/cm/newinst/ux-dialog.cc
  2. 1 1
      ldap/cm/newinst/ux-dialog.h

+ 4 - 2
ldap/cm/newinst/ux-dialog.cc

@@ -1034,7 +1034,7 @@ askSampleNext(Dialog *me)
 	return DIALOG_NEXT;
 }
 
-DialogYesNo askPopulate(
+DialogInput askPopulate(
 "You may wish to populate your new directory instance with some data.\n"
 "You may already have a file in LDIF format to use or some suggested\n"
 "entries can be added.  If you want to import entries from an LDIF\n"
@@ -1074,7 +1074,9 @@ askPopulateSetup(Dialog *me)
 	}
 
 	dialogSetup(me, SLAPD_KEY_INSTALL_LDIF_FILE, "none");
-	me->setInputLen(1024); // it seems to get reset somewhere . . .
+    // max input buffer size is sizeof(Dialog::_buf)-1
+    // Dialog::_buf is defined as char[MED_BUF]
+	me->setInputLen(MED_BUF-1); // it seems to get reset somewhere . . .
 
 	long setupval = 0;
 	if (me->getUserData(SETUP_DEFAULTS, setupval) == SETUP_ONLY ||

+ 1 - 1
ldap/cm/newinst/ux-dialog.h

@@ -54,7 +54,7 @@ extern DialogInput askSlapdSuffix;
 extern DialogInput askSlapdRootDN;
 extern DialogYesNo askReplication;
 extern DialogYesNo askSample;
-extern DialogYesNo askPopulate;
+extern DialogInput askPopulate;
 extern DialogInput askOrgSize;
 extern DialogYesNo askCIR;
 extern DialogInput askCIRHost;