소스 검색

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;