update the patch to the current one I posted to bugzilla.samba.org
This commit is contained in:
parent
019e0ee6ef
commit
fa0bbbc00f
@ -2,78 +2,88 @@ Index: source/client/client.c
|
|||||||
===================================================================
|
===================================================================
|
||||||
--- source/client/client.c (revision 21918)
|
--- source/client/client.c (revision 21918)
|
||||||
+++ source/client/client.c (working copy)
|
+++ source/client/client.c (working copy)
|
||||||
@@ -3847,6 +3847,7 @@
|
@@ -3847,6 +3847,8 @@
|
||||||
char *p;
|
char *p;
|
||||||
int rc = 0;
|
int rc = 0;
|
||||||
fstring new_workgroup;
|
fstring new_workgroup;
|
||||||
+ BOOL first_opt = True;
|
+ BOOL tar_opt = False;
|
||||||
|
+ BOOL service_opt = False;
|
||||||
struct poptOption long_options[] = {
|
struct poptOption long_options[] = {
|
||||||
POPT_AUTOHELP
|
POPT_AUTOHELP
|
||||||
|
|
||||||
@@ -3900,6 +3901,44 @@
|
@@ -3899,7 +3901,42 @@
|
||||||
|
|
||||||
in_client = True; /* Make sure that we tell lp_load we are */
|
in_client = True; /* Make sure that we tell lp_load we are */
|
||||||
|
|
||||||
while ((opt = poptGetNextOpt(pc)) != -1) {
|
- while ((opt = poptGetNextOpt(pc)) != -1) {
|
||||||
|
+ /* let's fetch the first opt, this will fetch also arg0 (program name) which we will skip
|
||||||
|
+ * and eventually the service and the password */
|
||||||
|
+ opt = poptGetNextOpt(pc);
|
||||||
+
|
+
|
||||||
+ /* bad hack to cope with the breackage the -T option would cause
|
+ /* skip argv 0, (program name) */
|
||||||
+ * by eating the wrong arguments. We need to eat arg 0,[1,2] before */
|
+ poptGetArg(pc);
|
||||||
+ if (first_opt) {
|
|
||||||
+ int argind = 0;
|
|
||||||
+ while (poptPeekArg(pc)) {
|
|
||||||
+ switch(argind) {
|
|
||||||
+ case 0: /* progname */
|
|
||||||
+ poptGetArg(pc); /* skip */
|
|
||||||
+ break;
|
|
||||||
+
|
+
|
||||||
+ case 1: /* service name */
|
+ do {
|
||||||
+ pstrcpy(service,poptGetArg(pc));
|
+ /* this check is needed to insure that the -T tar option is forcibly the last one */
|
||||||
+ /* Convert any '/' characters in the service name to '\' characters */
|
+ /* I see no other way to keep things sane --SSS */
|
||||||
+ string_replace(service, '/','\\');
|
+ if (tar_opt == True) {
|
||||||
|
+ d_printf("ERROR: the tar option -T MUST be the last option specified on the command line\n");
|
||||||
|
+ poptPrintUsage(pc, stderr, 0);
|
||||||
|
+ exit(-1);
|
||||||
|
+ }
|
||||||
+
|
+
|
||||||
+ if (count_chars(service,'\\') < 3) {
|
+ /* if the service has not yet been specified lets see if it is available in the popt stack */
|
||||||
+ d_printf("\n%s: Not enough '\\' characters in service\n",service);
|
+ if (!service_opt && poptPeekArg(pc)) {
|
||||||
+ poptPrintUsage(pc, stderr, 0);
|
+ pstrcpy(service, poptGetArg(pc));
|
||||||
+ exit(1);
|
+ /* Convert any '/' characters in the service name to '\' characters */
|
||||||
+ }
|
+ string_replace(service, '/','\\');
|
||||||
+ break;
|
|
||||||
+ case 2: /* command line provided password */
|
|
||||||
+ cmdline_auth_info.got_pass = True;
|
|
||||||
+ pstrcpy(cmdline_auth_info.password,poptGetArg(pc));
|
|
||||||
+ break;
|
|
||||||
+
|
+
|
||||||
+ default:
|
+ if (count_chars(service,'\\') < 3) {
|
||||||
+ /* uh? garbage? */
|
+ d_printf("\n%s: Not enough '\\' characters in service\n",service);
|
||||||
+ d_printf("\nUnknown option: [%s]!\n", poptGetArg(pc));
|
+ poptPrintUsage(pc, stderr, 0);
|
||||||
+ poptPrintUsage(pc, stderr, 0);
|
+ exit(1);
|
||||||
+ exit(1);
|
|
||||||
+ }
|
|
||||||
+ argind++;
|
|
||||||
+ }
|
+ }
|
||||||
+ first_opt = False;
|
+ service_opt = True;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ /* if the service has already been retrieved then check if we have also a password */
|
||||||
|
+ if (service_opt && (!cmdline_auth_info.got_pass) && poptPeekArg(pc)) {
|
||||||
|
+ pstrcpy(cmdline_auth_info.password, poptGetArg(pc));
|
||||||
|
+ cmdline_auth_info.got_pass = True;
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
switch (opt) {
|
switch (opt) {
|
||||||
case 'M':
|
case 'M':
|
||||||
/* Messages are sent to NetBIOS name type 0x3
|
/* Messages are sent to NetBIOS name type 0x3
|
||||||
@@ -3959,7 +3998,7 @@
|
@@ -3954,13 +3991,9 @@
|
||||||
*/
|
poptPrintUsage(pc, stderr, 0);
|
||||||
optnum -= i;
|
exit(1);
|
||||||
for (i = 0; i < optnum; i++)
|
}
|
||||||
|
- /* Now we must eat (optnum - i) options - they have
|
||||||
|
- * been processed by tar_parseargs().
|
||||||
|
- */
|
||||||
|
- optnum -= i;
|
||||||
|
- for (i = 0; i < optnum; i++)
|
||||||
- poptGetOptArg(pc);
|
- poptGetOptArg(pc);
|
||||||
+ poptGetArg(pc);
|
|
||||||
}
|
}
|
||||||
|
+ /* this must be the last option, mark we have parsed it so that we know we have */
|
||||||
|
+ tar_opt = True;
|
||||||
break;
|
break;
|
||||||
case 'D':
|
case 'D':
|
||||||
@@ -3971,8 +4010,6 @@
|
pstrcpy(base_directory,poptGetOptArg(pc));
|
||||||
|
@@ -3969,10 +4002,8 @@
|
||||||
|
grepable=True;
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
- }
|
||||||
|
+ } while ((opt = poptGetNextOpt(pc)) != -1);
|
||||||
|
|
||||||
- poptGetArg(pc);
|
- poptGetArg(pc);
|
||||||
-
|
-
|
||||||
/* check for the -P option */
|
/* check for the -P option */
|
||||||
|
|
||||||
if ( port != 0 )
|
if ( port != 0 )
|
||||||
@@ -4011,23 +4048,6 @@
|
@@ -4011,23 +4042,6 @@
|
||||||
else
|
else
|
||||||
pstrcpy( calling_name, global_myname() );
|
pstrcpy( calling_name, global_myname() );
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user